一、apache负载均衡器操作

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

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

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

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

            我们来观察上述的参数“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/         #注意这里以"/"结尾
            <Proxy balancer://proxy>
                BalancerMember http://www.php186.com/  loadfactor=3
                BalancerMember http://www.php186.com/  loadfactor=1
            </Proxy>

            参数”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  #注意这里以"/"结尾
            <Proxy balancer://proxy>
                BalancerMember http://www.php186.com/  loadfactor=3
                BalancerMember http://www.php186.com/  loadfactor=1
            </Proxy>

            参数“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就没有这个限制,对它来说后面是什么服务器是完全透名的。