新聞中心
小編給大家分享一下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ǔ)更為高效,寫操作也更為優(yōu)化。每一個(gè)session參數(shù)是在調(diào)用HttpSession.setAttribute時(shí)寫入redis的,其它方案卻一般是每次都將整個(gè)session進(jìn)行序列化后寫入。
使用
1.將redisson-all-3.11.0.jar,redisson-tomcat-8-3.11.0.jar(針對(duì)tomcat8,其它版本可在上述項(xiàng)目地址頁面找到下載鏈接)兩個(gè)jar包下載放到tomcat的lib目錄下。
2.在tomcat conf目錄下的context.xml文件中添加如下配置
其中
configPath:指向Redisson的json或yaml格式的配置文件,第3步中給出。
readMode:session屬性的讀取模式??扇≈?1. MEMORY, 該模式會(huì)將session屬性同時(shí)保存到本地tomcat session與redis中,后續(xù)的session更新通過redis事件傳播到本地tomcat session;2. REDIS,只將session屬性保存到redis中。默認(rèn)為REDIS。
updateMode:session屬性的更新模式。可取值 1. DEFAULT,session屬性只通過setAttribute方法保存到redis中;2. AFTER_REQUEST,在每次請(qǐng)求之后,將所有session屬性保存至redis。默認(rèn)為DEFAULT。
broadcastSessionEvents:如果設(shè)置為true,則sessionCreated與sessionDestroyed事件將會(huì)被廣播到所有tomcat實(shí)例,并使所有注冊(cè)的HttpSessionListeners監(jiān)聽器被觸發(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來實(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è)資訊頻道!
本文題目:redission-tomcat如何實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署
標(biāo)題鏈接:http://fisionsoft.com.cn/article/iiddjg.html