apache+tomcat 负载均衡

其实无论是分布式,数据缓存,还是负载均衡,无非就是改善网站的性能瓶颈,在网站源码不做优化的情况下,负载均衡可以说

是最直接的手段了。其实抛开这个名词,放开了说,就是希望用户能够分流,也就是说把所有用户的访问压力分散到多台服务器上,也可以

分散到多个tomcat里,如果一台服务器装多个tomcat,那么即使是负载均衡,性能也提高不了太多,不过可以提高稳定性,即容错性。

当其中一个主tomcat当掉,其他的tomcat也可以补上,因为tomcat之间实现了Session共享。待tomcat服务器修复后再次启动,就会

自动拷贝所有session数据,然后加入集群。这样就可以不间断的提供服务。如果要真正从本质上提升性能,必须要分布到多台服务器。

同样tomcat也可以做到。网上相关资料比较多,可以很方便的查到,但是质量不算高。我希望可以通过这篇随笔,系统的总结。本文的

例子是同一台服务器上运行两个tomcat,做两个tomcat之间的负载均衡。其实多台服务器各配置一个tomcat也可以,而且那样的话,可以使用

安装版的tomcat,而不用是下文中的免安装的tomcat,而且tomcat端口配置也就不用修改了。下文也会提到。

tomcat的负载均衡需要apache服务器的加入来实现。在进行配置之前请先卸载调已安装的tomcat,然后检查apache的版本。

我这次配置使用的是apache-tomcat-6.0.18免安装版本,我亲自测试后推断安装版的tomcat在同一台机子上会不能启动两个以上,可能是

因为安装版的tomcat侵入了系统,导致即使在server.xml里修改了配置,还是会引起冲突。所以我使用tomcat免安装版。

apache使用的是apache_2.2.19-win32-x86-no_ssl.msi。如果版本低于2.2负载均衡的配置要有所不同,因为这个2.2.19、2.2.11、2.2.8版本

集成了jk2等负载均衡工具,所以配置要简单许多。别的版本我没有具体测试,有待考究。这两个软件可以到官方网站下载。

把Apache安装为运行在80端口的Windows服务,安装成功后在系统服务列表中可以看到Apache2.2服务。服务启动后在浏览器中

输入http://localhost进行测试,如果能看到一个"It works!"的页面就代表Apache已经正常工作了。把tomcat解压到任意目录,赋值一个另命名。

起名和路径对配置没有影响。但要保证端口不要冲突,如果装有Oracle或IIS的用户需要修改或关闭相关接口的服务。当然jdk的配置也是

必须的,这个不再过多叙述。

首先,在Apache安装目录下找到conf/httpd.conf文件,去掉以下文本前的注释符(#)以便让Apache在启动时自动加载代理(proxy)

模块。

LoadModule proxy_module modules/mod_proxy.so

LoadModuleproxy_ajp_modulemodules/mod_proxy_ajp.so

LoadModuleproxy_balancer_modulemodules/mod_proxy_balancer.so

LoadModuleproxy_connect_modulemodules/mod_proxy_connect.so

LoadModuleproxy_ftp_modulemodules/mod_proxy_ftp.so

LoadModule proxy_http_module modules/mod_proxy_http.so

向下拉动文档找到<IfModule dir_module>节点,在DirectoryIndex index.html后加上index.jsp,这一步只是为了待会配置完tomcat后能看到小

猫首页,可以不做。继续下拉文档找到Include conf/extra/httpd-vhosts.conf,去掉前面的注释符。

然后打开conf/extra/httpd-vhosts.conf,配置虚拟站点,在最下面加上

<!--<br></!--<br></div></div><div class="share_buttons" id="sharePanel"></div><div class="article_next_prev"> <li class="prev_article"> <span>上一篇:</span><a href="http://blog.csdn.net/free_xiang/article/details/6559022">生成输入目录下的所有文件名.html</a></li></div></div><div id="ad_cen"></div><script type="text/javascript"> new Ad(4, 'ad_cen');</script><div class="panel_head">查看评论<a name="comments"></a></div><div id="comment_list"></div><div id="comment_bar"></div><div id="comment_form"></div><div class="announce">* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场</div><script type="text/javascript"> var fileName = '6609209'; var commentscount = 0; var islock = false</script><script type="text/javascript" src="http://static.blog.csdn.net/scripts/comment.js"></script><div id="ad_bot"></div><script type="text/javascript"> new Ad(5, 'ad_bot');</script> <div class="clear"></div> </div> </div> <div id="side"> <div class="side"><div id="panel_Profile" class="panel"> <ul class="panel_head"><span>个人资料</span></ul> <ul class="panel_body profile"> <div id="blog_userface"> <a href="http://hi.csdn.net/free_xiang" target="_blank" title="进入个人空间"> <img src="http://avatar.csdn.net/0/4/F/1_free_xiang.jpg" style="max-width:90%"/> </a> <br /> <span>free_xiang</span> </div> <div id="blog_medal"> </div> <ul id="blog_rank"> <li>访问:<span>3066次</span></li> <!--<li>积分:<span>830分</span></li> <li>排名:<span>千里之外</span></li>-->
  • 原创:23篇
  • 转载:25篇
  • 译文:0篇
  • 评论:2条
  • 文章搜索
  • 文章分类
  • 阅读排行
  • android模拟器操作 (1024)
  • spring下连接池比较 (295)
  • struts2+json+jquery ... (232)
  • SSH Secure Shell Cli... (184)
  • YUI Changing the Con... (171)
  • tomcat内存溢出 (158)
  • 利用eclipse编写高质量的java代... (115)
  • Android模拟器调试与真机调试 (107)
  • sqlserve2000 关于100万数... (92)
  • DB2建备份表和清空表 (77)
  • 评论排行
  • Flex自定义日历控件 (2)
  • apache+tomcat 负载均衡 (0)
  • 快捷删除文件夹下的所有.svn文件夹 (0)
  • DB2建备份表和清空表 (0)
  • DB2数据库命令 (0)
  • DB2删除数据库 (0)
  • Java中解决所有路径问题 (0)
  • 利用eclipse编写高质量的java代... (0)
  • struts2+json+jquery ... (0)
  • js随机抽人员比赛并导出为excel (0)
  • 最新评论

相关推荐