redission-tomcat快速實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署詳解
前言
一些項(xiàng)目初期出于簡(jiǎn)單快速,都是做單機(jī)開(kāi)發(fā)與部署,但是隨著業(yè)務(wù)的擴(kuò)展或?qū)捎眯砸蟮奶岣撸瑔螜C(jī)環(huán)境已不滿(mǎn)足需求。單機(jī)部署往多機(jī)部署切換,其中可能存在的一個(gè)重要環(huán)節(jié)就是session的共享(如果一開(kāi)始就是基于token的認(rèn)證則可忽略)。本文介紹一個(gè)基于redis的tomcat session管理開(kāi)源項(xiàng)目:redission-tomcat,可無(wú)代碼侵入式地快速實(shí)現(xiàn)session共享。
簡(jiǎn)介
redisson是與jedis類(lèi)似的一個(gè)redis客戶(hù)端,其功能比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/; } }
以上即為使用redisson-tomcat來(lái)實(shí)現(xiàn)單機(jī)部署到多機(jī)部署的所有配置。
總結(jié)
技術(shù)架構(gòu)都是隨著業(yè)務(wù)的發(fā)展而不斷演進(jìn)。在業(yè)務(wù)發(fā)展初期,用戶(hù)量、業(yè)務(wù)復(fù)雜度都相對(duì)較低,為了實(shí)現(xiàn)快速上線驗(yàn)證,往往采用簡(jiǎn)單單一的架構(gòu)。許多項(xiàng)目可能還沒(méi)來(lái)得及進(jìn)行架構(gòu)演進(jìn)升級(jí)就GG了,而有幸繼續(xù)成長(zhǎng)的項(xiàng)目必然會(huì)隨著業(yè)務(wù)的擴(kuò)張不斷優(yōu)化與升級(jí)。
本文介紹的redisson-tomcat可幫助單機(jī)項(xiàng)目快速切換到多機(jī)支持,當(dāng)然只是在session管理環(huán)節(jié)。如果涉及到其它如文件上傳,定時(shí)任務(wù)等分布式支持,則要另做相應(yīng)調(diào)整了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
tomcat虛擬主機(jī)_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
對(duì)于Tomcat服務(wù)器,可以放置多個(gè)網(wǎng)站(多個(gè)web應(yīng)用),這就是講配置多個(gè)虛擬主機(jī),可以看成好像有多個(gè)主機(jī),而每個(gè)主機(jī)上有一個(gè)web應(yīng)用2017-07-07在IDEA 2020.3.1中部署Tomcat并且創(chuàng)建第一個(gè)web項(xiàng)目的過(guò)程詳解
這篇文章主要介紹了在IDEA 2020.3.1中部署Tomcat并且創(chuàng)建第一個(gè)web項(xiàng)目,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02Tomcat中GET和POST請(qǐng)求時(shí)亂碼問(wèn)題及解決
這篇文章主要介紹了Tomcat中GET和POST請(qǐng)求時(shí)亂碼問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06Tomcat部署項(xiàng)目局域網(wǎng)使用IP地址實(shí)現(xiàn)直接訪問(wèn)
這篇文章主要介紹了Tomcat部署項(xiàng)目局域網(wǎng)使用IP地址實(shí)現(xiàn)直接訪問(wèn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06一次tomcat自動(dòng)關(guān)閉的bug解決
這篇文章主要給大家介紹了一次關(guān)于tomcat自動(dòng)關(guān)閉的bug的解決過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用tomcat具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Tomcat 類(lèi)加載器的實(shí)現(xiàn)方法及實(shí)例代碼
這篇文章主要介紹了Tomcat 類(lèi)加載器的實(shí)現(xiàn)方法及實(shí)例代碼,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-05-05快速解決Tomcat重新配置后啟動(dòng)慢的問(wèn)題
這篇文章主要介紹了解決Tomcat重新配置后啟動(dòng)慢的問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02Tomcat 請(qǐng)求資源[/XXX/]不可用問(wèn)題的解決方法
Tomcat 請(qǐng)求的資源[/XXX/]不可用問(wèn)題,通過(guò)正確路徑訪問(wèn)(運(yùn)行代碼時(shí)候自動(dòng)打開(kāi)瀏覽器訪問(wèn)的路徑),和錯(cuò)誤路徑訪問(wèn),它的表現(xiàn)是不一樣的,本文就來(lái)介紹一下解決方法2023-11-11Apache及Tomcat搭建集群環(huán)境過(guò)程解析
這篇文章主要介紹了Apache及Tomcat搭建集群環(huán)境過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10