两台web服务器 实现负载均衡 +fastCGI模块+mysql实现分布式架构 

操作系统:redhat 5.8
 
实验环境准备 :三台服务器 
Server 1  IP :172.16.2.1    安装:apache  NFS
Server 2  IP :172.16.2.2    安装:apache  DNS  
Server 3  IP:172.16..2.3    安装:php  mysql
实验图如下 :
 

工作原理:
1、当客户端请求www.tast.com 
2、Server 2 上的DNS会以轮询的方式把请求转给 172.16.2.1 和172.16.2.2 
3、如果此次请求是静态页面 web服务就直接把结果返给客户 ,如果是动态页面,就转给server 3 上的php 解析
4、如果需要用到数据库的数据,就通过数据库的接口访问数据库 
5、Php解析后把结果返回给前端的web
6、Web把结果返回给客户 
步骤
1、配置server 1
          安装配置 apache 和 NFS  
2、配置 server 2
          安装配置apache 和DNS
3、配置 server 3 
          安装配置 mysql 和 php 
4、总结
注:此次试验只是给大家提供一种思路,可以这么配置,企业实际需求中,不同的需求,不同的操作系统,不同的软件版本,配置过程会略有不同,但原理都是想通了,希望大家在做实验的同时不要忘了思考,学而不思则罔,原理理解了,我们就可以根据实际需求搭建出更适合自己需要的服务。 
过程

一、配置server 1

1.1 配置编译安装环境 

   由于此次试验每个软件都是编译安装,所以每台服务器都要先配置好编译安装环境 
确保这两个组安装 
 
 
   
  1. Development Tools 
  2. Development Libraries 
  3. #yum  -y groupinstall "Development Libraries"   

1.2  安装httpd 2.4.2 版本 

      
 
   
  1. #yum -y install pcre-devel  解决依赖关系  
  2. # tar xf httpd-2.4.2.tar.bz2 
  3. # cd httpd-2.4.2 
  4. # less INSTALL   查看安装说明  
  5.  $ ./configure --prefix=PREFIX 
  6.      $ make 
  7.      $ make install 
  8.      $ PREFIX/bin/apachectl start 
  9. # ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd 
  10. --enable-so --enable-rewrite --with-zlib --with-pcre 
  11. --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util
  12.  --enable-modules=most  --enable-ssl    --enable-modules-shared=most  
  13. #make && make install  
1.3 修改httpd的主配置文件,设置其Pid文件的路径
 
   
  1. #vim  /etc/httpd/httpd.conf 
  2. idFile  "/var/run/httpd.pid" 添加 
  
