Apache负载均衡配置(反向代理模式)

Apache负载均衡配置(反向代理模式)参考地址:https://blog.csdn.net/wgw335363240/article/details/8221444Apache负载均衡配置(反向代理模式)本文只适合EKP产品,至于应用

大家好,又见面了,我是你们的朋友全栈君。

参考地址:https://blog.csdn.net/wgw335363240/article/details/8221444

Apache负载均衡配置(反向代理模式)

本文只适合EKP产品,至于应用集群是我们自己实现的功能,所以这里的配置可能与其他产品的配置是不一致的。

目前我们使用apache 做为前端负载均衡的转发器。考虑到jk 的不稳定性,我们建议使用代理模式协同工作。因此, 安装的apache 需要有proxy_module,proxy_ftp_module,proxy_http_module, rewrite_module,proxy_connect_module、proxy_balancer_module和proxy_ajp_module模块。

下面以配置Apache与应用“ekp”整合为例,说明Apache如何与IP为“192.168.3.119”和“192.168.3.116”两台机器上的app应用是如何协同的。

1.1  确认开启负载均衡模块

打开Apache安装目录/conf/httpd.conf文件,开启下图中红色框内的模块,如果行是以“#”号开头,则去掉“#”号(“#”号开头的行为注释行),如下图:

<span role="heading" aria-level="2">Apache负载均衡配置(反向代理模式)

1.2  添加EKP负载均衡配置文件

在httpd.conf文件接近末尾的位置,增加引用ekp配置文件的配置,代码如下:

# Virtual ekp host for balacing

Include conf/httpd-ekp-balance.conf

新增配置在配置文件中的位置如下图:

<span role="heading" aria-level="2">Apache负载均衡配置(反向代理模式)

1.3  EKP负载均衡配置文件设置

在Apache安装目录/conf目录下新建一个名为“httpd-ekp-balance.conf”的文件,在该文件中添加下面的内容。下面的内容是一个完整的两个EKP节点的集群示例设置,一般来说,只要替换其中的具体IP 及相关目录的路径即可完成配置。如果多于两个节点,则是在proxy 节处加入BalancerMember 并在后面的ProxyPassReverse 节加入新的节点即可。下表中的红色部分“m69”和“m115”需要与每个应用ekp\WEB-INF\classes\trswcmcluster.properties文件中的参数“cluster.session.balancerRoute”保持一致。

<VirtualHost *:80>

    AddType text/javascript .js

    AddType text/css; .css

    AddType text/html;charset=UTF-8  .html

    ServerName my.ekp.com

    ServerAdmin wu.guowei@trs.com.cn

    <Proxy  balancer://ekpcluster>

        BalancerMember http://192.9.200.69:8065 route=m69

        BalancerMember http://192.9.200.115:8060 route=m115

        ProxySet stickysession=CSID

    </Proxy>

    RewriteEngine on

    RewriteRule  ^/ekp/(.*\.(jsp|do|jws|appletdo))$ balancer://ekpcluster/ekp/$1 [P,L]

    RewriteRule  ^/ekp/(.*;jsessionid.*)$ balancer://ekpcluster/ekp/$1 [P,L]

    RewriteRule ^/ekp/(sd)$  balancer://ekpcluster/ekp/$1 [P,L]

RewriteRule ^/ekp/(TRSIdSSSOProxyServlet)$  balancer://ekpcluster/ekp/$1 [P,L]

    #SoapService rule

    RewriteRule ^/ekp/services/(.*) http://192.9.200.69:8065/ekp/services/$1 [P,L]

 

    ProxyPassReverse / http://192.9.200.69:8065/

    ProxyPassReverse /http://192.9.200.115:8060/

   

#webpic

    Alias /webpic “Z:/WCMData/webpic

    <Directory “Z:/WCMData/webpic“>

        Options -Indexes MultiViews  FollowSymLinks Includes

        AllowOverride None

        Order allow,deny

        Allow from all

    </Directory>

    <Directory  “D:/TRS/TRSEKPV65_Cluster_B1111/WCMData/webpic/WEB-INF”>

        Deny from all

    </Directory>

 

