热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

两台Web服务器实现负载均衡+FastCGI模块+MySQL实现分布式架构

两台Web服务器实现负载均衡+FastCGI模块+MySQL实现分布式架构操作系统:RedHat5.8实验环境准备:三台服务器Server1IP:172.16.2.1安装:apacheNFS
两台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.   

推荐阅读
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • Tomcat安装与配置教程及常见问题解决方法
    本文介绍了Tomcat的安装与配置教程,包括jdk版本的选择、域名解析、war文件的部署和访问、常见问题的解决方法等。其中涉及到的问题包括403问题、数据库连接问题、1130错误、2003错误、Java Runtime版本不兼容问题以及502错误等。最后还提到了项目的前后端连接代码的配置。通过本文的指导,读者可以顺利完成Tomcat的安装与配置,并解决常见的问题。 ... [详细]
  • [翻译]微服务设计模式5. 服务发现服务端服务发现
    服务之间需要互相调用,在单体架构中,服务之间的互相调用直接通过编程语言层面的方法调用就搞定了。在传统的分布式应用的部署中,服务地 ... [详细]
  • ZooKeeper 学习
    前言相信大家对ZooKeeper应该不算陌生。但是你真的了解ZooKeeper是个什么东西吗?如果别人面试官让你给他讲讲ZooKeeper是个什么东西, ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • Java和JavaScript是什么关系?java跟javaScript都是编程语言,只是java跟javaScript没有什么太大关系,一个是脚本语言(前端语言),一个是面向对象 ... [详细]
  • 解决Sharepoint 2013运行状况分析出现的“一个或多个服务器未响应”问题的方法
    本文介绍了解决Sharepoint 2013运行状况分析中出现的“一个或多个服务器未响应”问题的方法。对于有高要求的客户来说,系统检测问题的存在是不可接受的。文章详细描述了解决该问题的步骤,包括删除服务器、处理分布式缓存留下的记录以及使用代码等方法。同时还提供了相关关键词和错误提示信息,以帮助读者更好地理解和解决该问题。 ... [详细]
  • PHP组合工具以及开发所需的工具
    本文介绍了PHP开发中常用的组合工具和开发所需的工具。对于数据分析软件,包括Excel、hihidata、SPSS、SAS、MARLAB、Eview以及各种BI与报表工具等。同时还介绍了PHP开发所需的PHP MySQL Apache集成环境,包括推荐的AppServ等版本。 ... [详细]
  • 负载均衡_Nginx反向代理动静分离负载均衡及rewrite隐藏路径详解(Nginx Apache MySQL Redis)–第二部分
    nginx反向代理、动静分离、负载均衡及rewrite隐藏路径详解 ... [详细]
  • Nginx Buffer 机制引发的下载故障
    Nginx ... [详细]
author-avatar
mobiledu2502894115
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有