实战,利用apache来做集群,实现负载均衡

前端之家收集整理的这篇文章主要介绍了实战,利用apache来做集群,实现负载均衡前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

以前用ha,lvs做过负载均衡,我知道apache可以做负载均衡,一直没有做。所以今天我尝试用apache做了一次负载均衡。感觉还可以,以后如果有公司非要让我用apache来做负载均衡,也不要花很多时间去研究了。

一,查看有没有安装过mod_proxy之类的东西

[zhangy@BlackGhost ~]$ /usr/local/apache2/bin/httpd -l

如果没有发现mod_proxy,我们就到apache安装目录下的modules里面看看有没有mod_proxy.so文件,如果都没有,则说明没有加载负载均衡的模块

二,安装mod_proxy,proxy_balancer_module等


进入apache的解压目录,就是你从网上下载下来的压缩文件,然后解压产生的目录。

cd   apache的解压目录/modules/proxy

[root@BlackGhost proxy]# /usr/local/apache2/bin/apxs -c -i mod_proxy.c proxy_util.c

注意:上面如果不加proxy_util.c的话,LoadModule proxy_module modules/mod_proxy.so会报错的,提示你找不到mod_proxy.so文件

[root@BlackGhost proxy]# /usr/local/apache2/bin/apxs -c -i mod_proxy_balancer.c

[root@BlackGhost proxy]# /usr/local/apache2/bin/apxs -c -i mod_proxy_http.c

出现下面的东西说明装好了。

———————————————————————-
Libraries have been installed in:
/usr/local/apache2/modules

#要安装的模块装好了
[zhangy@BlackGhost apache2]$ ls ./modules/
httpd.exp     mod_fastcgi.so    mod_proxy.so           mod_rewrite.so
libPHP5.so    mod_fcgid.so      mod_proxy_balancer.so
mod_cache.so  mod_mem_cache.so  mod_proxy_http.so

三,配置httpd.conf,测试负载均衡

1,根据请求数(默认),平均分配

  1. LoadModule proxy_module modules/mod_proxy.so
  2. LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
  3. LoadModule proxy_http_module modules/mod_proxy_http.so
  4.  
  5. ProxyRequests Off
  6. PHPinfo>
  7. BalancerMember http://192.168.18.2:10004
  8. BalancerMember http://192.168.18.2:10000
  9. PHPinfo stickysession=STICK_PORT_TOKEN nofailover=On
  10. ProxyPassReverse /test2 balancer://clusterPHPinfo
  11. 配置说明:httpd.conf里面添加以上配置

  12. 1,为什么我这里要用/test2而不是,因为在这里用/会和documentroot冲突,因为监听的都是80端口。2stickysession 从字面上看,严格的session加上他说明实现严格的session负载均衡,根据个人需要吧。

  13. 3,其实像这样的负载均衡,其实就是反向代理,http://localhost/test2起到了连接池的作用,如果你访问http://localhost/test2/index.PHP,他其实访问的http://192.168.18.2:10004/index.PHP或者是http://192.168.18.2:10000/index.PHP

  14. 4内容是用监测负载均衡的情况的,可 以放到正式服务器,也可以不放。

  15. 访问http://localhost/test2/balancer-manager看下图:

  16. apache负载均衡

    apache负载均衡

  17. 图片说明:从上图我们可以看出,负载均衡算法是根据请求数(byrequests),平均分配到二个虚拟主机。

  18. 2,给节点加权重,根据挂起的请求数进行平衡

  19. LoadModule proxy_module modules/mod_proxy.so
  20. LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
  21. LoadModule proxy_http_module modules/mod_proxy_http.so
  22. ProxyRequests Off
  23. PHPinfo>
  24. BalancerMember http://192.168.18.2:10004 loadfactor=5
  25. BalancerMember http://192.168.18.2:10000 loadfactor=1
  26. ProxySet lbmethod=bytraffic
  27. PHPinfo stickysession=STICK_PORT_TOKEN nofailover=On
  28. ProxyPassReverse /test2 balancer://clusterPHPinfo
  29. 配置说明:说一下不同的

  30. 1,平衡算法,由byrequests变成bytraffic

  31. 2,由平均分配变成非平均分配

  32. apache负载均衡bytraffic

    apache负载均衡bytraffic

猜你在找的Nginx相关文章