濮阳杆衣贸易有限公司

主頁 > 知識庫 > redission-tomcat快速實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署詳解

redission-tomcat快速實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署詳解

熱門標(biāo)簽:智能電話機(jī)器人線路 金融行業(yè)外呼線路 江蘇電銷外呼防封系統(tǒng)是什么 高德地圖標(biāo)注無營業(yè)執(zhí)照 廣州電銷機(jī)器人系統(tǒng)圖 長沙開福怎么申請400電話 賀州市地圖標(biāo)注app 東莞人工智能電銷機(jī)器人供應(yīng)商 百度地圖標(biāo)注要不要錢

前言

一些項(xiàng)目初期出于簡單快速,都是做單機(jī)開發(fā)與部署,但是隨著業(yè)務(wù)的擴(kuò)展或?qū)捎眯砸蟮奶岣撸瑔螜C(jī)環(huán)境已不滿足需求。單機(jī)部署往多機(jī)部署切換,其中可能存在的一個(gè)重要環(huán)節(jié)就是session的共享(如果一開始就是基于token的認(rèn)證則可忽略)。本文介紹一個(gè)基于redis的tomcat session管理開源項(xiàng)目:redission-tomcat,可無代碼侵入式地快速實(shí)現(xiàn)session共享。

簡介

redisson是與jedis類似的一個(gè)redis客戶端,其功能比jedis要更豐富一些。redission-tomcat是一個(gè)基于redis的tomcat session管理器項(xiàng)目,項(xiàng)目地址。相比于其它實(shí)現(xiàn),該項(xiàng)目的存儲更為高效,寫操作也更為優(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(針對tomcat8,其它版本可在上述項(xiàng)目地址頁面找到下載鏈接)兩個(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, 該模式會將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,在每次請求之后,將所有session屬性保存至redis。默認(rèn)為DEFAULT。
  • broadcastSessionEvents:如果設(shè)置為true,則sessionCreated與sessionDestroyed事件將會被廣播到所有tomcat實(shí)例,并使所有注冊的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/;
}
}

以上即為使用redisson-tomcat來實(shí)現(xiàn)單機(jī)部署到多機(jī)部署的所有配置。

總結(jié)

技術(shù)架構(gòu)都是隨著業(yè)務(wù)的發(fā)展而不斷演進(jìn)。在業(yè)務(wù)發(fā)展初期,用戶量、業(yè)務(wù)復(fù)雜度都相對較低,為了實(shí)現(xiàn)快速上線驗(yàn)證,往往采用簡單單一的架構(gòu)。許多項(xiàng)目可能還沒來得及進(jìn)行架構(gòu)演進(jìn)升級就GG了,而有幸繼續(xù)成長的項(xiàng)目必然會隨著業(yè)務(wù)的擴(kuò)張不斷優(yōu)化與升級。

本文介紹的redisson-tomcat可幫助單機(jī)項(xiàng)目快速切換到多機(jī)支持,當(dāng)然只是在session管理環(huán)節(jié)。如果涉及到其它如文件上傳,定時(shí)任務(wù)等分布式支持,則要另做相應(yīng)調(diào)整了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:北京 滄州 松原 玉樹 張家界 洛陽 永州 廊坊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《redission-tomcat快速實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署詳解》,本文關(guān)鍵詞  redission-tomcat,快速,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《redission-tomcat快速實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于redission-tomcat快速實(shí)現(xiàn)從單機(jī)部署到多機(jī)部署詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宜章县| 阜南县| 上犹县| 什邡市| 上虞市| 汕头市| 大宁县| 娄烦县| 紫云| 龙川县| 兴城市| 定日县| 西藏| 余江县| 宁明县| 门源| 柏乡县| 抚州市| 独山县| 华坪县| 清新县| 白河县| 嘉兴市| 开平市| 车致| 安康市| 应用必备| 松溪县| 泌阳县| 大关县| 蓬溪县| 安图县| 锡林浩特市| 南城县| 乌拉特后旗| 南投县| 德清县| 峨眉山市| 台南市| 化隆| 亚东县|