Session会话之tomcat解决方案

一.常见的session共享方案

1.使用nginx的ip_hash

使用ip绑定ip_hash算法时,用户的请求都会绑在同一个节点服务器上,这样的设置会导致一台或多台服务器过载无法提供服务,而后端正常的服务器无法提供服务,当绑定的服务器挂了,用户只能重启浏览器后才能重新访问,这样用户体验度极差,除了特殊需要,不建议使用这种机制实现session共享

2.基于服务端的session共享

1)服务端的session复制

session复制是指session信息会在集群节点之间复制,每个节点服务器上都会有session信息。
优点:即使一个节点服务器挂了,只要还有服务器可以提供服务,就不会影响用户使用。
缺点:服务器之间通信频繁,效能感应速度有影响,多并发、高频率操作的情况下性能下降比较明显。

2)session共享

将session缓存之内存或保存在本地文件中,使用redis/memcached/file来实现。

3)session持久化

将session存储在数据库中,像操作数据一样操作session。

二.session应用方案

解决session共享的问题,网上有很多的解决方案,比如通过memcached来实现,通过redis来实现,很多人都是通过jcoleman的redis解决方案,但是此方案仅支持tomcat6和7,如果要支持tomcat8或9需要修改代码,然后打包部署,非常麻烦。不建议使用。
这里主要介绍一个更为简单的方案:redisson,支持最新的jdk和各个版本的tomcat,官方网站:https://redisson.org/redisson是redis官网推荐的java语言实现的分布式锁项目。该项目还包括很多的分布式结构项目,这里主要使用的是redisson提供的tomcat session manager 功能。
tomcat session 共享的githu的地址:https://github.com/redisson/redisson/tree/master/redisson-tomcat

三.场景规划与地址分配

首先说明一下实践的应用环境

[图片上传失败...(image-6d2995-1574170005860)]

image

对应服务安装的主机如上表,通过实现web01和web02的负载均衡,进而判断两个tomcat示例是否实现了session共享。

四.nginx+tomcat+redis部署过程

1.redis安装部署

1)redis安装

redis安装比较简单,这里直接使用yum进行安装。

[root@db01 ~]#  yum -y install redis

2)配置redis并启动

#打开redis配置文件/etc/redis.conf,修改配置文件内容
[root@db01 ~]# vim /etc/redis.conf 
bind 127.0.0.1 172.16.1.51
#保存退出并启动redis
[root@db01 ~]# systemctl start redis
[root@db01 ~]# systemctl enable redis

2.tomcat安装部署

1.安装tomcat
部署tomcat之前,需要先安装jdk,这里选择jdk1.8版本,从orcal官网下载linux-64版本的JDK,下载时选择自己机器适合的版本运行即可,oracle官网提供的JDK都是二进制版本的,因此,JDK的安装非常简单,只需要下按在下来的程序包解压到相应的目路下即可。(这里是下载orecle官方的安装包然后后上传安装)

#方法一
[root@web01 ~]# yum -y localinstall jdk-8u102-linux-x64.rpm 
[root@web01 ~]# mkdir /app
[root@web01 ~]# tar xf apache-tomcat-8.0.27.tar.gz -C /app
#简化名称
[root@web01 /app]# mv apache-tomcat-8.0.27 tomcat
#启动tomcat
[root@web01 /app/tomcat]# /app/tomcat/bin/startup.sh
#方法二
[root@web01 ~]# mkdir /app/
[root@web01 ~]# tar xf jdk-8u60-linux-x64.tar.gz -C /app/
[root@web01 ~]# ln -s /app/jdk1.8.0_60 /app/jdk
[root@web01 ~]# sed -i.ori '$a export JAVA_HOME=/app/jdk\nexport PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH\nexport CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$JAVA_HOME/lib/tools.jar' /etc/profile
[root@web01 ~]# source /etc/profile
[root@web01 ~]# tar xf apache-tomcat-8.0.27.tar.gz -C /app
[root@web01 ~]# /app/apache-tomcat-8.0.27/bin/startup.sh 

3.tomcat与redis整合实现session共享

接下来就是配置tomcat和readis整合,实现session管理,需要如下两个步骤。

1)部署jar包

根据github上的说明,需要下载两个jar包,根据现有的环境,需要下载redisson-all-3.11.5.jar和redisson-tomcat-8-3.11.5.jar,这两个jar包都可以从https://github.com/redisson/redisson/tree/master/redisson-tomcat
下载。
将下载下来的jar包放到[图片上传失败...(image-629fc9-1574170005860)]TOMCAT_BASE是指tomcat的安装目录)目录下,这里的路径就是指/app/tomcat/lib。

2)增加RedissonSessionManager配置

此步骤就是在$TOMCAT_BASE/conf/context.xml中,添加如下配置

<Manager className="org.redisson.tomcat.RedissonSessionManager"
  configPath="${catalina.base}/conf/redisson.conf" 
  readMode="REDIS" updateMode="DEFAULT"/>
