欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

redission-tomcat快速实现从单机部署到多机部署详解

程序员文章站 2022-03-18 14:42:44
前言 一些项目初期出于简单快速,都是做单机开发与部署,但是随着业务的扩展或对可用性要求的提高,单机环境已不满足需求。单机部署往多机部署切换,其中可能存在的一个重要环节就是...

前言

一些项目初期出于简单快速,都是做单机开发与部署,但是随着业务的扩展或对可用性要求的提高,单机环境已不满足需求。单机部署往多机部署切换,其中可能存在的一个重要环节就是session的共享(如果一开始就是基于token的认证则可忽略)。本文介绍一个基于redis的tomcat session管理开源项目:redission-tomcat,可无代码侵入式地快速实现session共享。

简介

redisson是与jedis类似的一个redis客户端,其功能比jedis要更丰富一些。redission-tomcat是一个基于redis的tomcat session管理器项目,。相比于其它实现,该项目的存储更为高效,写操作也更为优化。每一个session参数是在调用httpsession.setattribute时写入redis的,其它方案却一般是每次都将整个session进行序列化后写入。

使用

1.将,(针对tomcat8,其它版本可在上述项目地址页面找到下载链接)两个jar包下载放到tomcat的lib目录下。

2.在tomcat conf目录下的context.xml文件中添加如下配置

<manager classname="org.redisson.tomcat.redissonsessionmanager"
configpath="${catalina.base}/conf/redisson.conf" 
readmode="memory" updatemode="after_request" broadcastsessionevents="false"/>

其中

  • configpath:指向redisson的json或yaml格式的配置文件,第3步中给出。
  • readmode:session属性的读取模式。可取值 1. memory, 该模式会将session属性同时保存到本地tomcat session与redis中,后续的session更新通过redis事件传播到本地tomcat session;2. redis,只将session属性保存到redis中。默认为redis。
  • updatemode:session属性的更新模式。可取值 1. default,session属性只通过setattribute方法保存到redis中;2. after_request,在每次请求之后,将所有session属性保存至redis。默认为default。
  • broadcastsessionevents:如果设置为true,则sessioncreated与sessiondestroyed事件将会被广播到所有tomcat实例,并使所有注册的httpsessionlisteners监听器被触发。默认为false。

3.在tomcat conf目录下新增配置文件redisson.conf,内容如下

{
"singleserverconfig":{
"idleconnectiontimeout":10000,
"connecttimeout":10000,
"timeout":3000,
"retryattempts":3,
"retryinterval":1500,
"password":"123456",
"subscriptionsperconnection":5,
"clientname":null,
"address": "redis://127.0.0.1:6379",
"subscriptionconnectionminimumidlesize":1,
"subscriptionconnectionpoolsize":50,
"connectionminimumidlesize":24,
"connectionpoolsize":64,
"database":0,
"dnsmonitoringinterval":5000
},
"threads":16,
"nettythreads":32,
"codec":{
"class":"org.redisson.codec.fstcodec"
},
"transportmode":"nio"
}

以上为单机模式redis环境配置,其中password,address修改为自己的值。如果是集群模式,则配置文件为

{
"sentinelserversconfig":{
"idleconnectiontimeout":10000,
"connecttimeout":10000,
"timeout":3000,
"retryattempts":3,
"retryinterval":1500,
"failedslavereconnectioninterval":3000,
"failedslavecheckinterval":60000,
"password":null,
"subscriptionsperconnection":5,
"clientname":null,
"loadbalancer":{
"class":"org.redisson.connection.balancer.roundrobinloadbalancer"
},
"subscriptionconnectionminimumidlesize":1,
"subscriptionconnectionpoolsize":50,
"slaveconnectionminimumidlesize":24,
"slaveconnectionpoolsize":64,
"masterconnectionminimumidlesize":24,
"masterconnectionpoolsize":64,
"readmode":"slave",
"subscriptionmode":"slave",
"sentineladdresses":[
"redis://127.0.0.1:26379",
"redis://127.0.0.1:26389"
],
"mastername":"mymaster",
"database":0
},
"threads":16,
"nettythreads":32,
"codec":{
"class":"org.redisson.codec.fstcodec"
},
"transportmode":"nio"
}

我们可以使用nginx来实现负载均衡,参考配置

upstream cnserver{
server 127.0.0.1:8080 weight=2 fail_timeout=10s max_fails=1;
server 127.0.0.1:8081 weight=2 fail_timeout=10s max_fails=1;
}
server {
listen 80;
server_name localhost;
index index.html index.htm;
location /rest/ {
index index.html;
proxy_pass http://cnserver/rest/;
}
}

以上即为使用redisson-tomcat来实现单机部署到多机部署的所有配置。

总结

技术架构都是随着业务的发展而不断演进。在业务发展初期,用户量、业务复杂度都相对较低,为了实现快速上线验证,往往采用简单单一的架构。许多项目可能还没来得及进行架构演进升级就gg了,而有幸继续成长的项目必然会随着业务的扩张不断优化与升级。

本文介绍的redisson-tomcat可帮助单机项目快速切换到多机支持,当然只是在session管理环节。如果涉及到其它如文件上传,定时任务等分布式支持,则要另做相应调整了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。