#ekp

    Alias /ekp “D:/TRS/TRSEKPV65_Cluster_B1111/Tomcat/webapps/ekp

    <Directory “D:/TRS/TRSEKPV65_Cluster_B1111/Tomcat/webapps/ekp“>

        Options -Indexes MultiViews  FollowSymLinks Includes

        DirectoryIndex index.html

        AllowOverride None

        Order allow,deny

        Allow from all

    </Directory>

    <Directory “D:/TRS/TRSEKPV65_Cluster_B1111/Tomcat/webapps/ekp/WEB-INF“>

        Deny from all

    </Directory>

    <Location  /ekpcluster-manager>

        SetHandler balancer-manager

        #Deny from all

        #设定可以访问管理器的主机

        Allow from all

    </Location>

</VirtualHost>

 

注意事项

l  route与stickysession

会话固定是负载均衡器的一个重要功能,其作用是把用户会话固定在一个服务节点上,当且仅当该节点失效时才会将会话转发到其它节点处理。这两项的设置与EKP的设置也有关系,下面会再说到。

l  配置文件中的RewriteRule都要在一行

示例中的一些换行可能是文档排版需要,在实际设置时要注意每一条RewriteRule都是一行。

l  共享目录地址

如果主节点和Apache配置在同一台机器上,则共享目录地址建议直接使用安装的WCMData地址。

1.4  EKP负载均衡配置主要配置说明

httpd-ekp-balance.conf主要配置说明如下:

#section 1 设置负载均衡的成员

<Proxy  balancer://ekpcluster>

        BalancerMember http://192.9.200.69:8065 route=m69

        BalancerMember http://192.9.200.115:8060 route=m115

        ProxySet stickysession=CSID

</Proxy>

#section 2 设置转发规则,只有动态请求才转发到应用服务器

RewriteEngine  on

    RewriteRule  ^/ekp/(.*\.(jsp|do|jws|appletdo))$ balancer://ekpcluster/ekp/$1 [P,L]

    RewriteRule ^/ekp/(.*;jsessionid.*)$  balancer://ekpcluster/ekp/$1 [P,L]

RewriteRule ^/ekp/(sd)$ balancer://ekpcluster/ekp/$1 [P,L]

RewriteRule ^/ekp/(TRSIdSSSOProxyServlet)$ balancer://ekpcluster/ekp/$1  [P,L]

#之下ip可指向集群中任意的EKP服务器地址和对应应用端口

    RewriteRule ^/ekp/services/(.*) http://192.9.200.103:18080/ekp/services/$1 [P,L]

#section 3 转发规则,反向代理模式转发到应用服务器

#ProxyPassReverse  / balancer://ekpcluster

ProxyPassReverse  / http://192.9.200.69:8065/

ProxyPassReverse  / http://192.9.200.115:8060/

#section 4  apache 均衡管理器

<Location /ekpcluster-manager>

                   SetHandler  balancer-manager

                   #Deny  from all

                   #设定可以访问管理器的主机

                   Allow  from 192.9.200.69

</Location>

 

 

Apache负载均衡配置(反向代理模式)

本文只适合EKP产品,至于应用集群是我们自己实现的功能,所以这里的配置可能与其他产品的配置是不一致的。

目前我们使用apache 做为前端负载均衡的转发器。考虑到jk 的不稳定性,我们建议使用代理模式协同工作。因此, 安装的apache 需要有proxy_module,proxy_ftp_module,proxy_http_module, rewrite_module,proxy_connect_module、proxy_balancer_module和proxy_ajp_module模块。

下面以配置Apache与应用“ekp”整合为例,说明Apache如何与IP为“192.168.3.119”和“192.168.3.116”两台机器上的app应用是如何协同的。

1.1  确认开启负载均衡模块

打开Apache安装目录/conf/httpd.conf文件,开启下图中红色框内的模块,如果行是以“#”号开头,则去掉“#”号(“#”号开头的行为注释行),如下图:

<span role="heading" aria-level="2">Apache负载均衡配置(反向代理模式)

1.2  添加EKP负载均衡配置文件

在httpd.conf文件接近末尾的位置,增加引用ekp配置文件的配置,代码如下:

# Virtual ekp host for balacing

Include conf/httpd-ekp-balance.conf

新增配置在配置文件中的位置如下图:

