设为首页 收藏本站
查看: 593|回复: 0

[经验分享] Apache负载均衡设置方法

[复制链接]

尚未签到

发表于 2017-1-1 08:14:44 | 显示全部楼层 |阅读模式
如果一个节点挂掉了,会自动跳过此节点


Apache负载均衡设置方法 准备:

Jdk1.6

下载地址:http://java.sun.com

tomcat -6.0.29

下载地址:http://jakarta.apache.org

apache_2.2.4-win32-x86-no_ssl.msi

下载地址:http://httpd.apache.org/download.cgi

mod_jk-1.2.31-httpd-2.0.52.so (主要作用是建立Apache Server与Tomcat之间的连接)

下载地址:http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/



   说明:apache-server安装完成后,可以在浏览器中输入http://localhost/来测试,如果出现” It works!”则表示安装成功。

  本地安装两个tomcat  访问端口 8081 和9081

1. 负载均衡的设置

1).基本配置
Apache可以应对上面这两种需求。先来讨论一下如何做负载均衡。假设一台apache服务器域名为www.a.com, 首先需要启用Apache的几个模块:


Httpd.conf代码
LoadModule proxy_module modules/mod_proxy.so  
LoadModule proxy_balancer_module modules/mod_proxy_balancer.so  
LoadModule proxy_http_module modules/mod_proxy_http.so  

mod_proxy提供代理服务器功能,mod_proxy_balancer提供负载均衡功能, mod_proxy_http让代理服务器能支持HTTP协议。如果把mod_proxy_http换成其他协议模块(如mod_proxy_ftp),或许能支持其他协议的负载均衡,有兴趣的朋友可以自己尝试一下。

然后要添加以下配置:


Httpd.conf代码
ProxyRequests Off  
<Proxy balancer://mycluster>  
    BalancerMember http://localhost:8081
    BalancerMember http://localhost:9081
</Proxy>  
ProxyPass / balancer://mycluster/  
# 警告:以下这段配置仅用于调试,绝不要添加到生产环境中!!!  
<Location /balancer-manager>  
    SetHandler balancer-manager  
    order Deny,Allow  
    Deny from all  
    Allow from localhost  
</Location>  


注:node-a.myserver.com,node-b.myserver.com是另外两台服务器的域名,不是当前服务器的域名

从上面的 ProxyRequests Off 这条可以看出,实际上负载均衡器就是一个反向代理,只不过它的代理转发地址不是某台具体的服务器,而是一个 balancer:// 协议:

ProxyPass / balancer://mycluster协议地址可以随便定义。然后,在<Proxy>段中设置该balancer协议的内容即可。 BalancerMember指令可以添加负载均衡组中的真实服务器地址。

下面那段<Location /balancer-manager>是用来监视负载均衡的工作情况的,调试时可以加上(生产环境中禁止使用!),然后访问 http://localhost/balancer-manager/ 即可看到负载均衡的工作状况。

OK,改完之后重启服务器,访问你的Apache所在服务器的地址(www.a.com),即可看到负载均衡的效果了。

出错提示:
访问网页提示Internal Serveral Error,察看error.log文件


Error.log代码
[warn] proxy: No protocol handler was valid for the URL /admin/login_form. If you are using a DSO version of mod_proxy, make sure the proxy submodules are included in the configuration using LoadModule.   

原因是配置:# ProxyPass / balancer://mycluster 可能少了一个/

2). 负载比例分配
打开 balancer-manager 的界面,可以看到请求是平均分配的。

如果不想平均分配怎么办?给 BalancerMember 加上 loadfactor 参数即可,取值范围为1-100。比如你有三台服务器,负载分配比例为 7:2:1,只需这样设置:


Httpd.conf代码
ProxyRequests Off  
<Proxy balancer://mycluster>  
    BalancerMember http://node-a.myserver.com:8080 loadfactor=7  
    BalancerMember http://node-b.myserver.com:8080 loadfactor=2  
    BalancerMember http://node-c.myserver.com:8080 loadfactor=1  
</Proxy>  
ProxyPass / balancer://mycluster  


3).负载分配算法

默认情况下,负载均衡会尽量让各个服务器接受的请求次数满足预设的比例。如果要改变算法,可以使用 lbmethod 属性。如:



Httpd.conf代码
ProxyRequests Off  
<Proxy balancer://mycluster>  
    BalancerMember http://node-a.myserver.com:8080 loadfactor=7  
    BalancerMember http://node-b.myserver.com:8080 loadfactor=2  
    BalancerMember http://node-c.myserver.com:8080 loadfactor=1  
</Proxy>  
ProxyPass / balancer://mycluster  
ProxySet lbmethod=bytraffic  


lbmethod可能的取值有:

lbmethod=byrequests 按照请求次数均衡(默认)
lbmethod=bytraffic 按照流量均衡
lbmethod=bybusyness 按照繁忙程度均衡(总是分配给活跃请求数最少的服务器)

各种算法的原理请参见Apache的文档。

2. 热备份(Hot Standby)
热备份的实现很简单,只需添加 status=+H 属性,就可以把某台服务器指定为备份服务器:


Httpd.conf代码
ProxyRequests Off  
<Proxy balancer://mycluster>  
    BalancerMember http://node-a.myserver.com:8080  
    BalancerMember http://node-b.myserver.com:8080 status=+H  
</Proxy>  
ProxyPass / balancer://mycluster  


从 balancer-manager 界面中可以看到,请求总是流向 node-a ,一旦node-a挂掉, Apache会检测到错误并把请求分流给 node-b。Apache会每隔几分钟检测一下 node-a 的状况,如果node-a恢复,就继续使用node-a。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-322179-1-1.html 上篇帖子: 转载: Apache Zookeeper入门1 下篇帖子: Windows下Apache整合Tomcat
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表