一.常见的session共享方案
1.使用nginx的ip_hash
使用ip绑定ip_hash算法时,用户的请求都会绑在同一个节点服务器上,这样的设置会导致一台或多台服务器过载无法提供服务,而后端正常的服务器无法提供服务,当绑定的服务器挂了,用户只能重启浏览器后才能重新访问,这样用户体验度极差,除了特殊需要,不建议使用这种机制实现session共享。
2.基于服务端的session共享
1)服务端的session复制
session复制是指session信息会在集群节点之间复制,每个节点服务器上都会有session信息。
优点:即使一个节点服务器挂了,只要还有服务器可以提供服务,就不会影响用户使用。
缺点:服务器之间通信频繁,效能感应速度有影响,多并发、高频率操作的情况下性能下降比较明显。
这里提供一个实现方法的链接地址:https://www.cnblogs.com/ouyida3/p/9425027.html
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
三.场景规划与地址分配
首先说明一下实践的应用环境
对应服务安装的主机如上表,通过实现web01和web02的负载均衡,进而判断两个tomcat示例是否实现了session共享。
四.nginx+tomcat+redis部署过程
redis安装部署
1)redis安装
redis安装比较简单,这里直接使用yum进行安装。
[root@db01 ~]# yum -y install redis
)配置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
安装部署
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 #简化名称 [root@web01 /app/tomcat]# /app/tomcat/bin/startup.sh #启动tomcat
#方法二
tar xf jdk-8u60-linux-x64.tar.gz -C /app/ ln -s /app/jdk1.8.0_60 /app/jdk cat >>/etc/profile<<'EOF' export JAVA_HOME=/app/jdk export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH export CLASSPATH=.$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$JAVA_HOME/lib/tools.jar EOF source /etc/profile mkdir /app/ tar xf apache-tomcat-8.0.27.tar.gz -C /app /app/apache-tomcat-8.0.27/bin/startup.sh
与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包放到$TOMCAT_BASE/lib($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"/>
${catalina.base}/conf/创建redisson.conf文件,文件内容如下:
[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
http://10.0.0.7:8080/session.jsp
tomcat后,在浏览器中访问:然后登陆redis客户端进行查看
[root@db01 ~]# redis-cli 127.0.0.1:6379> keys * 1) "redisson:tomcat_session:CEA8347FDF151A82ED8B08A59120ED55" 127.0.0.1:6379>
部署第二台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
然后登陆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官方源进行安装。
使用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
按下Esc键,输入:wq并回车以保存并关闭文件。
下载安装nginx。
[root@web01 ~]# yum -y install nginx
启动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
测试结果如下:
登录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>
至此验证结果都已经实现,如果版本不同,请注意下载对应的版本的jar包。
赞赏微信赞赏
支付宝赞赏