Rainbond最佳实践:Tomcat配置Redis实现Session共享
Rainbond是國內(nèi)首個(gè)開源的生產(chǎn)級(jí)無服務(wù)器PaaS,深度整合基于Kubernetes的容器管理、多類型CI/CD應(yīng)用構(gòu)建與交付、多數(shù)據(jù)中心的資源管理等技術(shù),提供云原生應(yīng)用全生命周期解決方案,構(gòu)建應(yīng)用與基礎(chǔ)設(shè)施、應(yīng)用之間及基礎(chǔ)設(shè)施之間的互聯(lián)互通生態(tài)體系。
點(diǎn)擊安裝
為了使您的應(yīng)用承受更多的并發(fā),提高應(yīng)用穩(wěn)定性,您需要在適當(dāng)情況下進(jìn)行擴(kuò)容。每個(gè)節(jié)點(diǎn)下的Tomcat只存儲(chǔ)來訪問自己的請(qǐng)求時(shí)產(chǎn)生的session,為了解決擴(kuò)容后session持久化的問題,我們提供 Java的War包項(xiàng)目使用Tomcat配置Redis實(shí)現(xiàn)Session共享 解決方案,將您session儲(chǔ)存在redis中來保證您應(yīng)用程序穩(wěn)定性。如圖所示:
若 Load Balancing 將請(qǐng)求發(fā)送給 container 1 下的 tomcat A ,同時(shí)產(chǎn)生 session ,將此 session 持久化到Redis 中。當(dāng) Web Server 再次發(fā)送請(qǐng)求,若請(qǐng)求到 container 2的 tomcat A ,此時(shí)會(huì)在Redis 中找到已存在的 session,即取即用。
通過源碼構(gòu)建,您可以通過如下兩種方式實(shí)現(xiàn) 配置redis實(shí)現(xiàn)session共享:
使用Webapp-Runner或Jetty-Runner
云幫使用 [webapp-Runner]() 內(nèi)嵌的 tomcat 或 [jetty-Runner]() 內(nèi)嵌的 jetty 實(shí)現(xiàn)服務(wù)器功能。在您不創(chuàng)建其他服務(wù)器情況下即可輕松將應(yīng)用部署在云幫。通過以下步驟可實(shí)現(xiàn) 配置redis實(shí)現(xiàn)session共享。
-
應(yīng)用端口8080,平臺(tái)默認(rèn)開啟應(yīng)用5000端口,為了端口映射正常:
- 在Procfile中指定端口--port 5000
- 在應(yīng)用控制臺(tái)-端口設(shè)置8080端口
- 指定session存儲(chǔ)--session-store redis
為方便創(chuàng)建應(yīng)用時(shí)依賴,建議提前通過應(yīng)用市場(chǎng)創(chuàng)建 Redis 應(yīng)用;若您未在創(chuàng)建時(shí)依賴Redis應(yīng)用,也可以在應(yīng)用創(chuàng)建完成后在 應(yīng)用控制臺(tái)-依賴進(jìn)行Redis應(yīng)用關(guān)聯(lián)。關(guān)聯(lián)后記得重啟應(yīng)用哦。
使用docker鏡像
云幫提供使用定制 tomcat 容器來啟動(dòng)應(yīng)用的方法。通過以下步驟可實(shí)現(xiàn) 配置redis實(shí)現(xiàn)session共享。
創(chuàng)建Dockerfile,寫入如下內(nèi)容:
- 使用源碼
- 使用war包
總結(jié)
以上是生活随笔為你收集整理的Rainbond最佳实践:Tomcat配置Redis实现Session共享的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 分布式架构 springcloud+re
- 下一篇: 超高性能管线式HTTP请求(实践·原理·