LAMP之AMP分离+XCache加速
搭建LAMP平台,要求apache、php、MariaDB分别在不同服务器实现动静分离,不需要考虑动态服务器和静态服务器数据同步问题;在LAMP平台之上,搭建博客和论坛,博客和论坛分别位于不同主机;
公网用户除了可以访问httpd之外不能访问内网任何一台服务器;
部署完成使用ab命令进行压力测试,并且部署Xcache为php提供加速功能。
环境拓扑如下所示:
部署思路网络环境:
Apache服务器使用双网卡,一块网卡监听外网用户请求,一块网卡和内网服务区进行通信,apache的内网网卡和其他服务器使用交换机进行连接。
Apache和php交互:
Apache和php交互有三种方式,cgi,模块方式,fcgi;但是cgi和fcgi跨主机访问php服务器,所以apache和php服务器只能使用fcgi方式进行交互。
php和MariaDB交互:
安装bbs和blog时,会要求提供MariaDB数据库和用户密码等信息,所以只需要在MariaDB数据创建好相关的数据库和用户,然后在保证php服务器可以访问即可。
bbs和blog安装问题:
[*]安装的程序包需要在apache和php服务器都存在一份,apache提供静态页面访问,php提供动态页面访问;不考虑同步问题
[*]如果出现要求对程序有写入权限,静态服务器设置apache的服务用户daemon对文件可写,动态服务器设置php-fpm的服务用户nobody对文件可写。
实验环境
系统版本
主机名
ip地址
Apache
Centos 6.6 64位
web-01
外网:eth0: 1.1.1.1
内网:eth1:172.16.4.100
论坛
Centos 6.6 64位
bbs-01
内网: eth0:172.16.4.101
博客
Centos 6.6 64位
blog-01
内网: eth0:172.16.4.102
数据库
Centos 6.6 64位
MariaDB-01
内网:eth0:172.16.4.136
使用软件
1
2
3
4
5
6
7
8
apr-1.5.0.tar.bz2
apr-util-1.5.3.tar.bz2
httpd-2.4.10.tar.bz2
mariadb-5.5.43-linux-x86_64.tar.gz
php-5.4.40.tar.bz2
wordpress-3.3.1-zh_CN.zip
xcache-3.2.0.tar.bz2
Discuz_7.2_FULL_SC_UTF8.zip
Apache配置解决依赖关系
1
2
3
4
5
6
7
8
9
10
11
12
13
14
yum -y groupinstall "Development tools""Desktop Platform Development"
yum -y install pcre-devel openssl-devel
tar xf apr-1.5.0.tar.bz2
cd apr-1.5.0
./configure --prefix=/usr/local/apr
make && make install
cd ..
tar xf apr-util-1.5.3.tar.bz2
cd apr-util-1.5.3
./configure --prefix=/usr/local/apr-util--with-apr=/usr/local/apr
make && make install
cd ..
编译安装httpd
1
2
3
4
tar xf httpd-2.4.10.tar.bz2
cd httpd-2.4.10
./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd24--enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre--with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util/--enable-modules=most --enable-mpms-shared=all --with-mpm=event
make && make install
修改PATH变量,让系统可以直接找到http的命令路径
1
2
3
4
5
# vim/etc/profile.d/httpd.sh
export PATH=/usr/local/acaphe/bin:$PATH
# ./etc/profile.d/httpd.sh
# which httpd
/usr/local/apache/bin/httpd
设置启动脚本
1
2
3
4
5
6
7
8
9
# cp/usr/local/apache/bin/apachectl /etc/init.d/httpd24
# vim /etc/init.d/httpd24
#!/bin/sh
# chkconfig: 35 85 15 #设置服务识别参数,3、5级别启动,启动顺序85,关闭顺序15
# description: Apache #服务描述信息
# chkconfig --add httpd24
# chkconfig --level 35 httpd24 on
# chkconfig --list httpd24
httpd24 0:off1:off2:off3:on 4:off5:on 6:off
修改httpd配置文件设置监听的端口
1
2
3
# vim /etc/httpd24/httpd.conf
Listen 1.1.1.1:80
Listen 172.16.4.100:80
启动服务并访问验证
1
2
3
4
# service httpd24 start
# netstat -lnt | grep 80
tcp 0 0 172.16.4.100:80 0.0.0.0:* LISTEN
tcp 0 0 1.1.1.1:80 0.0.0.0:* LISTE
虚拟主机配置编辑主配置文件,注释中心主机,启用虚拟主机选项
1
2
3
# vim /etc/httpd24/httpd.conf
#DocumentRoot "/usr/local/apache/htdocs"
Include /etc/httpd24/extra/httpd-vhosts.conf
设置虚拟主机
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# vim/etc/httpd24/extra/httpd-vhosts.conf
<VirtualHost *:80>
ServerName bbs.discuz.com
DocumentRoot "/www/bbs"
<Directory "/www/bbs">
Options none
AllowOverride none
Require all granted
</Directory>
ErrorLog"/var/log/httpd/bbs-error-log"
CustomLog"/var/log/httpd/bbs-access-log" common
</VirtualHost>
<VirtualHost *:80>
ServerName blog.wordpress.com
DocumentRoot "/www/blog"
<Directory "/www/blog">
Options none
AllowOverride none
Require all granted
</Directory>
ErrorLog"/var/log/httpd/blog-error-log"
CustomLog"/var/log/httpd/blog-access-log" common
</VirtualHost>
设置虚拟主机目录
1
2
3
# mkdir -p /www/{bbs,blog}
# echo bbs > /www/bbs/index.html
# echo blog > /www/blog/index.html
访问测试虚拟主机
MariaDB配置配置/dev/sda3为lvm分区
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# fdisk -l /dev/sda
Disk /dev/sda: 128.8 GB, 128849018880 bytes
255 heads, 63 sectors/track, 15665 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x000471dd
DeviceBoot Start End BlocksIdSystem
/dev/sda1* 1 26 20480083Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 26 7859 62914560 8eLinux LVM
/dev/sda3 7859 11775 31462303+ 8eLinux LVM
创建逻辑卷
1
2
3
4
5
6
7
8
9
10
# lvcreate /dev/sda3
# vgcreate myvg /dev/sda3
# lvcreate -L 15G -n mydata myvg
# lvs
LV VGAttr LSizePool Origin Data%Meta% Move Log Cpy%Sync Convert
mydata myvg-wi-a----- 15.00g
root vg0 -wi-ao---- 20.00g
swap vg0 -wi-ao----2.00g
usr vg0 -wi-ao---- 10.00g
var vg0 -wi-ao---- 20.00g
格式化并挂载
1
2
3
4
5
# mkfs.ext4 /dev/myvg/mydata
# vim /etc/fstab
/dev/myvg/mydata /mydata ext4 defaults 0 0
# mkdir /mydata
# mount -a
创建MariaDB服务用户,并且设置数据目录的属主属组为服务用户
1
2
3
4
# groupadd -r mysql
# useradd -g mysql -r -s/sbin/nologin -M mysql
# mkdir /mydata/data
# chown -R mysql:mysql/mydata/data/
安装MariaDB并初始化
1
2
3
4
5
6
tar xf mariadb-5.5.43-linux-x86_64.tar.gz -C/usr/local/
cd /usr/local/
ln -sv mariadb-5.5.43-linux-x86_64/ mysql
cd mysql/
chown -R mysql:mysql .
scripts/mysql_install_db --user=mysql--datadir=/mydata/data/
为MariaDB提供主配置文件
1
2
3
4
5
# cpsupport-files/my-large.cnf /etc/my.cnf
# vim /etc/my.cnf
thread_concurrency = 2 #设置CPU核心数量乘以2
datadir = /mydata/data #设置数据文件目录
innodb_file_per_table = 1#使用inoodb引擎,每表一个表文件
为MariaDB提供启动脚本
1
2
3
4
5
# cpsupport-files/mysql.server /etc/rc.d/init.d/mysqld
# chkconfig --add mysqld
# chkconfig mysqld on
# chkconfig --list mysqld
mysqld 0:off1:off2:on 3:on 4:on 5:on 6:off
修改PATH环境变量,让系统直接使用MariaDB相关命令
1
2
3
# vim /etc/profile.d/mysql.sh
export PATH=/usr/local/mysql/bin:$PATH
# . /etc/profile.d/mysql.sh
启动测试
1
2
3
4
5
6
7
8
9
10
11
12
# service mysqld start
Starting MySQL...
# mysql
Welcome to the MariaDB monitor.Commands end with ; or \g.
Your MariaDB connection id is 2
Server version: 5.5.43-MariaDB-log MariaDB Server
Copyright (c) 2000, 2015, Oracle, MariaDBCorporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clearthe current input statement.
MariaDB [(none)]>
动态服务器blog配置Php-fpm配置编译安装php依赖于MariaDB的文件,但是不需要对MariaDB进行任何配置,只需要解压到指定目录即可。
解压MariaDB到指定位置
1
2
3
tar xf mariadb-5.5.43-linux-x86_64.tar.gz -C/usr/local/
cd /usr/local/
ln -sv mariadb-5.5.43-linux-x86_64/ mysql
安装php依赖软件包
1
yum -y install libmcrypt libmcrypt-devel mhashmhash-devel openssl-devel bzip2-devel
编译安装php
1
2
3
4
tar xf php-5.4.40.tar.bz2
cd php-5.4.40
./configure --prefix=/usr/local/php5--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 --with-config-file-scan-dir=/etc/php.d--with-bz2
make && make install
为php提供配置文件
1
# cp php.ini-production/etc/php.ini
为php-fpm提供配置文件
1
# cp/usr/local/php5/etc/php-fpm.conf.default /usr/local/php5/etc/php-fpm.conf
为php-fpm提供启动脚本
1
2
3
4
# cpsapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm
# chmod +x/etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on
修改php-fpm设置
1
2
3
4
5
6
7
# vim/usr/local/php/etc/php-fpm.conf
pm.max_children = 50 #每个进程的子进程数据
pm.start_servers = 5 #启动时开启的进程数
pm.min_spare_servers = 2 #最少空闲机舱内
pm.max_spare_servers = 8 #最多空闲进程
pid = /usr/local/php/var/run/php-fpm.pid
listen = 172.16.4.102:9000 #设置监听的地址,需要保证web服务器可以访问此地址。
启动并验证
1
2
3
4
# service php-fpm start
# netstat -lnt | grepphp-fpm
# netstat -lnt | grep:9000
tcp 0 0 172.16.4.102:9000 0.0.0.0:* LISTEN
查看启动的进程
1
2
3
4
5
6
7
8
# ps aux | grep php-fpm
root 125690.00.0 103252832 pts/0 S+ 06:480:00 grep php-fpm
root 978110.00.4 155924 4084 ? Ss 04:050:01 php-fpm: master process (/usr/local/php5/etc/php-fpm.conf)
nobody 978120.02.5 175708 26068 ? S 04:05 0:03 php-fpm: poolwww
nobody 978130.02.5 175936 25992 ? S 04:05 0:04 php-fpm: poolwww
nobody 978140.02.1 170612 21372 ? S 04:05 0:02 php-fpm: poolwww
nobody 978150.02.0 170584 20980 ? S 04:05 0:03 php-fpm: poolwww
nobody 978160.02.0 168996 21084 ? S 04:05 0:03 php-fpm: poolwww
apache的blog虚拟主机设置连接php配置httpd支持fcgi,修改主配置文件取消注释即可
1
2
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
修改虚拟主机配置,使所有php结尾的文件通通转发到后端的blog服务器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# vim/etc/httpd24/extra/httpd-vhosts.conf
<VirtualHost *:80>
ServerName blog.wordpress.com
DocumentRoot "/www/blog"
<Directory "/www/blog">
Options none
AllowOverridenone
Require all granted
</Directory>
ErrorLog"/var/log/httpd/blog-error-log"
CustomLog"/var/log/httpd/blog-access-log" common
ProxyRequests Off #关闭正向代理
ProxyPassMatch ^/(.*\.php)$ fcgi://172.16.4.102:9000/www/blog/$1 #访问php结尾的所有文件,转发给后端的php服务器
</VirtualHost>
设置完成重启httpd服务
blog服务器准备目录
1
# mkdir -p /www/blog
放入测试页测试
1
2
3
4
# vim /www/blog/index.php
<?php
phpinfo();
?>
访问web服务器,web服务器看到访问的文件是php结尾,就将请求转发给了后端的blog服务器
Blog服务器和MariaDB数据库连接MariaDB数据库创建blog的库和用户,并且授权用户对库有所有权限
1
2
MariaDB > create database wordpress;
MariaDB > GRANT all ON wordpress.* TO'wordpress'@'172.16.4.102' IDENTIFIED BY 'blogpasswd';
测试php和MariaDB的连接
测试页如下:
1
2
3
4
5
6
7
8
# vim /www/blog/index.php
<?php
$conn=mysql_connect('172.16.4.136','wordpress','blogpasswd');
if ($conn)
echo"连接数据库成功";
else
echo"连接数据库失败"
?>
安装blog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# unzip wordpress-3.3.1-zh_CN.zip
# mv wordpress/* /www/blog/
# cd /www/blog/
# cp wp-config-sample.phpwp-config.php
# vim wp-config.php
/** WordPress 数据库的名称 */
define('DB_NAME', 'wordpress');
/** MySQL 数据库用户名 */
define('DB_USER', 'wordpress');
/** MySQL 数据库密码 */
define('DB_PASSWORD', 'blogpasswd');
/** MySQL 主机 */
define('DB_HOST', '172.16.4.136');
web服务器需要为用户提供wordpress的静态文件
1
2
# mv wordpress/* /www/blog/
# unzip wordpress-3.3.1-zh_CN.zip
在blog服务器和web服务器都准备好静态文件之后,就可以进行安装了,打开浏览器输入,http://blog.wordpress.com/wp-admin/install.php即可安装。
配置完成之后登录
动态服务器bbs配置Php-fpm配置解压MariaDB到指定位置
1
2
3
tar xf mariadb-5.5.43-linux-x86_64.tar.gz -C/usr/local/
cd /usr/local/
ln -sv mariadb-5.5.43-linux-x86_64/ mysql
安装php依赖软件包
1
yum -y install libmcrypt libmcrypt-devel mhashmhash-devel openssl-devel bzip2-devel
编译安装php
1
2
3
4
tar xf php-5.4.40.tar.bz2
cd php-5.4.40
./configure --prefix=/usr/local/php5--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--with-config-file-scan-dir=/etc/php.d --with-bz2
make && make install
为php提供配置文件
1
# cp php.ini-production/etc/php.ini
为php-fpm提供配置文件
1
# cp/usr/local/php5/etc/php-fpm.conf.default /usr/local/php5/etc/php-fpm.conf
为php-fpm提供启动脚本
1
2
3
4
# cp sapi/fpm/init.d.php-fpm/etc/rc.d/init.d/php-fpm
# chmod +x/etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on
编辑php-fpm的配置文件
1
2
3
4
5
6
7
# vim /usr/local/php/etc/php-fpm.conf
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 8
pid = /usr/local/php/var/run/php-fpm.pid
listen = 172.16.4.101:9000 #设置php-fpm监听的地址,保证web服务器可以访
问此地址
启动php-fpm
1
2
3
# service php-fpm start
# netstat -lnt | grep :9000
tcp 0 0 172.16.4.101:9000 0.0.0.0:* LISTEN
配置web服务器和bbs服务器连接虚拟主机设置,将php结尾的文件转发到后端的bbs服务器
1
2
3
4
5
6
7
8
9
10
11
12
13
<VirtualHost *:80>
ServerName bbs.discuz.com
DocumentRoot "/www/bbs"
<Directory "/www/bbs">
Options none
AllowOverride none
Require all granted
</Directory>
ErrorLog"/var/log/httpd/bbs-error-log"
CustomLog"/var/log/httpd/bbs-access-log" common
ProxyRequests Off
ProxyPassMatch^/(.*\.php)$ fcgi://172.16.4.101:9000/www/bbs/$1
</VirtualHost>
验证apache和php的cfgi连接
1
2
3
4
# vim /www/bbs/index.php
<?php
phpinfo();
?>
配置bbs服务器和MariaDB服务器连接创建数据库和数据库用户,并且授权用户对数据库具有全部权限
1
2
MariaDB > create database bbsdb;
MariaDB > GRANT all ON bbsdb.* TO 'runbbs'@'172.16.4.101' IDENTIFIED BY 'adm123';
测试php和mysql的连接
修改测试页面
1
2
3
4
5
6
7
8
9
10
11
12
# vim /www/bbs/index.php
<?php
$conn=mysql_connect('172.16.4.136','runbbs','adm123');
if ($conn)
echo"连接数据库成功";
else
echo"连接数据库失败"
?>
<?php
phpinfo();
?>
部署论坛将Discuz的程序文件解压,并且将upload中所有文件放置到网站目录
1
2
# unzip Discuz_7.2_FULL_SC_UTF8.zip-d Discuz
# mv Discuz/upload/* /www/bbs/
设置php-fpm的服务用户为下面文件的属主或者对其设置写权限,否则安装时会报错
1
2
3
# cd /www/bbs/
# chown -R nobody templates/attachments/ forumdata/
# chown -R nobodyuc_client/data/cache/ config.inc.php
web服务器也需要有静态文件
1
2
# mv Discuz/upload/* /www/bbs/
# unzip Discuz_7.2_FULL_SC_UTF8.zip-d Discuz
设置httpd的服务用户对指定文件也需要有写权限
1
2
3
# cd /www/bbs/
# chown -R daemon templates/attachments/ forumdata/
# chown -R daemonuc_client/data/cache/ config.inc.php
设置完成之后,输入httd://bbs.discuz.com/install即可安装
只需要根据错误提示进行排除即可
1
2
3
# vim /etc/php.ini
short_open_tag = ON
# service php-fpm restart
排错之后继续访问安装目录,就可以继续安装了
填写数据库的相关信息,添加数据库服务器的地址和MariaDB创建的数据库和用户密码,而后在设置bbs的管理员帐号密码就可以继续安装了。
剩下的根据提示安装即可。
出现上面这种情况是由于php服务器安装了discuz之后导致程序发生变化从而导致动态服务器和静态服务器的程序不一致,只需要手动把bbs服务器的文件和web服务器进行一次同步即可,如果想实现自动同步,需要使用其他服务,如initory+rsync、sersync等工具。
1
# scp -r *root@172.16.4.100:/www/bbs/
动态服务器和静态服务器同步文件之后,再次访问bbs的网址就正常了。
压力测试
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# ab -n 3000 -c 100 httpd://www.discuz.com/index.php
省略部分内容……
Server Software: Apache/2.4.10
Server Hostname: bbs.discuz.com
Server Port: 80
Document Path: /index.php
Document Length: 7691 bytes
Concurrency Level: 100
Time taken for tests: 58.782 seconds
Complete requests: 3000
Failed requests: 2137
(Connect:0, Receive: 0, Length: 2137, Exceptions: 0)
Write errors: 0
Non-2xx responses: 29
Total transferred: 23679924 bytes
HTML transferred: 22723414 bytes
Requests per second: 51.04 [#/sec] (mean) #每秒可以处理请求
Time per request: 1959.391 (mean)
Time per request: 19.594 (mean, across all concurrentrequests)
Transfer rate: 393.40 received
Connection Times (ms)
minmean[+/-sd] median max
Connect: 0 210.2 0 135
Processing:142 1926 1621.3 1355 31212
Waiting: 141 1924 1620.6 1354 31212
Total: 195 1928 1620.6 1356 31212
Percentage of the requests served within a certaintime (ms)
50% 1356
66% 1717
75% 2312
80% 2482
90% 2945
95% 4149
98% 6231
99% 9875
100%31212 (longest request)
部署xcache为php加速编译安装Xcache
1
2
3
4
5
tar xf xcache-3.2.0.tar.bz2
cd xcache-3.2.0
/usr/local/php5/bin/phpize
./configure --enable-xcache--with-php-config=/usr/local/php5/bin/php-config
make && make install
安装结束会出现如下行
Installing shared extensions: /usr/local/php5/lib/php/extensions/no-debug-non-zts-20100525/
整合php和xcache,将XCache配置文件复制到php.d目录下,使php可以读取XCache配置文件
1
2
# mkdir /etc/php.d
# cp xcache.ini/etc/php.d/
接下来编辑/etc/php.d/xcache.ini,找到zend_extension开头的行,修改为如下行
1
zend_extension =/usr/local/php5/lib/php/extensions/no-debug-non-zts-20100525/xcache.so
设置完成之后,重启php-fpm服务。
在bbs网页目录准备php测试页面,访问如果出现Xcache的内容说明Xcache安装成功
在次进行压力测试
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# ab -n 3000 -c 100http://bbs.discuz.com/index.php
省略部分内容…………
Server Software: Apache/2.4.10
Server Hostname: bbs.discuz.com
Server Port: 80
Document Path: /index.php
Document Length: 7687 bytes
Concurrency Level: 100
Time taken for tests: 9.983 seconds
Complete requests: 3000
Failed requests: 0
Write errors: 0
Total transferred: 24031128 bytes
HTML transferred: 23061000 bytes
Requests per second: 300.51 [#/sec] (mean)
Time per request: 332.762 (mean)
Time per request: 3.328 (mean, across all concurrentrequests)
Transfer rate: 2350.82 received
Connection Times (ms)
minmean[+/-sd] median max
Connect: 0 1 3.9 0 25
Processing: 3132745.2 328 701
Waiting: 3132745.2 327 701
Total: 4232843.4 328 701
Percentage of the requests served within a certaintime (ms)
50% 328
66% 339
75% 346
80% 354
90% 378
95% 391
98% 417
99% 428
100% 701 (longest request)
通过对比安装Xcache前后的压力测试结果,可以看出处理的请求数由每秒处理50个请求提升到了300个,当然由于是本机进行测试,没有考虑带宽的因素,所以性能稍高。
页:
[1]