apache+多个tomcat+memcached共享session会话(ubuntu12.04篇)
2012-08-27 22:48
375 查看
参考:
http://thetechnocratnotebook.blogspot.com/2012/05/installing-tomcat-7-and-apache2-with.html
ubuntu下apache+tomcat+jk配置负载均衡
目前比较常用的负载均衡技术主要有
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
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
[html]
view plaincopyprint?
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:localhost:11211"
requestUriIgnorePattern=".*/.(png|gif|jpg|css|js)$"
sessionBackupAsync="false"
sessionBackupTimeout="100"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
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服务器,参见
/article/2309042.html
5、测试代码以及测试结果
创建webapps/balance/test.jsp文件
启动apache以及2个tomcat服务,还有别忘了memcache服务正常启动检查一下(telnet 127.0.0.1 11211 &stats)
在浏览器中输入localhost/balance/test.jsp
填写键值,提交
刷新页面
http://thetechnocratnotebook.blogspot.com/2012/05/installing-tomcat-7-and-apache2-with.html
Nginx+Tomcat+Memcached集群Session共享(windows)
ubuntu下apache+tomcat+jk配置负载均衡
Ubuntu Server 10.04+Apache2+Tomcat7+jk+负载均衡(原创)
目前比较常用的负载均衡技术主要有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
[html]
view plaincopyprint?
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:localhost:11211"
requestUriIgnorePattern=".*/.(png|gif|jpg|css|js)$"
sessionBackupAsync="false"
sessionBackupTimeout="100"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
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服务器,参见
/article/2309042.html
5、测试代码以及测试结果
创建webapps/balance/test.jsp文件
<%@ page contentType="text/html; charset=utf-8" %> <%@ page import="java.util.*" %> <html><head><title>Cluster App Test</title></head> <body> Server Info: <% out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%> <% out.println("<br> ID " + session.getId()+"<br>"); // 如果有新的 Session 属性设置 String dataName = request.getParameter("dataName"); if (dataName != null && dataName.length() > 0) { String dataValue = request.getParameter("dataValue"); session.setAttribute(dataName, dataValue); } out.print("<b>Session 列表</b>"); Enumeration e = session.getAttributeNames(); while (e.hasMoreElements()) { String name = (String)e.nextElement(); String value = session.getAttribute(name).toString(); out.println( name + " = " + value+"<br>"); System.out.println( name + " = " + value); } %> <form action="test.jsp" method="POST"> 名称:<input type=text size=20 name="dataName"> <br> 值:<input type=text size=20 name="dataValue"> <br> <input type=submit> </form> </body> </html>
启动apache以及2个tomcat服务,还有别忘了memcache服务正常启动检查一下(telnet 127.0.0.1 11211 &stats)
在浏览器中输入localhost/balance/test.jsp
填写键值,提交
刷新页面
相关文章推荐
- apache+多个tomcat+memcached共享session会话(ubuntu12.04篇)
- apache+多个tomcat+memcached共享session会话(windows篇)
- memcached-session-manager配置(tomcat 全局会话共享)
- Apache+Tomcat+Memcached共享Session的构架设计
- 服务器安装Apache+Tomcat+Memcached共享Session的构架设计
- Apache+Tomcat+Memcached共享Session的构架设计
- apache+tomcat+memcached实现负载均衡,session共享(摘抄+整合)
- Apache+Tomcat+Memcached共享Session的构架设计
- Nginx+Memcached+Tomcat session会话共享实战
- apache + tomcat + mod_jk解决session会话共享的问题
- Apache+Tomcat负载均衡两种session共享方式的设置之二复制会话
- Apache+Tomcat负载均衡两种session共享方式的设置之二复制会话
- Nginx+LAT(apache+tomcat)的实现和使用memcached保存tomcat的session会话 推荐
- 服务器安装Apache+Tomcat+Memcached共享Session的构架设计
- 基于Memcached的tomcat集群session共享
- nginx+memcached处理tomcat中session共享问题
- Nginx+Tomcat+Memcached集群Session共享
- tomcat使用memcached完成集群(session共享实现方式)
- tomcat + memcached 实现session共享
- Tomcat+Memcached实现Session共享