1.4 提供SysV服务脚本,内容如下:
 
 
   
  1. #vim /etc/rc.d/init.d/httpd

  2. #!/bin/bash 
  3. # httpd        Startup script for the Apache HTTP Server 
  4. # chkconfig: - 85 15 
  5. # description: Apache is a World Wide Web server.  It is used to serve \ 
  6. #          HTML files and CGI. 
  7. # processname: httpd 
  8. # config: /etc/httpd/conf/httpd.conf 
  9. # config: /etc/sysconfig/httpd 
  10. # pidfile: /var/run/httpd.pid 
  11. # Source function library. 
  12. . /etc/rc.d/init.d/functions 
  13. if [ -f /etc/sysconfig/httpd ]; then 
  14.         . /etc/sysconfig/httpd 
  15. fi 
  16. # Start httpd in the C locale by default. 
  17. HTTPD_LANG=${HTTPD_LANG-"C"} 
  18. # This will prevent initlog from swallowing up a pass-phrase prompt if 
  19. # mod_ssl needs a pass-phrase from the user. 
  20. INITLOG_ARGS="" 
  21. # Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server 
  22. # with the thread-based "worker" MPM; BE WARNED that some modules may not 
  23. # work correctly with a thread-based MPM; notably PHP will refuse to start. 
  24. # Path to the apachectl script, server binary, and short-form for messages. 
  25. apachectl=/usr/local/apache/bin/apachectl 
  26. httpd=${HTTPD-/usr/local/apache/bin/httpd} 
  27. prog=httpd 
  28. pidfile=${PIDFILE-/var/run/httpd.pid} 
  29. lockfile=${LOCKFILE-/var/lock/subsys/httpd} 
  30. RETVAL=0 
  31. start() { 
  32.         echo -n $"Starting $prog: " 
  33.         LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS 
  34.         RETVAL=$? 
  35.         echo 
  36.         [ $RETVAL = 0 ] && touch ${lockfile} 
  37.         return $RETVAL 
  38. stop() { 
  39. echo -n $"Stopping $prog: " 
  40. killproc -p ${pidfile} -d 10 $httpd 
  41. RETVAL=$? 
  42. echo 
  43. [ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile} 
  44. reload() { 
  45.     echo -n $"Reloading $prog: " 
  46.     if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/null; then 
  47.         RETVAL=$? 
  48.         echo $"not reloading due to configuration syntax error" 
  49.         failure $"not reloading $httpd due to configuration syntax error" 
  50.     else 
  51.         killproc -p ${pidfile} $httpd -HUP 
  52.         RETVAL=$? 
  53.     fi 
  54.     echo 
  55. # See how we were called. 
  56. case "$1" in 
  57.   start) 
  58. start 
  59. ;; 
  60.   stop) 
  61. stop 
  62. ;; 
  63.   status) 
  64.         status -p ${pidfile} $httpd 
  65. RETVAL=$? 
  66. ;; 
  67.   restart) 
  68. stop 
  69. start 
  70. ;; 
  71.   condrestart) 
  72. if [ -f ${pidfile} ] ; then 
  73. stop 
  74. start 
  75. fi 
  76. ;; 
  77.   reload) 
  78.         reload 
  79. ;; 
  80.   graceful|help|configtest|fullstatus) 
  81. $apachectl $@ 
  82. RETVAL=$? 
  83. ;; 
  84.   *) 
  85. echo $"Usage: $prog {start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}" 
  86. exit 1 
  87. esac 
  88. exit $RETVAL 
  89. # chmod +x /etc/rc.d/init.d/httpd   为此脚本赋予执行权 
  90. # chkconfig --add httpd  加入服务列表: 
1.5 安装apache fastcgi模块:  
 
 
   
  1. #tar -zxvf mod_fastcgi-current.tar.gz    
  2. #cd mod_fastcgi  
  3. #cp Makefile.AP2 Makefile   
  4. #Vim  Makefile 修改top_dir=/usr/local/apache  #你的apache安装路径 
  5. #make   
  6. #make install 
 1.6修改配置文件 让apache支持php-fpm 
 
 
   
  1. 增加: LoadModule fastcgi_module modules/mod_fastcgi.so    
  2. 有的话不用添加。   
  3. ScriptAlias /cgi-bin/ "/usr/local/php/bin/"   
  4. FastCgiExternalServer /usr/local/php/bin/php-fpm -host 172.16.2.3:9000   
  5.   AddType application/x-httpd-php .php   
  6.    AddHandler php-fastcgi .php   
  7.     Action php-fastcgi /cgi-bin/php-fpm   
  8.   
  9.     <Directory "/usr/local/php/bin/">  
  10.     Options -Indexes FollowSymLinks +ExecCGI   
  11.     Order allow,deny   
  12.     Allow from all   
  13.     </Directory>  
  14.   
 2、配置NFS 
 
 
   
  1. Redhat5.8默认已经安装好了NFS,直接配置即可  
  2.    vim  /etc/exports  
  3.   /usr/local/apadhe/htdocs  172.16.0.0/16(rw,no_root_squash) 
  4.  保存退出  
  5. #exportfs  -arv 使其配置生效  
