一、LAMP架构之分离式拓扑


wKioL1VKIweCgeCOAAqTmH2wcT4425.bmp

 

二、架构说明


  当客户端访问Web服务器时,Web服务器根据客户端访问的资源进行判断,如果是静态的页面Web服务器就直接返回给给客户端,如果是动态的页面,Web服务器就请求PHP服务器进行解析,在解析过程有需要MySQL数据的PHP服务器就请求MySQL服务器,PHP服务器解析完后封装发送给Web服务器,Webt器在封装发送给客户端。

 

三、架构规划


主机网卡1网卡2备注
客户端172.16.9.6--
Web服务器172.16.9.2110.0.9.21提供Web服务
PHP服务器10.0.9.3110.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)启用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文件,内容如下:

<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数据库了,登录后的效果如图:

wKioL1VKI7HyjC6cAA4nWL0sN9w188.bmp

 

十、安装和配置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时很简单,因为前面已经把文件的属主和属组已经更改了,进行对相应的目录和文件都有写的权限,只需要要同意、下一步、全新安装、填写相应的数据库名等,填写数据库内容如图:

wKiom1VKImrRLUOtAAvOPMol8b8963.bmp

3)访问www.bbs.com

wKiom1VKIrbD9fLSAA318NN_3wM052.bmp

 

十一、安装Discuz问题集


1)打开网页缺少CSS样式

  在安装之后,发出打开Discuz页面缺少CSS样式,后来经过分析,Discuz在安装时把所有内容都安装在PHP服务器了,而Web服务器没有相应的文件,而生成的文件都是静态的文件,所以Web服务器找不到相应的文件,效果如下:

wKiom1VKIunBU1M3AAw5SO8ZveI570.bmp

 

通过调用Google Chrome浏览器的调试功能F12,发现页面找不到相应的文件,把PHP服务器相应的文件复制过来就可以解决问题了。

 

wKioL1VKJJHRUwxqAAtCQI0reYQ907.bmp

 

解决过程

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的分析,页面在加载时会使用互联网上指定的链接;在没有外网是就是出现加载页面慢的情况。

wKioL1VKJLbi7Sn9AAvGAPlReIk271.bmp

 

小结:

此架构是有一种的缺点:

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

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

改进方法:

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

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

   3) 对程序进行二次开发