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

[经验分享] apache+tomcat+jk配置负载均衡

[复制链接]

尚未签到

发表于 2018-11-27 13:51:24 | 显示全部楼层 |阅读模式
环境:
ubuntu 9.04
apache 2.2.11
tomcat 6.0.20
mod_jk mod_jk/1.2.26
负载均衡 ( Load Balance)  
由于目前现有网络的各个核心部分随着业务量的提高,访问量和数据流量的快速增长,其处理能力和计算强度也相应地增大,使得单一的服务 器设备根本无法承担。在  此情况下,如果扔掉现有设备去做大量的硬件升级,这样将造成现有资源的浪费,而且如果再面临下一次业务量的提升时,这又将导致再一次硬件升级的高额成本投  入,甚至性能再卓越的设备也不能满足当前业务量增长的需求。
负载平衡:即把负载压力根据某种算法合理分配到集群中的每一台计算机上,以减轻主服务器的压力,降低对主服务器的硬件和软件要求。

目前比较常用的负载均衡技术主要有

  • 基于DNS 的负载均衡
    通过DNS 服务中的随机名字解析来实现负载均衡,在DNS 服务器中,可以为多个不同的地址配置同一个名字,而最终查询这个名字的客户机将在解析这个名字  时得到其中一个地址。因此,对于同一个名字,不同的客户机会得到不同的地址,他们也就访问不同地址上的Web 服务器,从而达到负载均衡的目的
  • 反向代理负载均衡 (如apache+JK2+Tomcat 、apache+proxy http 或 apache+proxy+ajp)
  使用代理服务器可以将请求转发给内部的Web 服 务器,让代理服务器将请求均匀地转发给多台内部Web 服务器之一 上,从而达到负载均衡的目的。这种代理方 式与普通的代理方式有所不同,标准代理方式是客户使用代理访问多个外部Web 服务器,而这种代理方式是多个客户使用它访问内部Web 服务器,因此也被称为 反向代理模式。
3. 基于NAT (Network Address  Translation )的负载均衡技术  (如Linux Virtual Server ,简称LVS )
网络地址转换为在内部地址和外部地址之间进行转换,以便具备内部地址的计算机能访问外部网络,而当外部网络中的计算机访问 地址转换网关拥有的某一外部地址  时,地址转换网关能将其转发到一个映射的内部地址上。因此如果地址转换网关能将每个连接均匀转换为不同的内部服务器地址,此后外部网络中的计算机就各自与  自己转换得到的地址上服务器进行通信,从而达到负载分担的目的。



下文主要描述apache+JK2+Tomcat
相比之下 jk2  比http_proxy  和ajp_proxy  更稳定些,配置也更复杂一些
1  安装 apache  和 2 个tomcat
2  安装mod_jk
sudo apt-get install libapache2-mod-jk
查看一下在apache2 的启 动模块中是否有jk.load
$sudo ls  /etc/apache2/mods-enabled/
3  配置
/etc/libapache2-mod-jk/workers.properties

worker.list = controller,tomcat1,tomcat2  #server  列表
  #========tomcat1========
  worker.tomcat1.port=8009          #ajp13  端口号,在tomcat 下server.xml 配置, 默认8009
  worker.tomcat1.host=localhost  #tomcat 的主机地址,如不为本机,请填写ip 地址
  worker.tomcat1.type=ajp13
  worker.tomcat1.lbfactor = 1   #server 的加权比重,值越高,分得的请求越多
  #========tomcat2========
  worker.tomcat2.port=8109        #ajp13  端口号,在tomcat 下server.xml 配置, 默认8009
  worker.tomcat2.host=localhost  #tomcat 的主机地址,如不为本机,请填写ip 地址
  worker.tomcat2.type=ajp13
  worker.tomcat2.lbfactor = 1   #server 的加权比重,值越高,分得的请求越多
  #========controller, 负载均衡控制器========
  worker.controller.type=lb
  worker.controller.balanced_workers=tomcat1,tomcat2   # 指定分担请求的tomcat
  worker.controller.sticky_session=1
对于业务系统
worker.controller.sticky_session_force=true  很必要

如果tomcat 配置不对jvmRoute
worker.controller.sticky_session_force=true
会出现访问不了系统

4  配置apache2.conf :
  /usr/share/doc/libapache2-mod-jk/httpd_example_apache2.conf
  里的内容复制到 apache2.conf   的最后
