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

[经验分享] Apache tomcat 负载平衡配置

[复制链接]

尚未签到

发表于 2016-12-31 09:50:00 | 显示全部楼层 |阅读模式
  以前做企业应用的时候,都只用tomcat部署项目,从没接触过apache,apache在脑海里只是个战斗机的名称。
  

  现在做网站,网站的部署是用apache + tomcat来实现的。自然而然也慢慢了解了apache,上次迁移网站的服务器,装过一
  

  次apache,就简单的configure , make ,make install 三步曲搞定,配置文件都用的以前服务器上apache的,至于那些配
  

  置是啥子含义,完全不懂。最近网站出了问题,问题出在apache身上,所以花了点时间来了解apache 和tomcat的配置。
  

  “整合 Apache Http Server 和 Tomcat 可以提升对静态文件的处理性能、利用 Web 服务器来做负载均衡以及容错、无缝
  

  的升级应用程序。本文介绍了三种整合 Apache 和 Tomcat 的方式。”  这句话概括了为啥要用apache的原因。简单的说就
  

  是把一些静态资源给apache处理,比如:css,html, images。 而动态的东西通过apache转给tomcat来处理,jsp, servlet
  

  请求等等。
  

  apache 和 tomcat 连接有三种方式 :1.JK ,2 .http_proxy ,3. ajp_proxy 。之前看到robbin在一个帖子里说
  

  jk的连接方式已经淘汰了,貌似apache官网还是有jk的更新,由于我们网站之前用的是jk, 所以暂时还是用jk的方式。
  

  有机会可以测试下jk 和ajp_proxy到底哪种方式更好些。
  

  根据这几天对apache的了解,我记录下JK的连接方式。
  

  装完apache和tomcat后,把mod_jd.so文件拷贝到apache/modules目录下,在httpd.conf中加一句
  

  LoadModule jk_module modules/mod_jk.so,告诉服务器装载jk模块。
  

  准备两个配置文件,workers.properties和uriworkermap.properties ,分别放在conf目录下。
  

  在httpd.conf里指明这两个文件的位置:
  

     <IfModule jk_module>
     JkWorkersFile conf/workers.properties
     JkMountFile conf/uriworkermap.properties
     JkLogFile logs/mod_jk.log
     </IfModule>
  

  

  workers.properties文件的内容如下:
  

  

  worker.list=loadbalancer
  worker.balaweb54_1.port=2009
  worker.balaweb54_1.host=localhost
  worker.balaweb54_1.type=ajp13
  worker.balaweb54_1.lbfactor=1
  worker.balaweb54_1.socket_keepalive=1
  worker.balaweb54_1.socket_timeout=0
  worker.balaweb54_1.retries=3
  worker.loadbalancer.type=lb
  worker.retries=3
  worker.loadbalancer.balance_workers=balaweb54_1
  worker.loadbalancer.sticky_session=true
  worker.loadbalancer.sticky_session_force=false
  

  

  定义了一个名为balaweb54_1的worker,使用ajp13协议来通讯,apache连接tomcat的端口
  

  是2009,host=localhost表示监听2009端口的主机是本机,lbfactor定义负载平衡的权
  

  值,socket_keepalive这个值在web服务器和tomcat之间装有防火墙的时候需要用到,因为防火墙会丢掉处于
  

  inactive状态的连接,如果设置了这个值为true(默认为false)的话,操作系统会不断的发KEEP_LIVE信息给这个连接,这
  

  样的话,防火墙就不会丢掉这种处于inactive状态的连接,貌似这个属性对我们网站而言也用不上,用默认值就Ok了。
  

  socket_timeout:就不介绍了。
  

  上面还定义了一个type为lb的worker,表示有多个tomcat的时候,在多个tomcat之间均衡负载,这里只配置一个
  

  tomcat,这负载全给这个tomcat , sticky_session官网的解释:Specifies whether requests with
  

  SESSION ID's should be routed back to the same Tomcat worker. If sticky_session is
  

  set to True or 1 sessions are sticky, otherwise sticky_session is set to False. Set
  

  sticky_session to False when Tomcat is using a Session Manager which can persist
  

  session data across multiple instances of Tomcat.
  

   sticky_session_force 的解释:Specifies whether requests with SESSION ID's for
  

  workers that are in error state should be rejected. If sticky_session_force is set
  

  to True or 1 and the worker that matches that SESSION ID is in error state, client will
  

  receive 500 (Server Error). If set to False or 0 failover on another worker will be
  

  issued with loosing client session. This directive is used only when you
  

  set sticky_session=True.
  

  “If set to False or 0 failover on another worker will be issued with loosing client session. This directive is used only when you set sticky_session=True.”
  
   这句话不是很明白。貌似这两个值在只有一台tomcat服务器的时候,用默认值就Ok了。
  

  我觉得在只有一个tomcat的时候,这两个sticky的配置完全可以删掉。
  

  uriworkermap.properties文件的内容如下:
  

  /*.do=loadbalancer
  /*.jsp=loadbalancer
  /dwr/*=loadbalancer
  /servlet/*=loadbalancer
  !/*.shtml=loadbalancer
  !/*.html=loadbalancer
  !/*.js=loadbalancer
  !/*.css=loadbalancer
  !/*.jpg=loadbalancer
  !/*.gif=loadbalancer


loadbalancer即workers文件里面定义的loadbalancer,/*.do ,/*.jsp , /dwr/* ,


/servlet/* 这几个表示这样的动态


请求交给loadbalancer处理,而shtml ,html ......这些不交给loadbalancer处理,即由


apache处理,这就验证了开始


说的,静态请求有apache处理,动态请求由tomcat处理,!/*.shtml=loadbalancer ,感


叹号!表示 "非"的意思。




apache的官方说明:http://tomcat.apache.org/connectors-doc/reference/printer/workers.html

运维网声明 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-321884-1-1.html 上篇帖子: Apache POI操作Word统观 下篇帖子: Apache MINA学习之路(1)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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