一、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.bz2apr-util-1.5.3.tar.bz2httpd-2.4.10.tar.bz2mariadb-5.5.43-linux-x86_64.tar.gzphp-5.6.4.tar.xzphpMyAdmin-4.0.5-all-languages.zipDiscuz_X3.2_SC_UTF8.zip

 

五、准备安装开发环境

yum groupinstall  "Server Platform Development"  "Development tools" -yyum install pcre-devel -yyum install bzip2-devel libmcrypt-devel -yyum install libxml2-devel -y

 

六、Web服务器上安装httpd服务程序

1)安装httpd程序依赖apr程序包

tar xf apr-1.5.0.tar.bz2cd apr-1.5.0./configure --prefix=/usr/local/aprmake && 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/apachelrwxrwxrwx 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.soLoadModule proxy_fcgi_modulemodules/mod_proxy_fcgi.so

9)启用httpphp的支持/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.comwww.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文件,内容如下:

   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   
     AllowOverride None     Options None      Require all granted   
   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   
     AllowOverride None     Options None     Require all granted   

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.xzcd 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=bbsmake && 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/phplrwxrwxrwx 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.pidlisten = 10.0.9.31:9000pm.max_children = 60pm.start_servers = 5pm.min_spare_servers = 3pm.max_spare_servers = 8

6)启动php-fpm

[root@node-3 pma]# service php-fpm startStarting 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.com172.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的分析,页面在加载时会使用互联网上指定的链接;在没有外网是就是出现加载页面慢的情况。

 

小结:

此架构是有一种的缺点:

   1Web服务器文件缺少;安装时有些文件被安装在PHP服务器而调用去要使用Web服务器上的文件;

   2)用户上传文件无法显示;用户上传文件时被放置于PHP服务器,显示去查找的Web服务器上的文件;

改进方法:

   1Web服务器与PHP服务器站点文件目录同步使用,如rsync+inotify;

   2)使用共享存储,如NFS;

   3) 对程序进行二次开发