</Context>
其中,${catalina.base}/conf/redisson.conf文件内容如下:
[root@web01 /app/tomcat/conf]# cim redisson.conf
-bash: cim: command not found
[root@web01 /app/tomcat/conf]# vim redisson.conf
{
   "singleServerConfig":{
      "idleConnectionTimeout":10000,
      "connectTimeout":10000,
      "timeout":3000,
      "retryAttempts":3,
      "retryInterval":1500,
      "password":null,
      "subscriptionsPerConnection":5,
      "clientName":null,
      "address": "redis://172.16.1.51:6379",
      "subscriptionConnectionMinimumIdleSize":1,
      "subscriptionConnectionPoolSize":50,
      "connectionMinimumIdleSize":32,
      "connectionPoolSize":64,
      "database":0,
      "dnsMonitoringInterval":5000
   },
   "threads":0,
   "nettyThreads":0,
   "codec":{
      "class":"org.redisson.codec.FstCodec"
   },
   "transportMode":"NIO"
}

需要注意这里的"address"一项的值,如果tomcat和redis安装在一起,可以写成127.0.0.1:6379,如果redis在独立的一台服务器上,就写redis所在机器的ip地址。这里redis所在的主机的ip为172.16.1.51,所以就写上面的地址即可。到此tomcat与redis的互联配置完成。

4.测试获取session

在tomcat的$TOMCAT_BASE/webapps/ROOT目录下创建一个session.jsp内容如下:

[root@web01 /app/tomcat/webapps/ROOT]# vim session.jsp
<html>
<head>
<title>test1</title>
</head>
<body>
    SessionID is
    <%=session.getId()%>
    <BR> SessionIP is
    <%=request.getServerName()%>
    <BR> SessionPort is
    <%=request.getServerPort()%>
    <%
        out.println("Response from tomcat1");
    %>
</body>
</html>

接着,先关闭tomcat,之后再启动

[root@web01 /app/tomcat/bin]# ./shutdown.sh
[root@web01 /app/tomcat/bin]# ./startup.sh

启动tomcat后,在浏览器中访问:http://10.0.0.7:8080/session.jsp

[图片上传失败...(image-35cf8-1574170005860)]

image

然后登陆redis客户端进行查看

[root@db01 ~]# redis-cli
127.0.0.1:6379> keys *
1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55"
127.0.0.1:6379> 

5.部署第二台tomcat实例

第二台与第一台部署全部一样这里不在过多描述,为了区分,这里只需要将测试的文件session.jsp稍作修改,具体内容如下:

[root@web02 /app/tomcat/webapps/ROOT]# vim session.jsp 
<html>
<head>
<title>test2</title>
</head>
<body>
    SessionID is
    <%=session.getId()%>
    <BR> SessionIP is
    <%=request.getServerName()%>
    <BR> SessionPort is
    <%=request.getServerPort()%>
    <%
        out.println("Response from tomcat2");
    %>
</body>
</html>

修改完成后,先关闭tomcat,之后再启动,通过浏览器访问:http://10.0.0.8:8080/session.jsp

[图片上传失败...(image-27be84-1574170005860)]

image

然后登陆redis客户端进行查看

[root@db01 ~]# redis-cli
127.0.0.1:6379> keys *
1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55"
127.0.0.1:6379> keys *
1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55"
2) "redisson:tomcat_session:AAB9C0437D53573FB9C60565F345A63D"
127.0.0.1:6379> http://10.0.0.8:8080/session.jsp

说明:通过上图可以看到,两次访问得到session信息不一样,这是正常的现象。

6.部署nginx负载均衡

1.使用nginx官方源进行安装。

i.使用vi /etc/yum.repos.d/nginx.repo创建nginx.repo源文件。
按下i键,添加以下内容。

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

ii.按下Esc键,输入:wq并回车以保存并关闭文件。
iii.下载安装nginx。

[root@web01 ~]# yum -y install nginx

iv.启动nginx并设置开机自启动

[root@web01 ~]#systemctl start nginx
[root@web01 ~]#systemctl enable nginx
2.配置nginx负载均衡

打开nginx配置文件nginx.conf,重点配置如下内容:

[root@lb01 /etc/nginx]# vim nginx.conf 
upstream zrlog_pools {
  server 172.16.1.7:8080;
  server 172.16.1.8:8080;
 }
server {
    listen 80;
    server_name zrlog.oldboy.com;
    location / {
    proxy_pass http://zrlog_pools;
    include proxy_params;
   }
}
#保存退出,检查语法并检查语法
   [root@lb01 /etc/nginx]# nginx -t
   [root@lb01 /etc/nginx]# systemctl restart nginx                        

五.测试nginx+tomcat+redis的共享功能

首先在本地hosts配置域名解析,将zrlog.oldboy.com解析到lb01的公网ip:10.0.0.5。
之后在浏览器上测试访问:http://zrlog.oldboy.com/session.jsp
测试结果如下:

[图片上传失败...(image-a84d63-1574170005860)]

image

[图片上传失败...(image-749bd5-1574170005860)]

image

登录redis客户端查看结果如下:

[root@db01 ~]# redis-cli
127.0.0.1:6379> keys *
1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55"
127.0.0.1:6379> keys *
1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55"
2) "redisson:tomcat_session:AAB9C0437D53573FB9C60565F345A63D"
127.0.0.1:6379> keys *
1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55"
2) "redisson:tomcat_session:AAB9C0437D53573FB9C60565F345A63D"
3) "redisson:tomcat_session:84B3D1117D22661FAD32264A4DFD4C5B"
127.0.0.1:6379> 

</article>

0人点赞

Tomcat

作者:唯爱熊
链接:https://www.jianshu.com/p/d3df0d708f2e
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容