• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    redission-tomcat快速实现从单机部署到多机部署详解

    前言

    一些项目初期出于简单快速,都是做单机开发与部署,但是随着业务的扩展或对可用性要求的提高,单机环境已不满足需求。单机部署往多机部署切换,其中可能存在的一个重要环节就是session的共享(如果一开始就是基于token的认证则可忽略)。本文介绍一个基于redis的tomcat session管理开源项目:redission-tomcat,可无代码侵入式地快速实现session共享。

    简介

    redisson是与jedis类似的一个redis客户端,其功能比jedis要更丰富一些。redission-tomcat是一个基于redis的tomcat session管理器项目,项目地址。相比于其它实现,该项目的存储更为高效,写操作也更为优化。每一个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"/>

    其中

    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环境配置,其中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来实现单机部署到多机部署的所有配置。

    总结

    技术架构都是随着业务的发展而不断演进。在业务发展初期,用户量、业务复杂度都相对较低,为了实现快速上线验证,往往采用简单单一的架构。许多项目可能还没来得及进行架构演进升级就GG了,而有幸继续成长的项目必然会随着业务的扩张不断优化与升级。

    本文介绍的redisson-tomcat可帮助单机项目快速切换到多机支持,当然只是在session管理环节。如果涉及到其它如文件上传,定时任务等分布式支持,则要另做相应调整了。

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    上一篇:Linux CentOS 定时运行脚本配置的方法
    下一篇:一次因信号量引发的tomcat异常退出解决
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    redission-tomcat快速实现从单机部署到多机部署详解 redission-tomcat,快速,实现,