`
小混蛋
  • 浏览: 20566 次
社区版块
存档分类
最新评论

Apache负载均衡设置方法

阅读更多
如果一个节点挂掉了,会自动跳过此节点


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。

分享到:
评论

相关推荐

    负载均衡apache

    负载均衡apache负载均衡apache负载均衡apache负载均衡apache负载均衡apache负载均衡apache负载均衡apache负载均衡apache负载均衡apache

    Nginx+Apache负载均衡

    Nginx+Apache负载均衡

    apache2.2.4 负载均衡.txt

    apache2.2.4 负载均衡.txtapache2.2.4 负载均衡.txtapache2.2.4 负载均衡.txt随着访问量的不断提高,以及对响应速度的要求,进行负载均衡设置就显得非常必要了。公司的系统在最初设计的时候就已经考虑到了负载均衡的...

    Apache负载均衡实现

    通过Apache的反向代理实现负载均衡,内有相应的安装包、操作文档(配详细图文)、配置文件、测试页面,应有尽有!

    Apache负载均衡设置方法 mod_proxy使用介绍

    一般来说,负载均衡就是将客户端的请求分流给后端的各个真实服务器,达到... 废话少说,下面就来解释一下负载均衡的设置方法。 一般来说,负载均衡就是将客户端的请求分流给后端的各个真实服务器,达到负载均衡的目的

    Apache负载均衡含Linux和windows版本

    Apache负载均衡含Linux和windows版本,其中Linux包含一些Linux系统中安装必须的依赖包: tomcat-connectors-1.2.42-src.tar pcre-8.40.tar.gz httpd-2.4.25.tar.gz apr-util-1.5.4.tar.gz apr-1.5.2.tar.gz等。 并配...

    apache 负载均衡集群

    apache负载均衡的详细配置,你能根据这份文档的介绍,轻松的配置web服务器的负载均衡,让服务器运行更稳定。

    apache配置负载均衡

    Apache从软件上低投入实现访问请求分流,提高访问性能, 负载均衡就是把所有用户的访问压力分散到多台服务器上, 也可以分散到多个tomcat里

    weblogic apache负载均衡

    weblogic apache负载均衡

    apachetomcat负载均衡整合文档.pdf

    apachetomcat负载均衡整合文档

    Apache Tomcat 负载均衡

    Apache Tomcat 负载均衡配置说明

    apache服务器负载均衡方案

    apache服务器负载均衡方案

    Apache负载均衡

    这是有关于如何实现Apache2.2和Tomcat7集成负载均衡的技术,需要学习的可以拿下来。

    Weblogic加Apache的负载均衡以及群集配置

    Weblogic的负载均衡可以通过软件和硬件的方式实现。硬件可以使用F5等设备,软件一般使用apache来实现。下面说明使用apache的具体方法。 Weblogic的负载均衡可以通过软件和硬件的方式实现。硬件可以使用F5等设备,...

    Apache+Jboss负载均衡加域名转发

    Apache+Jboss负载均衡加域名转发

    Apache+tomcat负载均衡

    Apache+tomcat负载均衡配置详解工具及文档

    Apache,Tomcat集群和负载均衡

    Apache,Tomcat集群和负载均衡包括了apache-tomcat-5.5.29.zip,apache_2.2.4-win32-x86-no_ssl.msi,mod_jk-1.2.28-httpd-2.2.3.so,ApacheTomcat整合文档.doc,Apache,Tomcat集群和负载均衡教程.doc,Tomcat负载...

    apache 负载均衡配置

    本例子讲述 apache 负载均衡配置,里面包含了所需要用到的所有的软件和程序,以及使用说明和设置说明,简单可用。

    apache反向代理+负载均衡.txt

    Apache负载均衡和反向代理配置文件开启的模块及代码配置方法。。。。。。。。。。。。。。。。。。。

Global site tag (gtag.js) - Google Analytics