# Sample mod_jk configuration
# for Apache 2
#
# for all commands/options available see the manual
# provided in libapache-mod-jk-doc package.

# The location where mod_jk will find the workers  definitions
JkWorkersFile /etc/libapache2-mod-jk/workers.properties

# The location where mod_jk is going to place its  log file
JkLogFile /var/log/apache2/mod_jk.log

# The log level:
# - info log will contain standard mod_jk activity  (default).
# - warn log will contain non fatal error reports.
# - error log will contain also error reports.
# - debug log will contain all information on  mod_jk activity
# - trace log will contain all tracing information  on mod_jk  activity
JkLogLevel info


# Assign specific URLs to Tomcat. In general the  structure of a
# JkMount directive is: JkMount [URL prefix]  [Worker name]



# send all requests ending in .jsp to ajp13_worker
JkMount /*.jsp  controller
# send all requests ending /servlet to ajp13_worker
JkMount /*/servlet/  controller

# JkUnmount directive acts as an opposite to  JkMount and blocks  access
# to a particular URL. The purpose is to be able to  filter out  the
# particular content types from mounted context.

# do not send requests ending with .gif to  ajp13_worker
#JkUnMount /servlet/*.gif  controller


# JkMount / JkUnMount directives can also be used  inside  
# sections of your httpd.conf file.
5   修改 tomcat  配置文件 server.xml  
  如果你在不同电脑上安装tomcat,tomcat 的安装数量为一个,可以不必修改tomcat 配置文件
  我这里是在同一台电脑上安装两个tomcat ,所以需要更改其中一个的设置
  打开tomcat2/conf/server.xml 文 件
tomcat1
  修改为


tomcat2
  修改为


端口修改
修改为


修改为



修改为








采用 proxy_http  的 配置
  #httpd.conf(Apache 的配置文档,如果想了解Apache 相 关配置参数,请看参考文献)
  # 载入重要的模块
  LoadModule proxy_module modules/mod_proxy.so
  LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
  LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
  LoadModule proxy_connect_module modules/mod_proxy_connect.so
  LoadModule proxy_http_module modules/mod_proxy_http.so
  LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
  # 设置负载均衡分配用的服务器
  
  BalancerMember http://1.2.3.4:6888/   route=tomcat1  loadfactor=50
  BalancerMember http://1.2.3.5:6888/ route=tomcat2 loadfactor=50
  
  # 设置代理服务器转发方式,stickysession 就 是会话保持,JSESSIONID 就是Apusic 的会话ID ,nofailover 就是 说服务器没有做集群
  ProxyPass / balancer://apusicBalance stickysession=JSESSIONID  nofailover=On
  ProxyPa***everse / balancer://apusicBalance



采用的是 ajp_proxy   的 配置。
    其中 apache   的配置如下:
  #  引入ajp  模块
  LoadModule proxy_module  modules/mod_proxy.so
  LoadModule proxy_ajp_module  modules/mod_proxy_ajp.so
  #  用于监控界面
  LoadModule proxy_balancer_module  modules/mod_proxy_balancer.so
  ProxyPass /test  balancer://mycluster  stickysession=JSESSIONID
  BalancerMember ajp://localhost:8009/test  route=tomcat1  loadfactor=50
  BalancerMember ajp://localhost:9009/test  route=tomcat2  loadfactor=50


需要注意的几个地方
1 Session  黏性 需要tomcat 中server.xml 配置
  修改为

这样在用户请求中 的sessionId  会是 uuid.tomcat1   如70C011A23F79A154D8002FBFBABD4A82.tomcat1    这样就知道你请求上次请求到那个服务器。
2  测试JSP



Cluster App  Test


Server Info:

String dataName =  request.getParameter("dataName");
if (dataName != null &&  dataName.length() > 0) {
String dataValue =  request.getParameter("dataValue");
session.setAttribute(dataName,  dataValue);
}
out.print("Session  列表");
Enumeration e = session.getAttributeNames();
while (e.hasMoreElements()) {
String name =  (String)e.nextElement();
String value =  session.getAttribute(name).toString();
out.println( name + " = " +  value+"");
System.out.println( name + " =  " + value);
}
%>


名称:

数值:






运维网声明 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-640389-1-1.html 上篇帖子: centos 5.0 编译安装apache 2.2.6+php5.2.5+mysql5.0.46+Zend笔记 下篇帖子: PHP+APACHE+MYSQL简单配置 (陆续添加内容)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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