之前配置的tomcat集群使用的是tomcat提供的简单的集群管理的方式:
配置参考的文档有:点击打开链接、在这个链接里可以找到与你的Tomcat匹配的jar包,以及Tomcat配置的方法。下面记录一下我的配置过程。
1.根据前面博客的内容配置好Nginx反向代理;
2.在ubuntu下安装memcache:
可直接使用下面的命令进行安装
sudo apt-get install memcached
这个文件里有各个参数的配置,在这里要把-l参数注释掉,因为默认情况下memcache会监听所有地址,或者把127.0.0.1改为0.0.0.0来让memcache监听默认地址。
如果不这么做的话,就只能在本机上使用memcached,其他机器连接不进来,也就没有了意义。
配置完后,可以使用如下的命令查看是否能连接memcache,其中ip是memcache主机安装的ip地址,11211是memcache的监听端口。
telnet ip 11211
4.在所有的Tomcat节点上编辑CATALINA_HOME/conf/context.xml文件,在
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:cloud2:11211,n2:cloud3:11211"
sticky="false"
sessi
lockingMode="auto"
requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"
/>5.添加一些jar包到CATALINA_HOME/lib下
我这里使用到的包有:
memcached-session-manager-1.8.3.jar memcached-session-manager-tc8-1.8.3.jar spymemcached-2.11.1.jar
我这里的测试思路是这样的,使用如下代码建立一个Servlet,然后部署到两个tomcat服务器上。只启动其中一个服务器,然后通过浏览器访问负载均衡服务器,可在浏览器上查看并记下此时的SessionID。然后关闭这个服务器,启动另一个tomcat服务器,然后再用相同的地址访问负载均衡服务器,再在浏览器上查看SessionID,若两次SessionID一致,则说明SessionID被共享了。
package com.cyber_space.Servlet;
import java.io.IOException;
import java.io.PrintWriter;
import java.net.Inet4Address;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class TestServlet
*/
@WebServlet("/TestServlet")
public class TestServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
public TestServlet() {
super();
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
handle(request, response);
}
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
handle(request, response);
}
private void handle(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setHeader("Content-type", "text/html;charset=UTF-8");
String remoteIpString = request.getRemoteAddr() + " " + request.getRemoteHost() + " " + request.getRemoteUser();
PrintWriter pw = response.getWriter();
pw.println("请求来自:" + remoteIpString);
request.getSession().setAttribute("5", 5);
String sessionID = request.getSession().getId();
pw.println("赋予它的SESSIONID是:" + sessionID);
Inet4Address inet4Address = (Inet4Address) Inet4Address.getLocalHost();
pw.println("服务器的IP地址是:" + inet4Address.getHostAddress());
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
以上就介绍了Ubuntu1404下,Tomcat8+Nginx+memcache配置服务器集群session共享,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号