<span role="heading" aria-level="2">Apache负载均衡配置(反向代理模式)

1.3  EKP负载均衡配置文件设置

在Apache安装目录/conf目录下新建一个名为“httpd-ekp-balance.conf”的文件,在该文件中添加下面的内容。下面的内容是一个完整的两个EKP节点的集群示例设置,一般来说,只要替换其中的具体IP 及相关目录的路径即可完成配置。如果多于两个节点,则是在proxy 节处加入BalancerMember 并在后面的ProxyPassReverse 节加入新的节点即可。下表中的红色部分“m69”和“m115”需要与每个应用ekp\WEB-INF\classes\trswcmcluster.properties文件中的参数“cluster.session.balancerRoute”保持一致。

<VirtualHost *:80>

    AddType text/javascript .js

    AddType text/css; .css

    AddType text/html;charset=UTF-8  .html

    ServerName my.ekp.com

    ServerAdmin wu.guowei@trs.com.cn

    <Proxy  balancer://ekpcluster>

        BalancerMember http://192.9.200.69:8065 route=m69

        BalancerMember http://192.9.200.115:8060 route=m115

        ProxySet stickysession=CSID

    </Proxy>

    RewriteEngine on

    RewriteRule  ^/ekp/(.*\.(jsp|do|jws|appletdo))$ balancer://ekpcluster/ekp/$1 [P,L]

    RewriteRule  ^/ekp/(.*;jsessionid.*)$ balancer://ekpcluster/ekp/$1 [P,L]

    RewriteRule ^/ekp/(sd)$  balancer://ekpcluster/ekp/$1 [P,L]

RewriteRule ^/ekp/(TRSIdSSSOProxyServlet)$  balancer://ekpcluster/ekp/$1 [P,L]

    #SoapService rule

    RewriteRule ^/ekp/services/(.*) http://192.9.200.69:8065/ekp/services/$1 [P,L]

 

    ProxyPassReverse / http://192.9.200.69:8065/

    ProxyPassReverse /http://192.9.200.115:8060/

   

#webpic

    Alias /webpic “Z:/WCMData/webpic

    <Directory “Z:/WCMData/webpic“>

        Options -Indexes MultiViews  FollowSymLinks Includes

        AllowOverride None

        Order allow,deny

        Allow from all

    </Directory>

    <Directory  “D:/TRS/TRSEKPV65_Cluster_B1111/WCMData/webpic/WEB-INF”>

        Deny from all

    </Directory>

 

#ekp

    Alias /ekp “D:/TRS/TRSEKPV65_Cluster_B1111/Tomcat/webapps/ekp

    <Directory “D:/TRS/TRSEKPV65_Cluster_B1111/Tomcat/webapps/ekp“>

        Options -Indexes MultiViews  FollowSymLinks Includes

        DirectoryIndex index.html

        AllowOverride None

        Order allow,deny

        Allow from all

    </Directory>

    <Directory “D:/TRS/TRSEKPV65_Cluster_B1111/Tomcat/webapps/ekp/WEB-INF“>

        Deny from all

    </Directory>

    <Location  /ekpcluster-manager>

        SetHandler balancer-manager

        #Deny from all

        #设定可以访问管理器的主机

        Allow from all

    </Location>

</VirtualHost>

 

注意事项

l  route与stickysession

会话固定是负载均衡器的一个重要功能,其作用是把用户会话固定在一个服务节点上,当且仅当该节点失效时才会将会话转发到其它节点处理。这两项的设置与EKP的设置也有关系,下面会再说到。

l  配置文件中的RewriteRule都要在一行

示例中的一些换行可能是文档排版需要,在实际设置时要注意每一条RewriteRule都是一行。

l  共享目录地址

如果主节点和Apache配置在同一台机器上,则共享目录地址建议直接使用安装的WCMData地址。

1.4  EKP负载均衡配置主要配置说明

httpd-ekp-balance.conf主要配置说明如下:

#section 1 设置负载均衡的成员

<Proxy  balancer://ekpcluster>

        BalancerMember http://192.9.200.69:8065 route=m69

        BalancerMember http://192.9.200.115:8060 route=m115

        ProxySet stickysession=CSID

</Proxy>

#section 2 设置转发规则,只有动态请求才转发到应用服务器

