redission-tomcat如何實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署

小編給大家分享一下redission-tomcat如何實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

目前創(chuàng)新互聯(lián)公司已為上千多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計(jì)、長(zhǎng)壽網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

簡(jiǎn)介

redisson是與jedis類似的一個(gè)redis客戶端,其功能比jedis要更豐富一些。redission-tomcat是一個(gè)基于redis的tomcat session管理器項(xiàng)目,項(xiàng)目地址。相比于其它實(shí)現(xiàn),該項(xiàng)目的存儲(chǔ)更為高效,寫(xiě)操作也更為優(yōu)化。每一個(gè)session參數(shù)是在調(diào)用HttpSession.setAttribute時(shí)寫(xiě)入redis的,其它方案卻一般是每次都將整個(gè)session進(jìn)行序列化后寫(xiě)入。

使用

1.將redisson-all-3.11.0.jar,redisson-tomcat-8-3.11.0.jar(針對(duì)tomcat8,其它版本可在上述項(xiàng)目地址頁(yè)面找到下載鏈接)兩個(gè)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, 該模式會(huì)將session屬性同時(shí)保存到本地tomcat session與redis中,后續(xù)的session更新通過(guò)redis事件傳播到本地tomcat session;2. REDIS,只將session屬性保存到redis中。默認(rèn)為REDIS。

  • updateMode:session屬性的更新模式??扇≈?1. DEFAULT,session屬性只通過(guò)setAttribute方法保存到redis中;2. AFTER_REQUEST,在每次請(qǐng)求之后,將所有session屬性保存至redis。默認(rèn)為DEFAULT。

  • broadcastSessionEvents:如果設(shè)置為true,則sessionCreated與sessionDestroyed事件將會(huì)被廣播到所有tomcat實(shí)例,并使所有注冊(cè)的HttpSessionListeners監(jiān)聽(tīng)器被觸發(fā)。默認(rèn)為false。

3.在tomcat conf目錄下新增配置文件redisson.conf,內(nèi)容如下

{
"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"
}

以上為單機(jī)模式redis環(huán)境配置,其中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來(lái)實(shí)現(xiàn)負(fù)載均衡,參考配置

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/;
}
}

以上是“redission-tomcat如何實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)頁(yè)名稱:redission-tomcat如何實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署
文章來(lái)源:http://muchs.cn/article26/iiddjg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、網(wǎng)站策劃、全網(wǎng)營(yíng)銷(xiāo)推廣、外貿(mào)網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站、關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁(yè)設(shè)計(jì)公司