欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

apache和nginx负载均衡配置

程序员文章站 2022-05-21 17:49:23
...
 一、apache负载均衡器操作

            apache功能其实很是强大,最近一段时间研究了下apache的反向代理和负载均衡,反向代理网协的外网出口和我的博客出口就是通过apache的反向代理实现的,总结一下,重点说说负载均衡的配置。
            
            操作系统:DEBIAN 5.03(Ubuntu也可以同理配置)

            (1)、轮询均衡策略的配置

            进入Apache的conf目录,打开httpd.conf文件,在文件的末尾加入:

            ProxyPass / balancer://proxy/         #注意这里以"/"结尾
            
                BalancerMember http://www.php186.com/
                BalancerMember http://www.php186.com/
            

            我们来观察上述的参数“ProxyPass / balancer://proxy/”,其中,“ProxyPass”是配置虚拟服务器的命令,“/”代表发送Web请求的URL前缀,如:http: //myserver/或者http://myserver/aaa,这些URL都将符合上述过滤条件;“balancer://proxy/”表示要配置负载均衡,proxy代表负载均衡名;BalancerMember 及其后面的URL表示要配置的后台服务器,其中URL为后台服务器请求时的URL。以上面的配置为例,实现负载均衡的原理如下:
            假设Apache接收到http://localhost/aaa请求,由于该请求满足ProxyPass条件(其URL前缀为“/”),该请求会被分发到后台某一个BalancerMember,譬如,该请求可能会转发到 http://www.php186.com/aaa进行处理。当第二个满足条件的URL请求过来时,该请求可能会被分发到另外一台 BalancerMember,譬如,可能会转发到http://www.php186.com/。如此循环反复,便实现了负载均衡的机制。

            (2)、按权重分配均衡策略的配置

            ProxyPass / balancer://proxy/         #注意这里以"/"结尾
            
                BalancerMember http://www.php186.com/  loadfactor=3
                BalancerMember http://www.php186.com/  loadfactor=1
            

            参数”loadfactor”表示后台服务器负载到由Apache发送请求的权值,该值默认为1,可以将该值设置为1到100之间的任何值。以上面的配置为例,介绍如何实现按权重分配的负载均衡,现假设Apache收到http://myserver/aaa 4次这样的请求,该请求分别被负载到后台服务器,则有3次连续的这样请求被负载到BalancerMember为 http://www.php186.com的服务器,有1次这样的请求被负载BalancerMember为http: //www.php186.com后台服务器。实现了按照权重连续分配的均衡策略。

            (3)、权重请求响应负载均衡策略的配置

            ProxyPass / balancer://proxy/ lbmethod=bytraffic  #注意这里以"/"结尾
            
                BalancerMember http://www.php186.com/  loadfactor=3
                BalancerMember http://www.php186.com/  loadfactor=1
            

            参数“lbmethod=bytraffic”表示后台服务器负载请求和响应的字节数,处理字节数的多少是以权值的方式来表示的。 “loadfactor” 表示后台服务器处理负载请求和响应字节数的权值,该值默认为1,可以将该值设置在1到100的任何值。根据以上配置是这么进行均衡负载的,假设 Apache接收到http://myserver/aaa请求,将请求转发给后台服务器,如果BalancerMember为http: //www.php186.com后台服务器负载到这个请求,那么它处理请求和响应的字节数是BalancerMember为http: //www.php186.com 服务器的3倍(回想(2)均衡配置,(2)是以请求数作为权重负载均衡的,(3)是以流量为权重负载均衡的,这是最大的区别)。
            注:每次修改httpd.conf,用apachectl –k restart重新启动Apache。


        二、Nginx负载均衡操作
             Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,它已经在该站点运行超过两年半了。Igor 将源代码以类BSD许可证的形式发布。尽管还是测试版,但是,Nginx 已经因为它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名了。
             首先是配置十分的简单,而且功能非常强大。真是相见恨晚。先来看看配置文件怎么写吧

            worker_processes 1;  
            events {  
                worker_connections 1024;  
            }  
            http{  
                upstream myproject {  
                    #这里指定多个源服务器,ip:端口,80端口的话可写可不写  
                    server 192.168.43.158:80;  
                    server 192.168.41.167;  
                }  
                server {  
                    listen 8080;  
                    location / {  
                        proxy_pass http://myproject;  
                    }  
                }  
            } 

Nginx负载均衡有哪些功能呢?

            如果后面的服务器其中一台坏了,它能自动识别,更牛的是它好了之后Nginx可以马上识别服务器A和B,如果A的响应时间为3,B的响应时间为1,那么 Nginx会自动调整访问B的概率是A的3倍,真正做到Nginx负载均衡好的,安装完成了。我在make的时候报了个错,说HTTP Rewrite 模块 有问题,我就

            ./configure –without-http_rewrite_module
            然后再make,make install就可以了。

            安装好了之后新建一个配置文件,把上面的配置文件内容拷进去,当然要修改你的IP,保存为比如 load_balance.conf然后启动:

            /usr/local/Nginx/sbin/Nginx -c load_balence.conf

            由于Nginx的作者是俄国人,所以英文的文档也不是那么完善,对于我来说Nginx的最大优点还是配置简单,功能强大。我曾经配过 apache-jk,那真的不是一般人能配的。太复杂了,而且只能用来做tomcat的Nginx负载均衡。

            Nginx就没有这个限制,对它来说后面是什么服务器是完全透名的。

以上就介绍了apache和nginx负载均衡配置,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。