RewriteEngine  on

    RewriteRule  ^/ekp/(.*\.(jsp|do|jws|appletdo))$ balancer://ekpcluster/ekp/$1 [P,L]

    RewriteRule ^/ekp/(.*;jsessionid.*)$  balancer://ekpcluster/ekp/$1 [P,L]

RewriteRule ^/ekp/(sd)$ balancer://ekpcluster/ekp/$1 [P,L]

RewriteRule ^/ekp/(TRSIdSSSOProxyServlet)$ balancer://ekpcluster/ekp/$1  [P,L]

#之下ip可指向集群中任意的EKP服务器地址和对应应用端口

    RewriteRule ^/ekp/services/(.*) http://192.9.200.103:18080/ekp/services/$1 [P,L]

#section 3 转发规则,反向代理模式转发到应用服务器

#ProxyPassReverse  / balancer://ekpcluster

ProxyPassReverse  / http://192.9.200.69:8065/

ProxyPassReverse  / http://192.9.200.115:8060/

#section 4  apache 均衡管理器

<Location /ekpcluster-manager>

                   SetHandler  balancer-manager

                   #Deny  from all

                   #设定可以访问管理器的主机

                   Allow  from 192.9.200.69

</Location>

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155617.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • javaweb教务管理系统源码_java做一个学生管理系统

    javaweb教务管理系统源码_java做一个学生管理系统刚学完javaweb,做个项目练手与巩固所学的知识,同时分享自己写的这个教务管理系统,同样也是为自己记下笔记。为以后复习有帮助。该系统没有用到框架的知识,一共花了7天写出来。所以非常适合javaweb初学者教务管理系统javaweb项目运行环境:window系统,ApacheTomcatv7.0.84、JDK1.8开发环境:J2EEeclipse、navicatformysql运用的技术…

    2022年10月16日
    0
  • 苹果x蓝牙打不开一直转圈圈(苹果7p蓝牙一直转圈打不开)

    大家好,我是时间财富网智能客服时间君,上述问题将由我为大家进行解答。iphonex蓝牙一直转的解决方法是:1、重启手机;2、如果不行备份数据恢复手机的出厂设置;3、仍旧不行,可能是WiFi模块接接触不良,可能是因为进水或者摔过,建议去苹果直营店检修。iPhoneX(英语读音为iPhoneten)是北京时间2017年9月13日凌晨1点在ApplePark新总部史蒂夫・乔布斯剧院2017苹果秋季新品发…

    2022年4月10日
    299
  • 初识visifire图表「建议收藏」

    初识visifire图表「建议收藏」   在使用过jschart之后,觉得对俺们中国人不是很友善,短时间内是不会支持中文,没法用,也就这样就认识了visifire图表,第一次浏览他的网站就被他的华丽迷上了。   从他的网站上download下来,压缩包里面已经包含了samples。   首先必须在自己的机器上面安装微软的siverlight控件,否则你是不能浏览图表的,这个好办,到微软的网站上下载就可以了。   安装好siv

    2022年7月21日
    11
  • rabbitmq集群搭建_rabbitmq创建队列

    rabbitmq集群搭建_rabbitmq创建队列一普通集群以如下两台服务器为例ip:172.16.9.8hostname:rabbitmq1(master)ip:172.16.9.9hostname:rabbitmq2(slave)1.修改host文件编辑/etc/hosts文件,添加172.16.9.8rabbitmq1172.16.9.9rabbitmq22.复制cookie内容打开文件然后需要先把172.16.9.8服务器的/var/lib/rabbitmq/.erla…

    2022年9月11日
    0
  • 到底什么是集群&分布式

    到底什么是集群&分布式

    2020年11月12日
    215
  • java课程设计成绩管理系统_Java课程设计–学生成绩管理系统

    java课程设计成绩管理系统_Java课程设计–学生成绩管理系统一、团队名称:##团队成员林艺薇201721123032网络1712黄毓颖201721123033网络1712唐川201721123034网络1712梁才玉201721123038网络1712##任务分配#三、项目git提交记录截图#四、项目功能架构图与主要功能流程图##思维导图##成绩管理流程图#五、项目运行截图##主界面##选择用户##教师登陆界面##…

    2022年7月9日
    18

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号