3、安装 discuz 
 
 
   
  1. #unzip Discuz_7.2_FULL_SC_GBK.zip -d /usr/local/apadhe/htdocs 解压缩 
  2. #cd /usr/local/apadhe/htdocs 
  3. # ls  
  4. index.php  readme  upload  utilities 只要upload   其他三个不要  
  5. # rm -rf index.php readme/ utilities/  
  6. # mv upload/* ./ 把upload 目录下的所有网页文件 移动到当前目录下 
  7. http://www.magedu.com/install/ 第一次 要安装一下  安装时指定数据库的服务器时 
  8. 写入172.16.2.3 既是server 3 的IP   
二、配置 server 2
1、安装 配置apache 同上面一样 
 
2、挂载页面文件 
 
 
   
  1. Mount -t nfs 172.16.2.1:/usr/local/apadhe/htdocs /usr/local/apadhe/htdocs 
  2. 挂载同一个网页文件,是两个web服务访问页面一样  
3、安装配置DNS
3.1
 
   
  1. #yum -y install bind97 bind97-devel bind97-libs bind97-utils 
  
3.2 配置主配置文件
 
 
   
  1. #vim /etc/named.conf  
  2.  options {  
  3.         directory       "/var/named";  
  4. };  
  5. zone "." IN {  
  6.         type hint;  
  7.         file "named.ca";  
  8. };  
  9. zone "localhost.localdomain" IN {  
  10.           type master;  
  11.           file "named.localhost";  
  12.           allow-update { none; };  
  13.   };  
  14. zone "localhost" IN {  
  15.           type master;  
  16.           file "named.localhost";  
  17.           allow-update { none; };  
  18.   };  
  19. zone "test.com." IN {  
  20.           type master;  
  21.           file "test.com.zone";  
  22.           allow-update { none; };  
  23.   };   
    3.3 配置区域文件
 
 
   
  1.  # vim test.com.zone  
  2.       $TTL 600  
  3.  @       IN SOA  ns.test.com. admin.test.com. (  
  4.                                          0       ; serial  
  5.                                          1D      ; refresh  
  6.                                          1H      ; retry  
  7.                                          1W      ; expire  
  8.                                          3H )    ; minimum  
  9.          IN      NS      ns.test.com.  
  10.  ns      IN      A       172.16.2.1  
  11.  www     IN      A       172.16.2.1  
  12.  www     IN      A        172.16.2.2    
  13. 配置两条A记录,实现轮询 
  14. 修改区域文件的数组  为named   
三、配置server 3
      1、安装mysql -5.5.20
1.1 准备数据存放的文件系统 
  实际工作需要中我们可能需要把数据放在lvm逻辑卷上,这样可以动态扩展磁盘容量 
创建逻辑卷 :
 
 
   
  1. #fdisk  /dev/sda    创建分区  t 调整类型为8e 
  2. #partprobe /dev/sda 
  3. #pvcreate /dev/sda{5,6} 
  4. #vgcreate myvg /dev/sda{5,6} 
  5. #lvcreate -L 5G -n mydata myvg 
  6. #mke2fs -j -L MYDATA /dev/myvg/mydata 
  7. #mkdir /data 
  8. #vim /etc/fstab 开机自动挂载   
  9. #mkdir /data/mysql  存mysql的数据  
  10. #chown mysql:mysql /data/mysql/ 
1.2 安装mysql 
 
 
   
  1. # tar xf mysql-5.5.24-linux2.6-i686.tar.gz -C /usr/local  
  2. #cd /usr/local 
  3. # ln -sv mysql-5.5.24-linux2.6-i686 mysql  创建连接 方便以后升级  
  4. #cd mysql  
  5. # chown -R mysql:mysql . 修改当前目录下所有文件的属主 数组  为mysql  
  6.     手动初始化  
  7. # scripts/mysql_install_db --datadir=/data/mysql/ 指定数据存放位置 
  8. --user=mysql指定用户 
1.3 为mysql提供主配置文件:
 
 
   
  1. # cd /usr/local/mysql 
  2. # cp support-files/my-large.cnf  /etc/my.cnf 
  3. thread_concurrency = 2   修改为你的CPU个数乘以2 
  4. datadir=/data/mysql    写入 数据存放位置 
