密码:
网络营销 it新闻 军事新闻 社会新闻 it技术 网站优化 游戏资讯 公司资讯
nginx+多个Tomcat+Memcached共享session会话
发布日期:2014-03-19 阅读数:1836 来源:java技术网站 由金功呈网站建设公司整理 【关闭】



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

1、基于DNS的负载均衡

通过DNS服务中的随机名字解析来实现负载均衡,在DNS服务器中,可以为多个不同的地址配置同一个名字,而最终查询这个名字的客户机将在解析这个名字 时得到其中一个地址。因此,对于同一个名字,不同的客户机会得到不同的地址,他们也就访问不同地址上的Web服务器,从而达到负载均衡的目的

2、反向代理负载均衡 (如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模式

1、环境

apache+2个tomcat+memcached服务器

2、Ubuntu上apache \tomcat\memcached 服务器安装

a、安装 apache2

sudo apt-get install apache2

可以通过浏览器测试是否安装成功 http://localhost/

b、下载官方的tar压缩版本tomcat7(本案用的是7.0.29),并tar -zxvf 解压缩成2个名字不一样的文件夹

       

 

c、apache2 mod jk安装以及配置

sudo apt-get install libapache2-mod-jk

编辑workers.properties,添加如下内容

sudo gedit /etc/apache2/workers.properties

worker.list=controller,tomcat1,tomcat2 

worker.tomcat1.type=ajp13
worker.tomcat1.host=localhost
worker.tomcat1.port=8009
worker.tomcat1.lbfactor = 1 

worker.tomcat2.type=ajp13
worker.tomcat2.host=localhost
worker.tomcat2.port=9009
worker.tomcat2.lbfactor = 1 

#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2   #指定分担请求的tomcat
worker.controller.sticky_session=false

并替换sudo gedit /etc/apache2/mods-available/jk.conf

中JkWorkersFile属性值为/etc/apache2/workers.properties

最后,编辑虚拟主机文件

sudo gedit /etc/apache2/sites-enabled/default

 

<VirtualHost *:80>
.......................................
.......................................
JkMount /* controller
</VirtualHost *:80>

3、修改tomcat配置

第一个tomcat的conf/server.xml

    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
    <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

 

第二个tomcat的conf/server.xml

    <Connector port="9009" protocol="AJP/1.3" redirectPort="8443" />
    <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">

 

注意这个里面的Connector端口配置都是需要和第三步当中的workers.properties的端口一致。同时jvmRoute也要匹配一致。

当然还要保证conf/server.xml文件当中包含的端口都不要一致,集中改第二个tomcat即可。

修改Tomcat的context.xml

  1. <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"   
  2.   
  3. memcachedNodes="n1:localhost:11211"   
  4.   
  5. requestUriIgnorePattern=".*/.(png|gif|jpg|css|js)$"   
  6.   
  7. sessionBackupAsync="false"   
  8.   
  9. sessionBackupTimeout="100"  
  10.   
  11. transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"   
  12.   
  13. copyCollectionsForSerialization="false"/>  

需要用到的jar包:

memcached-2.6.jar(https://code.google.com/p/spymemcached/downloads/detail?name=spymemcached-2.8.4.jar

javolution-5.4.3.1.jar

memcached-session-manager-1.5.1.jar

memcached-session-manager-tc7-1.5.1.jar

msm-javolution-serializer-1.5.1.jar

msm-kryo-serializer-1.5.1.jar

msm-xstream-serializer-1.5.1.jar

以上jar包在http://code.google.com/p/memcached-session-manager/downloads/list中都可以找到。放入tomcat/lib目录下

4、安装memcached服务器,参见http://www.linuxidc.com/Linux/2012-08/69313.htm

5、测试代码以及测试结果

创建webapps/balance/test.jsp文件

  1. <%@ page contentType="text/html; charset=utf-8" %>  
  2. <%@ page import="java.util.*" %>  
  3. <html><head><title>Cluster App Test</title></head>  
  4. <body>  
  5. Server Info:  
  6. <%  
  7. out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>  
  8. <%  
  9. out.println("<br> ID " + session.getId()+"<br>");  
  10. // 如果有新的 Session 属性设置  
  11. String dataName = request.getParameter("dataName");  
  12. if (dataName != null && dataName.length() > 0) {  
  13. String dataValue = request.getParameter("dataValue");  
  14. session.setAttribute(dataName, dataValue);  
  15. }  
  16. out.print("<b>Session 列表</b>");  
  17. Enumeration e = session.getAttributeNames();  
  18. while (e.hasMoreElements()) {  
  19. String name = (String)e.nextElement();  
  20. String value = session.getAttribute(name).toString();  
  21. out.println( name + " = " + value+"<br>");  
  22. System.out.println( name + " = " + value);  
  23. }  
  24. %>  
  25. <form action="test.jsp" method="POST">  
  26. 名称:<input type=text size=20 name="dataName">  
  27. <br>  
  28. 值:<input type=text size=20 name="dataValue">  
  29. <br>  
  30. <input type=submit>  
  31. </form>  
  32. </body>  
  33. </html>  
启动apache以及2个tomcat服务,还有别忘了memcache服务正常启动检查一下(telnet 127.0.0.1 11211 &stats)

 

在浏览器中输入localhost/balance/test.jsp

 

填写键值,提交

刷新页面


广州金功呈网站建设网微信二维码
  • 深圳市一键一家网络科技有限公司官方网址:http://www.songhu9.com.cn
  • QQ:316675593,电话号码:19807655856
  • 业务范围:公司网站建设、管理软件研发、软件网站二次开发、400电话、电商平台研发、公众号研发!
  • 免责申明:本站内容均来源于网络,版权归原创所有,如有任何版权方面的问题,请与我们联系处理!