搭建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 |
使用软件
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
解决依赖关系
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
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的命令路径
[root@web-01 httpd-2.4.10]# vim/etc/profile.d/httpd.sh export PATH=/usr/local/acaphe/bin:$PATH [root@web-01 httpd-2.4.10]# ./etc/profile.d/httpd.sh [root@web-01 httpd-2.4.10]# which httpd /usr/local/apache/bin/httpd
设置启动脚本
[root@web-01 httpd-2.4.10]# cp/usr/local/apache/bin/apachectl /etc/init.d/httpd24 [root@web-01 httpd-2.4.10]# vim /etc/init.d/httpd24 #!/bin/sh # chkconfig: 35 85 15 #设置服务识别参数,3、5级别启动,启动顺序85,关闭顺序15 # description: Apache #服务描述信息 [root@web-01 ~]# chkconfig --add httpd24 [root@web-01 ~]# chkconfig --level 35 httpd24 on [root@web-01 ~]# chkconfig --list httpd24 httpd24 0:off 1:off 2:off 3:on 4:off 5:on 6:off
修改httpd配置文件设置监听的端口
[root@web01 ~]# vim /etc/httpd24/httpd.conf Listen 1.1.1.1:80 Listen 172.16.4.100:80
启动服务并访问验证
[root@web01 ~]# service httpd24 start [root@web01 ~]# 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
编辑主配置文件,注释中心主机,启用虚拟主机选项
[root@web01 ~]# vim /etc/httpd24/httpd.conf #DocumentRoot "/usr/local/apache/htdocs" Include /etc/httpd24/extra/httpd-vhosts.conf
设置虚拟主机
[root@web01 ~]# 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>
设置虚拟主机目录
[root@web01 ~]# mkdir -p /www/{bbs,blog} [root@web01 ~]# echo bbs > /www/bbs/index.html [root@web01 ~]# echo blog > /www/blog/index.html
访问测试虚拟主机
配置/dev/sda3为lvm分区
[root@MariaDB-01 ~]# 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 Blocks Id System /dev/sda1 * 1 26 204800 83 Linux Partition 1 does not end on cylinder boundary. /dev/sda2 26 7859 62914560 8e Linux LVM /dev/sda3 7859 11775 31462303+ 8e Linux LVM
创建逻辑卷
[root@MariaDB-01 ~]# pvcreate /dev/sda3 [root@MariaDB-01 ~]# vgcreate myvg /dev/sda3 [root@MariaDB-01 ~]# lvcreate -L 15G -n mydata myvg [root@MariaDB-01 ~]# lvs LV VG Attr LSize Pool 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
格式化并挂载
[root@MariaDB-01 ~]# mkfs.ext4 /dev/myvg/mydata [root@MariaDB-01 ~]# vim /etc/fstab /dev/myvg/mydata /mydata ext4 defaults 0 0 [root@MariaDB-01 ~]# mkdir /mydata [root@MariaDB-01 ~]# mount -a
创建MariaDB服务用户,并且设置数据目录的属主属组为服务用户
[root@MariaDB-01 ~]# groupadd -r mysql [root@MariaDB-01 ~]# useradd -g mysql -r -s/sbin/nologin -M mysql [root@MariaDB-01 ~]# mkdir /mydata/data [root@MariaDB-01 ~]# chown -R mysql:mysql/mydata/data/
安装MariaDB并初始化
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提供主配置文件
[root@MariaDB-01 mysql]# cpsupport-files/my-large.cnf /etc/my.cnf [root@MariaDB-01 mysql]# vim /etc/my.cnf thread_concurrency = 2 #设置CPU核心数量乘以2 datadir = /mydata/data #设置数据文件目录 innodb_file_per_table = 1 #使用inoodb引擎,每表一个表文件
为MariaDB提供启动脚本
[root@MariaDB-01 mysql]# cpsupport-files/mysql.server /etc/rc.d/init.d/mysqld [root@MariaDB-01 mysql]# chkconfig --add mysqld [root@MariaDB-01 mysql]# chkconfig mysqld on [root@MariaDB-01 mysql]# chkconfig --list mysqld mysqld 0:off 1:off 2:on 3:on 4:on 5:on 6:off
修改PATH环境变量,让系统直接使用MariaDB相关命令
[root@MariaDB-01 ~]# vim /etc/profile.d/mysql.sh export PATH=/usr/local/mysql/bin:$PATH [root@MariaDB-01 ~]# . /etc/profile.d/mysql.sh
启动测试
[root@MariaDB-01 ~]# service mysqld start Starting MySQL... [ OK ] [root@MariaDB-01 ~]# 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)]>
编译安装php依赖于MariaDB的文件,但是不需要对MariaDB进行任何配置,只需要解压到指定目录即可。
解压MariaDB到指定位置
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依赖软件包
yum -y install libmcrypt libmcrypt-devel mhashmhash-devel openssl-devel bzip2-devel
编译安装php
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提供配置文件
[root@blog-01 php-5.4.40]# cp php.ini-production/etc/php.ini
为php-fpm提供配置文件
[root@blog-01 php-5.4.40]# cp/usr/local/php5/etc/php-fpm.conf.default /usr/local/php5/etc/php-fpm.conf
为php-fpm提供启动脚本
[root@blog-01 php-5.4.40]# cpsapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm [root@blog-01 php-5.4.40]# chmod +x/etc/rc.d/init.d/php-fpm [root@blog-01 php-5.4.40]# chkconfig --add php-fpm [root@blog-01 php-5.4.40]# chkconfig php-fpm on
修改php-fpm设置
[root@blog-01 php-5.4.40]# 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服务器可以访问此地址。
启动并验证
[root@blog-01 php-5.4.40]# service php-fpm start [root@blog-01 php-5.4.40]# netstat -lnt | grep:9000 tcp 0 0 172.16.4.102:9000 0.0.0.0:* LISTEN
查看启动的进程
[root@blog-01 ~]# ps aux | grep php-fpm root 12569 0.0 0.0 103252 832 pts/0 S+ 06:48 0:00 grep php-fpm root 97811 0.0 0.4 155924 4084 ? Ss 04:05 0:01 php-fpm: master process (/usr/local/php5/etc/php-fpm.conf) nobody 97812 0.0 2.5 175708 26068 ? S 04:05 0:03 php-fpm: poolwww nobody 97813 0.0 2.5 175936 25992 ? S 04:05 0:04 php-fpm: poolwww nobody 97814 0.0 2.1 170612 21372 ? S 04:05 0:02 php-fpm: poolwww nobody 97815 0.0 2.0 170584 20980 ? S 04:05 0:03 php-fpm: poolwww nobody 97816 0.0 2.0 168996 21084 ? S 04:05 0:03 php-fpm: poolwww
配置httpd支持fcgi,修改主配置文件取消注释即可
LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
修改虚拟主机配置,使所有php结尾的文件通通转发到后端的blog服务器
[root@web01 ~]# 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服务器准备目录
[root@blog-01 php-5.4.40]# mkdir -p /www/blog
放入测试页测试
[root@blog-01 ~]# vim /www/blog/index.php <?php phpinfo(); ?>
访问web服务器,web服务器看到访问的文件是php结尾,就将请求转发给了后端的blog服务器
MariaDB数据库创建blog的库和用户,并且授权用户对库有所有权限
MariaDB [mysql]> create database wordpress; MariaDB [mysql]> GRANT all ON wordpress.* TO'wordpress'@'172.16.4.102' IDENTIFIED BY 'blogpasswd';
测试php和MariaDB的连接
测试页如下:
[root@blog-01 ~]# vim /www/blog/index.php <?php $conn=mysql_connect('172.16.4.136','wordpress','blogpasswd'); if ($conn) echo"连接数据库成功"; else echo"连接数据库失败" ?>
[root@blog-01 ~]# unzip wordpress-3.3.1-zh_CN.zip [root@blog-01 ~]# mv wordpress/* /www/blog/ [root@blog-01 ~]# cd /www/blog/ [root@blog-01 blog]# cp wp-config-sample.phpwp-config.php [root@blog-01 blog]# 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的静态文件
[root@web01 ~]# mv wordpress/* /www/blog/ [root@web01 ~]# unzip wordpress-3.3.1-zh_CN.zip
在blog服务器和web服务器都准备好静态文件之后,就可以进行安装了,打开浏览器输入,http://blog.wordpress.com/wp-admin/install.php即可安装。
配置完成之后登录
解压MariaDB到指定位置
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依赖软件包
yum -y install libmcrypt libmcrypt-devel mhashmhash-devel openssl-devel bzip2-devel
编译安装php
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提供配置文件
[root@bbs-01 php-5.4.40]# cp php.ini-production/etc/php.ini
为php-fpm提供配置文件
[root@bbs-01 php-5.4.40]# cp/usr/local/php5/etc/php-fpm.conf.default /usr/local/php5/etc/php-fpm.conf
为php-fpm提供启动脚本
[root@bbs-01 php-5.4.40]# cp sapi/fpm/init.d.php-fpm/etc/rc.d/init.d/php-fpm [root@bbs-01 php-5.4.40]# chmod +x/etc/rc.d/init.d/php-fpm [root@bbs-01 php-5.4.40]# chkconfig --add php-fpm [root@bbs-01 php-5.4.40]# chkconfig php-fpm on
编辑php-fpm的配置文件
[root@bbs-01 php-5.4.40]# 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
[root@bbs-01 php-5.4.40]# service php-fpm start [root@bbs-01 php-5.4.40]# netstat -lnt | grep :9000 tcp 0 0 172.16.4.101:9000 0.0.0.0:* LISTEN
虚拟主机设置,将php结尾的文件转发到后端的bbs服务器
<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连接
[root@bbs-01 ~]# vim /www/bbs/index.php <?php phpinfo(); ?>
创建数据库和数据库用户,并且授权用户对数据库具有全部权限
MariaDB [mysql]> create database bbsdb; MariaDB [mysql]> GRANT all ON bbsdb.* TO 'runbbs'@'172.16.4.101' IDENTIFIED BY 'adm123';
测试php和mysql的连接
修改测试页面
[root@bbs-01 ~]# vim /www/bbs/index.php <?php $conn=mysql_connect('172.16.4.136','runbbs','adm123'); if ($conn) echo"连接数据库成功"; else echo"连接数据库失败" ?> <?php phpinfo(); ?>
将Discuz的程序文件解压,并且将upload中所有文件放置到网站目录
[root@bbs-01 ~]# unzip Discuz_7.2_FULL_SC_UTF8.zip-d Discuz [root@bbs-01 ~]# mv Discuz/upload/* /www/bbs/
设置php-fpm的服务用户为下面文件的属主或者对其设置写权限,否则安装时会报错
[root@bbs-01 ~]# cd /www/bbs/ [root@bbs-01 bbs]# chown -R nobody templates/attachments/ forumdata/ [root@bbs-01 bbs]# chown -R nobodyuc_client/data/cache/ config.inc.php
web服务器也需要有静态文件
[root@web01 ~]# mv Discuz/upload/* /www/bbs/ [root@web01 ~]# unzip Discuz_7.2_FULL_SC_UTF8.zip-d Discuz
设置httpd的服务用户对指定文件也需要有写权限
[root@web01 ~]# cd /www/bbs/ [root@web01 bbs]# chown -R daemon templates/attachments/ forumdata/ [root@web01 bbs]# chown -R daemonuc_client/data/cache/ config.inc.php
设置完成之后,输入httd://bbs.discuz.com/install即可安装
只需要根据错误提示进行排除即可
[root@bbs-01 bbs]# vim /etc/php.ini short_open_tag = ON [root@bbs-01 bbs]# service php-fpm restart
排错之后继续访问安装目录,就可以继续安装了
填写数据库的相关信息,添加数据库服务器的地址和MariaDB创建的数据库和用户密码,而后在设置bbs的管理员帐号密码就可以继续安装了。
剩下的根据提示安装即可。
出现上面这种情况是由于php服务器安装了discuz之后导致程序发生变化从而导致动态服务器和静态服务器的程序不一致,只需要手动把bbs服务器的文件和web服务器进行一次同步即可,如果想实现自动同步,需要使用其他服务,如initory+rsync、sersync等工具。
[root@bbs-01 bbs]# scp -r *[email protected]:/www/bbs/
动态服务器和静态服务器同步文件之后,再次访问bbs的网址就正常了。
[root@client ~]# 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 [ms] (mean) Time per request: 19.594 [ms] (mean, across all concurrentrequests) Transfer rate: 393.40 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 2 10.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
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配置文件
[root@bbs-01 xcache-3.2.0]# mkdir /etc/php.d [root@bbs-01 xcache-3.2.0]# cp xcache.ini/etc/php.d/
接下来编辑/etc/php.d/xcache.ini,找到zend_extension开头的行,修改为如下行
zend_extension =/usr/local/php5/lib/php/extensions/no-debug-non-zts-20100525/xcache.so
设置完成之后,重启php-fpm服务。
在bbs网页目录准备php测试页面,访问如果出现Xcache的内容说明Xcache安装成功
在次进行压力测试
[root@client ~]# 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 [ms] (mean) Time per request: 3.328 [ms] (mean, across all concurrentrequests) Transfer rate: 2350.82 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 1 3.9 0 25 Processing: 31 327 45.2 328 701 Waiting: 31 327 45.2 327 701 Total: 42 328 43.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个,当然由于是本机进行测试,没有考虑带宽的因素,所以性能稍高。