tomcat集群下的session共享和负载均衡(memcache实现)

简介: tomcat集群下的session共享和负载均衡(memcache实现)

环境


操作系统:windows

tomcat1:Apache Tomcat/7.0.52(8085)

tomcat2:Apache Tomcat/7.0.52(8086)

jdk:1.8.0_251

nginx:nginx-1.20.1(8070)

memcache:1.4.4-14-g9c660c0(11211)


说明


基于memcache实现的session共享,基于nginx实现的负载均衡和反向代理。


部署

  • session共享配置


1、拷贝相关jar包到所有tomcat的lib目录下

memcache.zip


2、编辑tomcat/conf/server.xml,修改内部的端口配置,保证端口号不会被重复使用(多服务器时端口可相同),Engine标签内增加jumRoute配置(多个tomcat配置不同)


<Server port="8015" shutdown="SHUTDOWN">
    <Service name="Catalina">
        <Connector
            port="8085"
            protocol="HTTP/1.1" 
            redirectPort="8443"/>
    </Service>
    <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">
  </Engine>
</Server>


3、编辑tomcat/conf/context.xml,在Context标签内增加内容如下:


<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" 
          memcachedNodes="n1:127.0.0.1:11211" 
          requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$" 
          sessionBackupAsync="false" 
      sessionBackupTimeout="3000" 
transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" 
          copyCollectionsForSerialization="false" />


说明:Manager 标签内的memcachedNodes信息为memcache组件的信息

  • 反向代理和负载均衡配置


1、在nginx/conf/nginx.conf文件中进行配置

可参考如下(包含反向代理和负载均衡):

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
  upstream web-01 {
    server 192.168.0.168:8085 weight=1;
    server 192.168.0.168:8086 weight=1;
  }
    server {
        listen       8070;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
      proxy_pass http://web-01;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}


  • tomcat测试资源


部署test.jsp到测试包内

test.jsp内容参考如下(title和h1的内容可根据不同的tomcat进行调整以方便观察):

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>tomcat1</title>
</head>
<body>
<center><h1>tomcat1</h1></center>
<center>
<h3>sessionId:</h3><%=session.getId()%>
<h3>session创建时间:</h3><%=session.getCreationTime()%>
<center>
</body>
</html>


启动

  • 双击nginx/nginx.exe启动
  • cmd管理员模式进入到memcache安装路径下,执行命令memcached.exe -d start启动,可在服务中查看是否启动成功
  • 双击tomcat/bin/startup.bat启动多个tomcat


测试

  • 浏览器输入test.jsp所在资源的路径,页面中会包含tomcat信息和sessionId信息


88dc84b1d3bb44dfa3dce9c2d9aa1f5e.png

请求地址的ip和port为nginx代理的

e6afbf86da984bf484deb089cce133f8.png


  • 可以观察到nginx会将多次请求进行负载均衡转发到不同的tomcat上,同时所有tomcat的sessionId是同一个


06d8149354a641a4b02e6e999bc5a8ed.png

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
负载均衡 应用服务中间件 nginx
百度搜索:蓝易云【Nginx和tomcat实现负载均衡教程】
至此,你已经成功地使用Nginx和Tomcat实现了负载均衡。Nginx将根据配置的负载均衡策略将客户端请求分发到多个Tomcat服务器上,以提高系统的性能和可用性。请注意,在实际生产环境中,还需要进行其他配置和优化,如健康检查、会话保持等,以满足具体的需求。
156 0
|
负载均衡 应用服务中间件 nginx
nginx-tomcat反向代理以及负载均衡测试
nginx-tomcat反向代理以及负载均衡测试
228 0
|
11月前
|
负载均衡 前端开发 应用服务中间件
Tomcat的负载均衡和动静分离(与nginx联动)
总的来说,负载均衡和动静分离是提高Web应用性能的两个重要手段。通过合理的配置和使用,我们可以让Web应用更好地服务于用户。
349 21
|
11月前
|
负载均衡 Java 应用服务中间件
Tomcat与Nginx的负载均衡与动静分离技巧
总的来说,Tomcat和Nginx各有各的优点,在负载均衡和动静分离这两方面它们都有很好的应用。灵活使用这两个工具能够让Web应用具有更好的扩展性和用户体验。
343 14
|
11月前
|
负载均衡 前端开发 JavaScript
LVS-DR模式、keepalived、Nginx与Tomcat合作,打造动静分离,高效负载均衡与高可用性
为了采用这样的架构,你需要对LVS-DR、Keepalived、Nginx与Tomcat有一定的理解和掌握,同时也需要投入一些时间去研究和配置,但是一旦你把它运行起来,你将会发现,这一切都是值得的。
436 11
|
Java 应用服务中间件 Shell
Nginx+Keepalived+Tomcat 实现Web高可用集群
Nginx+Keepalived+Tomcat 实现Web高可用集群
478 0
apache+tomcat配置多站点集群的方法
apache+tomcat配置多站点集群的方法
222 4
|
负载均衡 应用服务中间件 Apache
Tomcat负载均衡原理详解及配置Apache2.2.22+Tomcat7
Tomcat负载均衡原理详解及配置Apache2.2.22+Tomcat7
310 3
|
缓存 负载均衡 NoSQL
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
235 1
|
负载均衡 前端开发 应用服务中间件
Nginx+Tomcat负载均衡配置_nginx做tomcat的负载均衡成功,但tomcat的css文件400
Nginx+Tomcat负载均衡配置_nginx做tomcat的负载均衡成功,但tomcat的css文件400

相关实验场景

更多
下一篇
开通oss服务