欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redission-tomcat快速實現從單機部署到多機部署詳解

 更新時間:2019年06月29日 14:56:01   作者:空山新雨  
這篇文章主要介紹了redission-tomcat快速實現從單機部署到多機部署詳解,本文介紹一個基于redis的tomcat session管理開源項目:redission-tomcat,可無代碼侵入式地快速實現session共享,需要的朋友可以參考下

前言

一些項目初期出于簡單快速,都是做單機開發(fā)與部署,但是隨著業(yè)務的擴展或對可用性要求的提高,單機環(huán)境已不滿足需求。單機部署往多機部署切換,其中可能存在的一個重要環(huán)節(jié)就是session的共享(如果一開始就是基于token的認證則可忽略)。本文介紹一個基于redis的tomcat session管理開源項目:redission-tomcat,可無代碼侵入式地快速實現session共享。

簡介

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

使用

1.將redisson-all-3.11.0.jar,redisson-tomcat-8-3.11.0.jar(針對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中,后續(xù)的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監(jiān)聽器被觸發(fā)。默認為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環(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來實現負載均衡,參考配置

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來實現單機部署到多機部署的所有配置。

總結

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • tomcat虛擬主機_動力節(jié)點Java學院整理

    tomcat虛擬主機_動力節(jié)點Java學院整理

    對于Tomcat服務器,可以放置多個網站(多個web應用),這就是講配置多個虛擬主機,可以看成好像有多個主機,而每個主機上有一個web應用
    2017-07-07
  • 在IDEA 2020.3.1中部署Tomcat并且創(chuàng)建第一個web項目的過程詳解

    在IDEA 2020.3.1中部署Tomcat并且創(chuàng)建第一個web項目的過程詳解

    這篇文章主要介紹了在IDEA 2020.3.1中部署Tomcat并且創(chuàng)建第一個web項目,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • tomcat如何更改默認ROOT目錄

    tomcat如何更改默認ROOT目錄

    這篇文章主要介紹了tomcat如何更改默認ROOT目錄問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Tomcat中GET和POST請求時亂碼問題及解決

    Tomcat中GET和POST請求時亂碼問題及解決

    這篇文章主要介紹了Tomcat中GET和POST請求時亂碼問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Tomcat部署項目局域網使用IP地址實現直接訪問

    Tomcat部署項目局域網使用IP地址實現直接訪問

    這篇文章主要介紹了Tomcat部署項目局域網使用IP地址實現直接訪問,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 一次tomcat自動關閉的bug解決

    一次tomcat自動關閉的bug解決

    這篇文章主要給大家介紹了一次關于tomcat自動關閉的bug的解決過程,文中通過示例代碼介紹的非常詳細,對大家學習或者使用tomcat具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • Tomcat 類加載器的實現方法及實例代碼

    Tomcat 類加載器的實現方法及實例代碼

    這篇文章主要介紹了Tomcat 類加載器的實現方法及實例代碼,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-05-05
  • 快速解決Tomcat重新配置后啟動慢的問題

    快速解決Tomcat重新配置后啟動慢的問題

    這篇文章主要介紹了解決Tomcat重新配置后啟動慢的問題,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • Tomcat 請求資源[/XXX/]不可用問題的解決方法

    Tomcat 請求資源[/XXX/]不可用問題的解決方法

    Tomcat 請求的資源[/XXX/]不可用問題,通過正確路徑訪問(運行代碼時候自動打開瀏覽器訪問的路徑),和錯誤路徑訪問,它的表現是不一樣的,本文就來介紹一下解決方法
    2023-11-11
  • Apache及Tomcat搭建集群環(huán)境過程解析

    Apache及Tomcat搭建集群環(huán)境過程解析

    這篇文章主要介紹了Apache及Tomcat搭建集群環(huán)境過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10

最新評論