LAMP 实现全过程及wordpress的搭建
一、介绍
1、 LAM(M)P:
L:linux
A:apache (httpd)
M:mysql, mariadb
M:memcached 缓存
P:php, perl, python
WEB 资源类型:
静态资源:原始形式与响应内容一致
动态资源:原始形式通常为程序文件,需要在服务器端执行之后,将执行结果返回给客户端
Web 相关语言
客户端技术: javascript ,html
服务器端技术:php, jsp,python
2、LAMP的工作原理:
cat /etc/mime.types 查看http默认支持的文件后缀,默认不支持PHP
二、centos 6 编译安装LAMP,php基于FPM模式的应用WordPress
原理:实现LAMP的全过程,基于FPM模式:php以独立服务建立,且实现xcache加速
注意:一定要确保自己在纯净的环境,若有httpd、mysql、php请事先卸载
1、准备各个包,软件+相关的包
mkdir /root/src 准备个目录放包
① 软件包
apr-1.6.2.tar.gz
apr-util-1.6.0.tar.gz
httpd-2.4.28.tar.bz2
mariadb-5.5.57-linux-x86_64.tar.gz
php-5.6.31.tar.xz
wordpress-4.8.1-zh_CN.tar.gz
xcache-3.2.0.tar.gz
② 所依赖的相关包
openssl-devel expat-devel pcre-devel http所依赖的
bzip2-devel libxml2-devel libmcrypt-devel php所依赖的,注意:需epel扩展源
2、编译httpd2.4(用方法二)
① 解包解压缩,把3个都放到统一目录httpd-2.4.28下
tar xvf apr-1.6.2.tar.gz
tar xvf apr-util-1.6.0.tar.gz
tar xvf httpd-2.4.28.tar.bz2
mv apr-1.6.2 httpd-2.4.28/srclib/apr
mv apr-util-1.6.0 httpd-2.4.28/srclib/apr-util
② 执行脚本
cd /root/src/httpd-2.4.28
./configure --prefix=/app/httpd24 \
--enable-so \
--enable-ssl \
--enable-cgi \
--enable-rewrite \
--with-zlib \
--with-pcre \
--with-included-apr \
--enable-modules=most \
--enable-mpms-shared=all \
--with-mpm=prefork
③ 并行、多线程编译安装
make -j 4 && make install
3、编译安装http 后的设置
① 修改PATH路径,因为是编译安装
vim /etc/profile.d/lamp.sh
PATH=/app/httpd24/bin:/usr/local/mysql/bin/:/app/php/bin/:$PATH 顺便把后边的mysql和php的也设置进去
. /etc/profile.d/lamp.sh 让设置生效
② 设置开机自启
cp /etc/init.d/httpd /etc/init.d/httpd24 拷个服务脚本,没有的话去其他机器拷一个
vim /etc/init.d/httpd24 修改路径
chkconfig --add httpd24 设置开机启动,哪个级别
service httpd24 start 开启服务
4、二进制安装mariadb-5.5.57
(1) 解包解压缩
tar xvf mariadb-5.5.57-linux-x86_64.tar.gz -C /usr/local/
(2) 创建mysql用户
① 加硬盘,创建逻辑卷,存放数据库
以为要存放数据库,最好空间越大越好,这里用一个硬盘作为逻辑卷,不够可以加空间
echo '- - -' > /sys/class/scsi_host/host2/scan 同步硬盘,虚拟机才能用,host2不行就host0
② 创建逻辑卷
pvcreate /dev/sdb 创建pv
vgcreate vg_mysqldb /dev/sdb 创建vg
lvcreate -n lv_mysqldb -l +100%FREE vg_mysqldb 创建lv
mkfs.ext4 /dev/vg_mysqldb/lv_mysqldb -L /data/mysqldb 文件系统格式化
③ 挂载
mkdir /data/mysqldb -p 创建挂载点,就是数据库存放的地方
vim /etc/fstab 设置开机自动挂载
/dev/vg_mysqldb/lv_mysqldb /data/mysqldb ext4 defaults,acl 0 0
mount -a 挂载
④ 创建用户
useradd -d /data/mysqldb -r -m -s /sbin/nologin mysql
chown mysql /data/mysqldb/
(3) cd /usr/local/ 发现mariadb的目录名字不符合要求
ln -s mariadb-5.5.57-linux-x86_64/ mysql 创建软连接也可以改名
(4) 创建修改配置文件
① 拷贝配置文件
cd /usr/local/mysql/
ls support-files/ 包里自带的有配置文件,但地方不对,要放在/etc/mysql/my.cnf
mkdir /etc/mysql
cp support-files/my-huge.cnf /etc/mysql/my.cnf
② 修改配置文件
vim /etc/mysql/my.cnf 修改配置文件
[mysqld]
datadir = /data/mysqldb //指定总目录,必须的
innodb_file_per_table = on //让每一个表数据库都是一个文件,方便管理
skip_name_resolve = on //忽略名字的反向解析,加快速度
(5)执行脚本,创建系统数据库
cd /usr/local/mysql 一定要在这个目录下执行脚本,因为脚本写死了
./scripts/mysql_install_db --user=mysql --datadir=/data/mysqldb 执行脚本
完成后就会在/app/mysqldb/ 生成mysql系统数据库
(6)把服务脚本复制过去
cp support-files/mysql.server /etc/init.d/mysqld
chkconfig --add mysqld 设置服务在哪个运行级别,在哪个运行级别开启服务
chkconfig --list mysqld
service mysqld start 失败,看失败原因:缺少日志文件,日志文件须有读写权限
(7)创建日志文件
touch /var/log/mysqld.log
chown mysql /var/log/mysqld.log
service mysqld start 开启成功
(8)运行安全初始化脚本,同上实验
mysql_secure_installation
(9)运行mysql,创建WordPress的数据库和管理员并授权
mysql -uroot -palong(自己设的密码)
MariaDB [(none)]> create database blogdb;
MariaDB [(none)]> grant all on blogdb.* to 'wpadm'@'localhost' identified by 'along' ;
4、编译安装php-5.6.31
① 解包 tar xvf
② 执行脚本
cd /root/src/php-5.6.31
./configure \
--prefix=/app/php \
--with-mysql=/usr/local/mysql \
--with-openssl \
--with-mysqli=/usr/local/mysql/bin/mysql_config \
--enable-mbstring \
--with-freetype-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib \
--with-libxml-dir=/usr \
--enable-xml \
--enable-sockets \
--enable-fpm \
--with-mcrypt \
--with-config-file-path=/etc/php/ \
--with-config-file-scan-dir=/etc/php.d \
--with-bz2
③ make -j 4 && make install
④ 创建并修改php 的配置文件和服务脚本
cd /root/src/php-5.6.31 在编译源代码的路径
mkdir /etc/php
cp php.ini-production /etc/php/php.ini 复制生产类型的配置文件
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm 复制个模板
chmod +x /etc/init.d/php-fpm
⑤ 编辑php配置文件
cd /app/php/etc 在编译源后的路径
cp /app/php/etc/php-fpm.conf.default /app/php/etc/php-fpm.conf
注意:在centos 7 中php-fpm.conf.default 和www.conf.default 这两个文件都需要cp,但centos 6把这两个文件合在php-fpm.conf.default 中了
略:vim /app/php/etc/php-fpm.conf 可以不修改,根据自己想要的设置
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 5 和pm.start_servers 一致
pid = /app/php/var/run/php-fpm.pid
⑥ 开启php-ftm服务
service php-fpm start
ss -ntl 开启9000端口
chkconfig --add php-fpm
5、修改http的主配置文件,让其支持php
① 取消两行对模块的注释,默认被注释了
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
② 修改下面行
DirectoryIndexindex.phpindex.html
③ 加下面四行
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/app/httpd24/htdocs/$1
6、布署wordpress
① 解包解压缩
② 把所有东西移到/app/httpd24/htdocs/
cd /src/wordpress
rm -rf /app/httpd24/htdocs/*
mv wordpress/* /app/httpd24/htdocs/
③ 准备WordPress的配置文件 wp-config.php
cd /app/httpd24/htdocs
cp wp-config-sample.php wp-config.php
vim wp-config.php 修改4行
define('DB_NAME', 'blogdb');
define('DB_USER', 'wpadm');
define('DB_PASSWORD', 'along');
define('DB_HOST', 'localhost');
④ 网页打开,设置,成功
⑤ ab 测试性能
ab -c 10 -n 100 http://192.168.30.111/
7、编译安装xcache
① 解包
tar xvf xcache-3.2.0.tar.gz
② 执行脚本
cd xcache-3.2.0 发现没有configure脚本
yum -y install php-devel
phpize 安装包,执行这个命令,生成configure脚本
./configure --enable-xcache --with-php-config=/app/php/bin/php-config
③ 编译安装
make && make install
④ 修改配置文件
mkdir /etc/php.d/
cp xcache.ini /etc/php.d/
ls /app/php/lib/php/extensions/no-debug-non-zts-20131226/
vim /etc/php.d/xcache.ini 因为是源码编译,xcache不是放在对应路径下,所以需修改
extension = /app/php/lib/php/extensions/no-debug-non-zts-20131226/xcache.so 修改此行
service php-fpm restart
8、测试
① ab 测试性能
ab -c 10 -n 100 http://192.168.30.111/ 确实性能提升很大
② 也可用文件测试
/app/httpd24/htdocs
vim a.php
<?php
phpinfo() 确认xcache 已加载
?>
能看到xcache模块的信息
三、centos 7 编译安装LAMP,php基于模块的应用WordPress
原理:实现LAMP的全过程,php基于FPM模式:php以独立服务建立,且实现xcache加速
注意:一定要确保自己在纯净的环境,若有httpd、mysql、php请事先卸载
1、准备各个包,软件+相关的包
mkdir /root/src 准备个目录放包
① 软件包
apr-1.6.2.tar.gz
apr-util-1.6.0.tar.gz
httpd-2.4.28.tar.bz2
mariadb-10.2.9-linux-x86_64.tar.gz
php-7.1.10.tar.xz
phpMyAdmin-4.0.10.20-all-languages.zip
wordpress-4.8.1-zh_CN.tar.gz
xcache-3.2.0.tar.gz
② 所依赖的相关包
openssl-devel expat-devel pcre-devel http所依赖的
bzip2-devel libxml2-devel libmcrypt-devel php所依赖的,注意:需epel扩展源
yum -y install openssl-devel expat-devel pcre-devel
yum -y install bzip2-devel libxml2-devel libmcrypt-devel
2、编译httpd2.4(用方法一)
① 解包解压缩,3个各自编译安装各自的
apr-1.6.2.tar.bz2
apr-util-1.6.0.tar.bz2
httpd-2.4.28.tar.bz2
② 安装apr-1.6.2.tar.bz2
cd apr-1.6.2
./configure --prefix=/app/apr 执行脚本
make && make install 并行编译安装
③ 安装apr-util-1.6.0.tar.bz2
cd ../apr-util-1.6.0
./configure --prefix=/app/apr-util --with-apr=/app/apr/
make -j 2 && make install
检查是否成功:ls /app/apr-util/
④ 编译安装httpd-2.4
cd ../httpd-2.4.28
./configure --prefix=/app/httpd24 \
--enable-so \
--enable-ssl \
--enable-cgi \
--enable-rewrite \
--with-zlib \
--with-pcre \
--with-apr=/app/apr/ \
--with-apr-util=/app/apr-util/ \
--enable-modules=most \
--enable-mpms-shared=all \
--with-mpm=prefork 执行脚本
⑤ make -j 4 && make install 并行,多线程编译安装
3、编译安装http 后的设置
① 修改PATH路径,因为是编译安装
vim /etc/profile.d/lamp.sh
PATH=/app/httpd24/bin:/usr/local/mysql/bin/:/app/php/bin/:$PATH 顺便把后边的mysql和php的也设置进去
. /etc/profile.d/lamp.sh 让设置生效
② 启动服务
apachectl 启动服务
ss -tnl 查看端口
4、二进制安装mariadb-10.2.8
(1) 解包解压缩
tar xvf mariadb-10.2.9-linux-x86_64.tar.gz -C /usr/local/
(2) 创建mysql用户
useradd -d /app/mysqldb -r -m -s /sbin/nologin mysql
chown mysql /app/mysqldb/
(3) cd /usr/local/ 发现mariadb的目录名字不符合要求
ln -s mariadb-10.2.9-linux-x86_64/ mysql 创建软连接也可以改名
(4) 创建修改配置文件
① 拷贝配置文件
cd /usr/local/mysql/
ls support-files/ 包里自带的有配置文件,但地方不对,要放在/etc/mysql/my.cnf
mkdir /etc/mysql
cp support-files/my-huge.cnf /etc/mysql/my.cnf
② 修改配置文件
vim /etc/mysql/my.cnf 修改配置文件
[mysqld]
datadir = /app/mysqldb //指定总目录,必须的
innodb_file_per_table = on //让每一个表数据库都是一个文件,方便管理
skip_name_resolve = on //忽略名字的反向解析,加快速度
(5)执行脚本,创建系统数据库
cd /usr/local/mysql 一定要在这个目录下执行脚本,因为脚本写死了
./scripts/mysql_install_db --user=mysql --datadir=/app/mysqldb 执行脚本
完成后就会在/app/mysqldb/ 生成mysql系统数据库
(6)把服务脚本复制过去
cp support-files/mysql.server /etc/init.d/mysqld
chkconfig --add mysqld 设置服务在哪个运行级别,在哪个运行级别开启服务
chkconfig --list mysqld
service mysqld start 失败,看失败原因:缺少日志文件,日志文件须有读写权限
(7)创建日志文件
mkdir /var/log/mariadb/
touch /var/log/mariadb/mariadb.log
chown mysql /var/log/mariadb/mariadb.log
service mysqld start 开启成功
(8)运行安全初始化脚本
mysql_secure_installation
(9)运行mysql,创建WordPress的数据库和管理员并授权
mysql -uroot -palong(自己设的密码)
MariaDB [(none)]> create database blogdb;
MariaDB [(none)]> grant all on blogdb.* to 'wpadm'@'localhost' identified by 'along' ;
5、编译安装php-7.1.10
① 解包 tar xvf
② 执行脚本
cd /root/src/php-7.1.10/
./configure \
--prefix=/app/php \
--enable-mysqlnd \
--with-mysqli=mysqlnd \
--with-openssl \
--with-pdo-mysql=mysqlnd \
--enable-mbstring \
--with-freetype-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib \
--with-libxml-dir=/usr \
--enable-xml \
--enable-sockets \
--with-apxs2=/app/httpd24/bin/apxs \ (php基于模块方式)
--with-mcrypt \
--with-config-file-path=/etc \
--with-config-file-scan-dir=/etc/php.d \
--enable-maintainer-zts \
--disable-fileinfo
③ make -j 4 && make install
④ 创建并修改php 的配置文件和服务脚本
cp php.ini-production /etc/php.ini
vim /app/httpd24/conf/httpd.conf
在文件尾部加两行
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
修改下面行
<IfModule dir_module>
DirectoryIndex index.php index.html
</IfModule>
apachectl stop
apachectl
⑤ 测试
测试php和mariadb连接
vim /app/httpd24/htdocs/index.php
<?php
$mysqli=new mysqli("localhost","root","along");
if(mysqli_connect_errno()){
echo "连接数据库失败!";
$mysqli=null;
exit;
}
echo "连接数据库成功!";
$mysqli->close();
phpinfo();
?>
6、布署phpmyadmin
注意:不要随便下载最新版,因为有的版本不支持PHP有些版本,例:4.7只支持php7.2
1、rz、解压缩,装包
unzip phpMyAdmin-4.0.10.20-all-languages.zip
2、cp -r phpMyAdmin-4.0.10.20-all-languages /app/httpd24/htdocs/pma/ 把文件放到//app/httpd24/htdocs下
网页打开发现确实东西 php-mbstring包
yum -y install php-mbstring
systemctl restart httpd 重启服务
3、在网页上设置数据库
① 登录
② 创建wpdb数据库,一会给WordPress用
③ 创建用户wpuser,
给他对wpdb数据库的全部权限
③ 加下面四行
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/app/httpd24/htdocs/$1
7、布署wordpress
① 解包解压缩
② 把所有东西移到/app/httpd24/htdocs/
cd /src/wordpress
mv wordpress/* /app/httpd24/htdocs/
③ 准备WordPress的配置文件 wp-config.php
cd /app/httpd24/htdocs
cp wp-config-sample.php wp-config.php
vim wp-config.php 修改4行
define('DB_NAME', 'wpdb');
define('DB_USER', 'along');
define('DB_PASSWORD', 'along');
define('DB_HOST', '192.168.30.222');
④ 网页打开,设置,成功
⑤ ab 测试性能
ab -c 10 -n 100 http://192.168.30.111/
实验就到这里了~~~
LAMP 实现全过程及wordpress的搭建的更多相关文章
- lamp+nginx代理+discuz+wordpress+phpmyadmin搭建
我们以模拟实际需求的形式来复习.需求如下:1. 准备两台centos 6,其中一台机器跑mysql,另外一台机器跑apache和nginx + php2. 同时安装apache和nginx,其中ngi ...
- Lamp(linux+apache+mysql+php)环境搭建
Lamp(linux+apache+mysql+php)环境搭建 .安装apache2:sudo apt-get installapache2 安装完毕后.执行例如以下命令重新启动apache:sud ...
- 爬虫管理平台以及wordpress本地搭建
爬虫管理平台以及wordpress本地搭建 学习目标: 各爬虫管理平台了解 scrapydweb gerapy crawlab 各爬虫管理平台的本地搭建 Windows下的wordpress搭建 爬虫 ...
- 在centos7上实现LAMP的全过程及实现wordpress
原理 http使用方法一编译安装,php独立服务fpm实现. 软件版本 在本次实验中,我们需要用到的软件版本如下: apr-1.6.2 apr-util-1.6.0 httpd-2.4.28 mari ...
- Centos7.2 搭建Lamp服务器以及迁移WordPress个人博客详细过程
其实自己的博客搭了有段时间了,但是由于自己不太确定是不是一定要用wd的框架,以及实验室公网服务器的不稳定,就一直荒废着. 今天偶然间看到了腾讯云对于学生的优惠活动,毕业之前每月只要8元的云服务器(就算 ...
- Centos7下搭建LAMP环境,安装wordpress(不会生产博客,只是一名博客搬运工)(菜鸟)
1.搭建MySQL数据库 安装MariaDB yum install mariadb-server -y 启动MySQL服务 emctl start mariadb #启动服务 emtcl enabl ...
- LAMP平台-wordpress的搭建
LAMP平台-wordpress的搭建 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Linux+Apache+Mysql/MariaDB+Perl/PHP/Python一组常用来 ...
- lamp+nginx代理+discuz+wordpress+phpmyadmin
实验课题:搭建LAMP,安装Nginx,作为代理,将MySQL安装在单独的机器,apache负责动态,nginx负责静态 实验环境: 1.VMware Workstation 11 2.设备A:MyS ...
- L(kali)A(apache)M(mysql)P(php)环境+wordpress站点搭建
一:LAMP环境配置 首先LAMP(linux+apache+mysql+php)即为本次搭建网站所需的环境,由于本次使用的debian衍生版kali版本自带lamp,因此只要在服务器上启动相应服务既 ...
随机推荐
- 转 Java输入输出流详解(非常详尽)
转 http://blog.csdn.net/zsw12013/article/details/6534619 通过数据流.序列化和文件系统提供系统输入和输出. Java把这些不同来源和目标的数据都 ...
- hibernate中Query的list和iterator区别(续)
打开cache后query的list和iterator方法区别 将query 的cache打开的话,缓存的是query本身,以hql 生成的 sql ,再加上参数,分页等信息做为key值,而不是que ...
- MySQL集群(四)之keepalived实现mysql双主高可用
前面大家介绍了主从.主主复制以及他们的中间件mysql-proxy的使用,这一篇给大家介绍的是keepalived的搭建与使用! 一.keepalived简介 1.1.keepalived介绍 Kee ...
- 图文详解在Windows server 2008 R2上安装SQL Server 2012集群
1.准备: 4台服务器(1台AD.2台SQL服务器.1台iSCSI存储服务器) 9个IP(1个AD的IP.2个SQL服务器的IP.2个心跳IP.1个iSCSI存储服务器的IP.1个集群IP.1个DTC ...
- 深入浅出AQS之独占锁模式
每一个Java工程师应该都或多或少了解过AQS,我自己也是前前后后,反反复复研究了很久,看了忘,忘了再看,每次都有不一样的体会.这次趁着写博客,打算重新拿出来系统的研究下它的源码,总结成文章,便于以后 ...
- #pragma编译指令
#pragma alignment#pragma anon_struct#pragma argsused#pragma checkoption#pragma codeseg#pragma commen ...
- 代理模式与java中的动态代理
前言 代理模式又分为静态代理与动态代理,其中动态代理是Java各大框架中运用的最为广泛的一种模式之一,下面就用简单的例子来说明静态代理与动态代理. 场景 李雷是一个唱片公司的大老板,很忙, ...
- IDE快捷键
visual studio 中 : /// 快速函数注释 ctrl+k,ctrl+F 格式化代码 Android Studio 中: /**回车 快速函数注释 ctrl+h 查看继承关系 自动格式化 ...
- eslint使用
参考文档 http://www.cnblogs.com/hahazexia/p/6393212.html http://blog.guowenfh.com/2016/08/07/ESLint-Rule ...
- java web Servlet 学习笔记 -3 会话管理技术
Cookie和HttpSession 什么是会话: 用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 每个用户在使用浏览器与服务器进行会话的过 ...