1.4 为mysql提供sysv服务脚本:
 
 
   
  1. # cd /usr/local/mysql 
  2. # cp support-files/mysql.server  /etc/rc.d/init.d/mysqld 
  3. # chkconfig --add mysqld   添加至服务列表: 
  4. # chkconfig mysqld on 
1.5 将其开发组件导出给系统使用 
 
 
   
  1. 输出mysql的man手册至man命令的查找路径: 
  2. #vim /etc/man.config 
  3. MANPATH  /usr/local/mysql/man 添加  
  4. 输出mysql的头文件至系统头文件路径/usr/include: 
  5. # ln -sv /usr/local/mysql/include  /usr/include/mysql 
  6. 输出mysql的库文件给系统库查找路径: 
  7. # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf 
  8. # ldconfig  让系统重新载入系统库: 
  9. 修改PATH环境变量,让系统可以直接使用mysql的相关命令。 
  10. # vim /etc/profile 
  11. PATH=/usr/local/mysql/bin:$PATH 
  12. # export PATH=/usr/local/mysql/bin:$PATH 立即生效  
2 编译安装  php-5.4.4.tar.bz2  
2.1 
 
   
  1. # tar xf php-5.4.4.tar.bz2   
  2. # cd php-5.4.4  
  3. #  ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql 
  4. --with-openssl --enable-fpm --enable-sockets --enable-sysvshm  
  5. --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring 
  6. --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib-dir
  7.  --with-libxml-dir=/usr --enable-xml  --with-mhash --with-mcrypt 
  8.  --with-config-file-path=/etc/php --with-config-file-scan-dir=/etc/php 
  9. --with-bz2 --with-curl --with-libevent-dir=/usr/local/libevent
     
  10. --enable-fpm 一启用mpm  也就是 以fastCGI的方式  和php 通信   
  11. # make 
  12. # make test 
  13. # make intall 
 
 
   
  1. 为php提供配置文件: 
  2. # cp php.ini-production /etc/php/php.ini 
  3. 为php-fpm提供Sysv init脚本,并将其添加至服务列表: 
  4. # cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm 
  5. # chmod +x /etc/rc.d/init.d/php-fpm 
  6. # chkconfig --add php-fpm 
  7. # chkconfig php-fpm on 
2.2 为php-fpm提供配置文件:
 
 
   
  1. # cp /usr/local/php4nginx/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf  
  2. 编辑php-fpm的配置文件: 
  3. # vim /usr/local/php/etc/php-fpm.conf 
  4. 配置pm.的相关选项为你所需要的值, 
  5. pm.max_children = 50 
  6. pm.start_servers = 5 
  7. pm.min_spare_servers = 2 
  8. pm.max_spare_servers = 8 
  9. pid = /usr/local/php/var/run/php-fpm.pid  启用pid文件 
  10. 接下来就可以启动php-fpm了: 
  11. # service php-fpm start 
  12. 使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了): 
  13. # ps aux | grep php-fpm 
四、总结
   过程基本配置到此结束,下面就是测试,我在配置的过程中是每配置好一个服务,就先单独测试,测试成功了,再和其他服务联系起来 这样排错时会比较容易一些。
 
 
   
  1. 1. 配置DNS 时 一定要把区域文件的数组改为named,不然解析不到 ,这是我前几次做都失败
  2. 的原因,让我做的很崩溃。 
  3. 2. 装discuz时 权限 不对,只要按它上面提示的,找到每一项修该一下  
  4.    例如 # setfacl -m u:apache:rw config.inc.php 如果是目录就改为rwx  
  5.    如果出现乱码 则 # vim /etc/httpd/conf/httpd.conf 默认语言  
  6.       #AddDefaultCharset UTF-8 注释掉这一行   
  7. 3.安装完mysql 启动一直失败,一次是把 数据库重新初始化了一下也就是重新执行了一次 
  8. # scripts/mysql_install_db --datadir=/data/mysql/  还有可能就是端口被占用了  

  终于写完了,也算对自己有一个交代,不过实验做完了,却感觉问题越来越多了,总是想只是实际生活中是怎么做的,到底apache php mysql 是放在一台的