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

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负载均衡设置方法 mod_proxy使用介绍

    Apache负载均衡设置方法主要依赖于`mod_proxy`模块,这是一种在Apache HTTP服务器中实现负载均衡和反向代理的功能。负载均衡的目标是分散客户端的请求到多个后端服务器,以优化资源利用,提高响应速度,以及增强系统...

    apache配置负载均衡

    Apache 配置负载均衡实现访问请求分流提高访问性能 Apache 配置负载均衡是将所有用户的访问压力分散到多...Apache 配置负载均衡是提高访问性能和可用性的有效方法,可以应用于各种场景,提高系统的整体性能和可用性。

    Apache负载均衡实现

    Apache负载均衡实现是一种高效的方法,用于在多台服务器之间分散网络流量,以提高系统的可用性和响应速度。在本文中,我们将深入探讨如何使用Apache HTTP Server作为反向代理,实现负载均衡的功能。 首先,Apache ...

    apache 负载均衡集群

    Apache 负载均衡集群是一种优化Web服务器性能和可靠性的技术。通过将工作负载分散到多个服务器上,这种集群能够确保即使单个服务器...正确配置和管理Apache负载均衡集群,能够显著提升企业的业务连续性和客户满意度。

    java使用apache+resin实现负载均衡设置

    Java 使用 Apache+Resin 实现负载均衡设置 ...本文介绍了使用 Apache+Resin 实现负载均衡设置的方法,包括 Resin 的负载均衡设置、Apache+Resin 的组合、负载均衡的配置等。希望本文能够对读者有所帮助。

    Apache负载均衡

    Apache负载均衡是网络服务优化的一种策略,通过将网络流量分散到多个服务器,以提高系统响应速度,提升服务的可用性和可靠性。在本场景中,我们关注的是Apache2.2与Tomcat7的集成,用于实现Web应用的负载均衡。...

    Apache负载均衡器配置

    ### Apache负载均衡器配置详解 #### 一、背景介绍 在现代互联网应用中,随着访问量的不断增加,单台服务器往往难以满足高并发的需求。为了提高系统的可用性和扩展性,通常采用集群技术来分担压力。Jboss作为一款...

    Nginx+Apache负载均衡

    ### Nginx+Apache负载均衡知识点详解 #### 一、Nginx简介及特性 **Nginx** 是一种高性能的 HTTP 和反向代理 Web 服务器,同时也支持 IMAP/POP3/SMTP 服务。其核心特点包括: - **高性能**:能够处理大量并发连接...

    apache2.2.4 负载均衡.txt

    #### 二、Apache负载均衡基础配置 要启用Apache的负载均衡功能,首先需要加载几个必要的模块: ```apache LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_ajp_module modules/mod_proxy_ajp.so ...

    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 负载均衡是一种网络技术,用于在多台服务器之间分发网络流量,从而提高系统的可用性和响应速度,防止单点故障,并优化资源利用。Apache HTTP Server 提供了 mod_proxy 模块来实现这一功能,它允许你将来自...

    apache服务器负载均衡方案

    #### 三、Apache负载均衡配置步骤 ##### 1. 启用代理模块 首先,需要确保Apache已经安装了必要的代理模块。通过编辑`httpd.conf`文件,取消以下行的注释启用相关模块: ```apache LoadModule proxy_module ...

    apache+tomcat集负载均衡

    Apache 和 Tomcat 集群负载均衡是一种常见的高可用性和可扩展性解决方案,它通过将请求分散到多个服务器上,确保即使单个服务器出现问题,整个系统仍能保持正常运行,并且能够处理更多的并发请求。 首先,我们需要...

    apachetomcat负载均衡整合文档.pdf

    Apache Tomcat 负载均衡整合是通过特定的配置实现多台Tomcat服务器协同工作,以提高应用的可用性和响应速度。在这个过程中,Apache HTTP Server作为前端代理,负责接收客户端请求,并根据预设的策略将请求分发到后端...

    Apache Tomcat 负载均衡

    在Apache Tomcat中,负载均衡可以通过集群配置实现,即通过设置多个Tomcat实例来分担服务请求,确保即使某个节点出现故障,其他节点仍能继续提供服务。 ### 二、配置Apache Tomcat负载均衡 #### 1. 配置`server....

    weblogic apache负载均衡

    weblogic apache负载均衡

    jboss4.2.3GA集群配置 Apache负载均衡

    JBoss 4.2.3GA 集群配置与Apache负载均衡详解 在IT行业中,高可用性和负载均衡是企业级应用的关键要素。JBoss 4.2.3GA是一个流行的Java应用服务器,通过配置集群可以提高服务的稳定性和性能。而Apache作为Web服务器...

    Apache+tomcat负载均衡

    Apache+Tomcat的负载均衡配置就是为了解决这一问题。 负载均衡的基本思想是将来自用户的请求分发到多个后端服务器,这样可以避免任何单一服务器过载,同时提高整体服务的可靠性和响应时间。Apache通常通过其模块mod...

    apache 负载均衡配置

    下面我们将深入探讨Apache负载均衡配置的相关知识点。 首先,我们要理解负载均衡的基本概念。负载均衡是一种网络技术,用于在多台服务器之间分配网络负载,防止单点故障,提升服务的可扩展性和性能。在Apache中,...

Global site tag (gtag.js) - Google Analytics