一、LAMP架构之分离式拓扑
二、架构说明
当客户端访问Web服务器时,Web服务器根据客户端访问的资源进行判断,如果是静态的页面Web服务器就直接返回给给客户端,如果是动态的页面,Web服务器就请求PHP服务器进行解析,在解析过程有需要MySQL数据的PHP服务器就请求MySQL服务器,PHP服务器解析完后封装发送给Web服务器,Webt器在封装发送给客户端。
三、架构规划
主机 | 网卡1 | 网卡2 | 备注 |
客户端 | 172.16.9.6 | - | - |
Web服务器 | 172.16.9.21 | 10.0.9.21 | 提供Web服务 |
PHP服务器 | 10.0.9.31 | 10.0.9.41 | 提供PHP程序解析 |
MySQL服务器 | 10.0.9.51 | - | 提供MySQL服务 |
四、LAMP程序包版本
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.6.4.tar.xz phpMyAdmin-4.0.5-all-languages.zip Discuz_X3.2_SC_UTF8.zip
五、准备安装开发环境
yum groupinstall "Server Platform Development" "Development tools" -y yum install pcre-devel -y yum install bzip2-devel libmcrypt-devel -y yum install libxml2-devel -y
六、Web服务器上安装httpd服务程序
1)安装httpd程序依赖apr程序包
tar xf apr-1.5.0.tar.bz2 cd apr-1.5.0 ./configure --prefix=/usr/local/apr make && make install
2)安装httpd程序依赖apr-util程序包
tar xf apr-util-1.5.3.tar.bz2 cdapr-util-1.5.3 ./configure --prefix=/usr/local/apr-util--with-apr=/usr/local/apr/ make&& make install
3)安装http程序包
[root@node-2 httpd-2.4.10]#useradd -r bbs [root@node-2 httpd-2.4.10]# ./configure--prefix=/usr/local/apache-2.4.10 --sysconfdir=/etc/apache24 --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util/ --enable-so--enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre--enable-modules=most --enable-mpms-shared=all --with-mpm=prefork --user=bbs [root@node-2 httpd-2.4.10]# make &&make install
4)创建apahce软链接
[root@node-2 ~]# ln -s/usr/local/apache-2.4.10/ /usr/local/apache [root@node-2 ~]# ll /usr/local/apache lrwxrwxrwx 1 root root 25 May 3 11:27 /usr/local/apache ->/usr/local/apache-2.4.10/
5)提供服务脚本/etc/rc.d/init.d/httpd
修改httpd的配置文件中指定pid文件存放路径
PidFile"/var/run/httpd.pid"
服务脚本通过复制系统原有的httpd服务脚本,在此基础上进行简单的修改,修改的内容如下:
[root@node-2 ~]# cp/etc/rc.d/init.d/httpd /etc/rc.d/init.d/httpd24 apachectl=/usr/local/apache/bin/apachectl httpd=${HTTPD-/usr/local/apache/bin/httpd}
添加到开机自启动服务中:
[root@node-2 ~]# chkconfig --add httpd24 [root@node-2 ~]# chkconfig httpd24 on
6)设置httpd环境变量
[root@node-2 httpd-2.4.10]# vim/etc/profile.d/httpd.sh PATH=/usr/local/apache/bin/:$PATH [root@node-2 httpd-2.4.10]# ./etc/profile.d/httpd.sh
7)启用http的相关php-fpm模块/etc/apache24/httpd.conf
在Apache httpd 2.4以后已经专门有一个模块针对FastCGI的实现,此模块为mod_proxy_fcgi.so,它其实是作为mod_proxy.so模块的扩充,因此,这两个模块都要加载
LoadModule proxy_modulemodules/mod_proxy.so LoadModule proxy_fcgi_modulemodules/mod_proxy_fcgi.so
9)启用http对php的支持/etc/apache24/httpd.conf
AddType application/x-httpd-php .php AddType application/x-httpd-php-source .phps DirectoryIndex index.php index.html
10)提供httpd虚拟机为www.blog.com和www.phpmysql.com
修改/etc/apache24/httpd.conf的配置文件,开启虚拟文件:
#DocumentRoot "/usr/local/apache-2.4.10/htdocs" Include/etc/apache24/extra/httpd-vhosts.conf
在编辑/etc/apache24/extra/httpd-vhost.conf文件,内容如下:
<VirtualHost *:80> ServerAdmin admin@bbs.com DocumentRoot "/web/discuz" ServerName www.bbs.com ServerAlias bbs.com ErrorLog "logs/bbs.com-error_log" CustomLog "logs/bbs.com-access_log" combined ProxyRequests Off ProxyPassMatch ^/(.*\.php)$ fcgi://10.0.9.31:9000/web/discuz/$1 <Directory "/web/discuz"> AllowOverride None Options None Require all granted </Directory> </VirtualHost> <VirtualHost *:80> ServerAdmin admin@phpmysql.com DocumentRoot "/web/pma" ServerName www.phpmysql.com ServerAlias phpmysql.com ErrorLog "logs/phpmysql.com-error_log" CustomLog "logs/phpmysql.com-access_log" combined ProxyRequests Off ProxyPassMatch ^/(.*\.php)$ fcgi://10.0.9.31:9000/web/pma/$1 <Directory "/web/pma"> AllowOverride None Options None Require all granted </Directory> </VirtualHost>
11)启用httpd服务
service httpd24 start
七、MySQL服务器上安装MariaDb数据库
1)创建MariaDB运行的用户
[root@mysql ~]# groupadd -r mysql [root@mysql ~]# useradd -r -g mysql mysql
2)创建数据库存放目录并设置属主、属组
[root@mysql ~]# mkdir /data/mysql -p [root@mysql ~]# chown -R mysql.mysql /data/mysql/
3)解压MariaDB程序包到/usr/local目录下
[root@mysql tools]# tar xfmariadb-5.5.43-linux-x86_64.tar.gz -C /usr/local/
4)创建软链接
[root@ mysql tools]# cd /usr/local/ [root@ mysql local]# ln -smariadb-5.5.43-linux-x86_64/ mysql
5)初始化数据库
[root@ mysql local]# cd mysql [root@ mysql mysql]# chown -R root.mysql ./* [root@ mysql mysql]#scripts/mysql_install_db --datadir=/data/mysql/ --user=mysql
6)提供MySQL的主配置文件
[root@ mysql mysql]# mkdir /etc/mysql [root@ mysql mysql]# cpsupport-files/my-large.cnf /etc/mysql/my.cnf
7)编辑/etc/mysql/my.cnf配置文件
在/etc/mysql/my.cnf配置文件中在[mysqld]标签中添加数据库存放目录。
datadir = /data/mysql
8)为MySQL提供服务脚本
[root@ mysql mysql]# cpsupport-files/mysql.server /etc/rc.d/init.d/mysqld [root@ mysql mysql]# chmod +x/etc/rc.d/init.d/mysqld [root@ mysql mysql]# chkconfig --add mysqld [root@ mysql mysql]# chkconfig mysqld on
9)设置mysql命令的环境变量
[root@ mysql mysql]# vim/etc/profile.d/mysql.sh PATH=/usr/local/mysql/bin:$PATH [root@ mysql mysql]# ./etc/profile.d/mysql.sh
10)设置mysql命令的man帮助手册
在/etc/man.cnf中添加如下一行
MANPATH/usr/local/mysql/man
11)导出mysql头文件至/usr/include
[root@ mysql mysql]# ln -s/usr/local/mysql/include/mysql/ /usr/include/
12)输出MySQL库文件
[root@ mysql mysql]# echo ‘/usr/local/mysql/lib‘> /etc/ld.so.conf.d/mysql.conf [root@ mysql mysql]# ldconfig
12)添加用于BBS的数据库和设置管理MySQL的用户名和密码
MariaDB [(none)]> CREATE DATABASE bbs; Query OK, 1 row affected (0.00 sec) MariaDB [(none)]> GRANT ALL ON bbs.* TO‘userbbs‘@‘10.%.%.%‘ IDENTIFIED BY ‘bbspass‘; Query OK, 0 rows affected (0.00 sec) MariaDB [(none)]> GRANT ALL ON *.* TO‘root‘@‘10.%.%.%‘ IDENTIFIED BY ‘bbspass‘; Query OK, 0 rows affected (0.00 sec) MariaDB [(none)]> FLUSH PRIVILEGES; Query OK, 0 rows affected (0.00 sec)
八、PHP服务器上安装PHP程序
创建php的运行用户bbs
useradd -r bbs
1)编译安装php
tar xf php-5.6.4.tar.xz cd php-5.6.4 ./configure--prefix=/usr/local/php5.6.4 --with-openssl --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/php.d --with-bz2 --user=bbs make && make install
2)为/usr/local/php-5.6.4创建软链接
[root@node-3 php-5.6.4]# ln -s/usr/local/php5.6.4/ /usr/local/php [root@node-3 php-5.6.4]# ll /usr/local/php lrwxrwxrwx 1 root root 20 May 3 18:42 /usr/local/php ->/usr/local/php5.6.4/
3)为PHP提供配置文件
[root@node-3 php-5.6.4]# mkdir -p/etc/php/php.d/ [root@node-3 php-5.6.4]# cpphp.ini-development /etc/php/php.ini
4)配置php-fpm
[root@node-3 php-5.6.4]# cpsapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm [root@node-3 php-5.6.4]# chmod +x/etc/rc.d/init.d/php-fpm [root@node-3 php-5.6.4]# chkconfig --addphp-fpm [root@node-3 php-5.6.4]# chkconfig php-fpmon
5)为php-fpm提供配置文件
[root@node-3 php-5.6.4]# cp /usr/local/php5.6.4/etc/php-fpm.conf.default /usr/local/php5.6.4/etc/php-fpm.conf
6)编辑php-fpm配置文件/etc/local/php/etc/php-fpm.conf
pid = /usr/local/php/var/run/php-fpm.pid listen = 10.0.9.31:9000 pm.max_children = 60 pm.start_servers = 5 pm.min_spare_servers = 3 pm.max_spare_servers = 8
6)启动php-fpm
[root@node-3 pma]# service php-fpm start Starting php-fpm done
九、安装和配置phpMyAdmin程序
1)分别在Web服务器上和PHP服务器解压PHPMyAdmin程序
在解压完之后,把PHPMyAdmin复制至/web/pma目录中,如果你看懂PHPMyAdmin的程序是可以把动态的面面放PHP服务器,静态的页面放在Web服务器的,这样可以实现动静的分离。
# mkdir /web/ # unzip phpMyAdmin-4.0.5-all-languages.zip # mv phpMyAdmin-4.0.5-all-languages/web/pma
2)修复PHP服务器中的PHPMyAdmin的数据库连接文件
# cd /web/pma # cp config.sample.inc.php config.inc.php # vim config.inc.php
将$cfg[‘Servers‘][$i][‘host‘]= ‘localhost‘;更改为:
$cfg[‘Servers‘][$i][‘host‘] = ‘10.0.9.51‘;
3)编辑本地电脑上hosts文件
编辑本地电脑上hosts文件,以实现解析域名的目的,内容如下:
172.16.9.21 www.bbs.com 172.16.9.21 www.phpmysql.com
4)在浏览器访问
在浏览器访问www.phpmysql.com,出现登录界面,根据在数据库的授权登录数据库,登录后就可以轻松的管理MySQL数据库了,登录后的效果如图:
十、安装和配置Discuz程序
安装Discuz程序需要在Web服务器和PHP服务器都要有程序,静态的内容的Web服务器将调用本地的文件,php页面就将交给PHP服务器来进行解析完成。
1)解压Discuz程序包
# unzip Discuz_X3.2_SC_UTF8.zip # mv upload/ /web/discuz
2)更改Discuz文件的属主和属组
[root@http discuz]# chown -R bbs.bbs ./*
2)安装Discuz程序
安装Discuz时很简单,因为前面已经把文件的属主和属组已经更改了,进行对相应的目录和文件都有写的权限,只需要要同意、下一步、全新安装、填写相应的数据库名等,填写数据库内容如图:
3)访问www.bbs.com
十一、安装Discuz问题集
1)打开网页缺少CSS样式
在安装之后,发出打开Discuz页面缺少CSS样式,后来经过分析,Discuz在安装时把所有内容都安装在PHP服务器了,而Web服务器没有相应的文件,而生成的文件都是静态的文件,所以Web服务器找不到相应的文件,效果如下:
通过调用Google Chrome浏览器的调试功能F12,发现页面找不到相应的文件,把PHP服务器相应的文件复制过来就可以解决问题了。
解决过程
在PHP服务器打包cache目录中的文件
[root@php discuz]# cd data/ [root@php data]# tar jcf cache.tar.gzcache/ [root@php data]# scp cache.tar.gz172.16.9.21:/web/discuz/data/ root@172.16.9.21‘s password: cache.tar.gz 100% 32KB 32.3KB/s 00:00
在Web服务器中解压cache目录
[root@http discuz]# cd data/ [root@http data]# rm -fr cache [root@http data]# tar xf cache.tar.gz
2)网页页面加载慢
在实验环境中,客户端在没有与互联网连网时,只有内网的环境中,就会出现网页页面加载很慢,但在有外网的环境网页页面加载就会很快,后来经过使用HttpWatch的分析,页面在加载时会使用互联网上指定的链接;在没有外网是就是出现加载页面慢的情况。
小结:
此架构是有一种的缺点:
1)Web服务器文件缺少;安装时有些文件被安装在PHP服务器而调用去要使用Web服务器上的文件;
2)用户上传文件无法显示;用户上传文件时被放置于PHP服务器,显示去查找的Web服务器上的文件;
改进方法:
1)Web服务器与PHP服务器站点文件目录同步使用,如rsync+inotify;
2)使用共享存储,如NFS;
3) 对程序进行二次开发
本文出自 “乌大宛” 博客,请务必保留此出处http://wuday.blog.51cto.com/2623944/1643661
原文地址:http://wuday.blog.51cto.com/2623944/1643661