zoukankan      html  css  js  c++  java
  • redission-tomcat:快速实现从单机部署到多机部署

    原文地址: http://blog.jboost.cn/session-redis.html

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

    1. 简介

    redisson是与jedis类似的一个redis客户端,其功能比jedis要更丰富一些。redission-tomcat是一个基于redis的tomcat session管理器项目,项目地址:https://github.com/redisson/redisson/tree/master/redisson-tomcat 。相比于其它实现,该项目的存储更为高效,写操作也更为优化。每一个session参数是在调用HttpSession.setAttribute时写入redis的,其它方案却一般是每次都将整个session进行序列化后写入。

    2. 使用

    1. redisson-all-3.11.0.jarredisson-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中,后续的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监听器被触发。默认为false。
    1. 在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"
      }
    2. 我们可以使用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来实现单机部署到多机部署的所有配置。

    3. 总结

    技术架构都是随着业务的发展而不断演进。在业务发展初期,用户量、业务复杂度都相对较低,为了实现快速上线验证,往往采用简单单一的架构。许多项目可能还没来得及进行架构演进升级就GG了,而有幸继续成长的项目必然会随着业务的扩张不断优化与升级。本文介绍的redisson-tomcat可帮助单机项目快速切换到多机支持,当然只是在session管理环节。如果涉及到其它如文件上传,定时任务等分布式支持,则要另做相应调整了。



    我的个人博客地址:http://blog.jboost.cn
    我的github地址:https://github.com/ronwxy
    我的微信公众号:jboost-ksxy (一个不只有实战干货的技术公众号, 欢迎关注)
    ———————————————————————————————————————————————————————————————
    微信公众号

  • 相关阅读:
    Jdk1.7 与 jdk1.8的区别,最新的特征有哪些(美团,360,京东面试题目)
    Android利用zxing生成二维码
    Android 事件传递机制
    Android 如何让EditText不自动获取焦点&隐藏软键盘
    Android--控件的滑动事件
    解决Android3.0之后不能在主线程中进行HTTP请求
    JavaIO 思维导图
    MySQL的注释方法
    MySQL——约束(constraint)详解
    自动回复之实现随机回复与常用Mapper XML标签
  • 原文地址:https://www.cnblogs.com/spec-dog/p/11105943.html
Copyright © 2011-2022 走看看