文档章节

分布式Session共享:tomcat+redis实现session共享

问题达人
 问题达人
发布于 2016/03/29 09:37
字数 998
阅读 198
收藏 0

一、前言

本文主要测试redis实现session共享的实现方式,不讨论如何让nginx参与实现负载均衡等。

二、环境配置

本测试在Window下进行

name                version                port

Tomcat1        7.0.61                    127.0.0.1:8081

Tomcat1        7.0.61                    127.0.0.1:8082

Redis            2.4.5                    127.0.0.1:6379

jdk                1.7                        -


三、安装tomcat-redis-session-manager插件

1.源码下载:

https://github.com/jcoleman/tomcat-redis-session-manager

最新版源码对jdk版本有要求,必须是JDk1.7,否则编译通不过。

之前我用的是Tomcat7与JDK1.6的组合,结果一直运行不了,抛出如下异常。

java.lang.UnsupportedClassVersionError: com/orangefunction/tomcat/redissessions/RedisSessionHandlerValve : Unsupported major.minor version 51.0
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)

如果你想要兼容版本较低的Tomcat或者jdk,可以尝试下载其他分支源码,其他分支我没有进行测试,不知道兼容情况如何。

2.或者Jar包下载:

https://github.com/jcoleman/tomcat-redis-session-manager/downloads

很多人都说Jar包有Bug,并不能真正的运行。我特意试了一下,确实不行,而且Jar包中的代码目录结构都与源码不一致,可能是包的版本太过老旧了,所以我还是尝试用源码重新编译生成Jar包。

3.重新编译:

源码构建基于 gradle,所以先要搭建gradle 环境,搭建很简单。

3.1 下载Gradle,直接下载Complete distribution版就可以。

3.2 下载后解压,并且设置环境变量。

GRADLE_HOME:E:\java\gradle-2.12-all\gradle-2.12(解压目录)

PATH:%GRADLE_HOME%\bin

3.3 cmd命令提示符中:输入gradle -v测试安装成功与否

输出表明安装成功。

C:\Users\Administrator>gradle -v

------------------------------------------------------------
Gradle 2.12
------------------------------------------------------------

Build time:   2016-03-14 08:32:03 UTC
Build number: none
Revision:     b29fbb64ad6b068cb3f05f7e40dc670472129bc0

Groovy:       2.4.4
Ant: Apache Ant(TM) version 1.9.3 compiled on December 23 2013
JVM: 1.7.0_79 (Oracle Corporation 24.79-b02)
OS: Windows 7 6.1 amd64

3.4 修改源码的build.gradle文件

由于作者使用了第三方仓库(sonatype),需要注册帐号,太麻烦,注释后直接使用maven中央仓库,同时注释签名相关脚本并增加依赖包的输出脚本 copyJars(dist目录),修改后的build.gradle 文件如下(红色字体为修改处):

apply plugin: 'java'
apply plugin: 'maven'
apply plugin: 'signing'

group = 'com.orangefunction'
version = '2.0.0'

repositories {
mavenLocal
mavenCentral
}

compileJava {

// java版本
sourceCompatibility = 1.7
targetCompatibility = 1.7
}

dependencies {

// 此处tomcat版本修改为自己使用的实际版本号
compile group: 'org.apache.tomcat', name: 'tomcat-catalina', version: '7.0.61' compile group: 'redis.clients', name: 'jedis', version: '2.5.2' compile group: 'org.apache.commons', name: 'commons-pool2', version: '2.2' //compile group: 'commons-codec', name: 'commons-codec', version: '1.9' testCompile group: 'junit', name: 'junit', version: '4.+' testCompile 'org.hamcrest:hamcrest-core:1.3' testCompile 'org.hamcrest:hamcrest-library:1.3' testCompile 'org.mockito:mockito-all:1.9.5' testCompile group: 'org.apache.tomcat', name: 'tomcat-coyote', version: '7.0.61' } task javadocJar(type: Jar, dependsOn: javadoc) { classifier = 'javadoc' from 'build/docs/javadoc' } task sourcesJar(type: Jar) { from sourceSets.main.allSource classifier = 'sources' } artifacts { archives jar archives javadocJar archives sourcesJar } //signing { // sign configurations.archives //} // 新增这段配置 task copyJars(type: Copy) { from configurations.runtime into 'dist' } uploadArchives { repositories { mavenDeployer { beforeDeployment { MavenDeployment deployment -> signing.signPom(deployment) } // repository(url: "https://oss.sonatype.org/service/local/staging/deploy/maven2/") { // authentication(userName: sonatypeUsername, password: sonatypePassword) // } //repository(url: "https://oss.sonatype.org/content/repositories/snapshots") { // authentication(userName: sonatypeUsername, password: sonatypePassword) //} pom.project { name 'tomcat-redis-session-manager' packaging 'jar' description 'Tomcat Redis Session Manager is a Tomcat extension to store sessions in Redis' url 'https://github.com/jcoleman/tomcat-redis-session-manager' issueManagement { url 'https://github.com:jcoleman/tomcat-redis-session-manager/issues' system 'GitHub Issues' } scm { url 'https://github.com:jcoleman/tomcat-redis-session-manager' connection 'scm:git:git://github.com/jcoleman/tomcat-redis-session-manager.git' developerConnection 'scm:git:git@github.com:jcoleman/tomcat-redis-session-manager.git' } licenses { license { name 'MIT' url 'http://opensource.org/licenses/MIT' distribution 'repo' } } developers { developer { id 'jcoleman' name 'James Coleman' email 'jtc331@gmail.com' url 'https://github.com/jcoleman' } } } } } }

修改完成后,cmd进入源码根目录,执行构建命令重新构建项目

gradle build -x test copyJars

分布式Session共享:tomcat+redis实现session共享

在源码根目录dist下查看输出jar包,另附下载地址:tomcat-redis-session-manager的相关Jar包

分布式Session共享:tomcat+redis实现session共享

4 导入jar包并修改context.xml

把以上生成的jar放入tomcat的lib目录下,有重复的包直接删除。

打开Context.xml,添加

<Valve
        className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
    <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
        host="localhost" port="6379" database="0" maxInactiveInterval="60" />

如果有多个tomcat,重复以上设置

四、测试结果

依次启动Redis、tomcat1、tomcat2

在浏览器中分别打开:

http://localhost:8081/examples/servlets/servlet/SessionExample

Session ID: 9E5BA1DB4BF56A025A66AF567057EBCB

http://localhost:8082/examples/servlets/servlet/SessionExample

Session ID: 9E5BA1DB4BF56A025A66AF567057EBCB

使用 redis-cli 连接 redis 服务器,输入Keys * 查看

分布式Session共享:tomcat+redis实现session共享

可以看到,三处SessionID都是一致的。

本文转载自:http://my.oschina.net/hnqingping1255/blog/647593

问题达人
粉丝 14
博文 94
码字总数 87450
作品 0
昌平
程序员
私信 提问
分布式Session共享:tomcat+redis实现session共享

一、序言 本文主要测试redis实现session共享的实现方式,不讨论如何让nginx参与实现负载均衡等。 二、环境配置 本测试在Window下进行 name version port Tomcat1 7.0.61 127.0.0.1:8081 Tomc...

-wangming-
2016/03/26
258
0
tomcat+redis实现session

1、网上查找资料,大部分从下面网址下载java代码,因是几年前实现的(大概2,3年前吧),不支持tomcat8 https://github.com/jcoleman/tomcat-redis-session-manager 2、在myeclipse 新建一个m...

小小子之家
2018/06/26
0
0
Spring Session Redis 在不同服务间共享 Session 时的类共享方案

Spring Session Redis 是不安全的 当在多服务之间使用 Spring Session Redis 进行 Session 共享要非常小心,因为它很不安全,很有可能导致整个服务实例不可用,无法处理任何请求。其中比较危...

OSC首席骠妓大将军
09/02
247
0
使用Tomcat+Redis来实现集群部署中的Session共享问题

一、工作中因为要使用到Tomcat集群部署,此时就涉及到了Session共享问题,主要有三种解决方案: 1、使用数据库来存储Session 2、使用Cookie来存储Session 3、使用Redis来存储Sesssion 二、本...

kolbe
2016/02/21
8.5K
11
分布式学习(4) ---- Spring Session + Redis实现分布式Session共享

单个服务器的应用,Tomcat会将Session保存在本机内存中,但一旦涉及到分布式应用,如何实现不同服务器间的Session共享问题呢? 目前比较主流的方式还是基于分布式缓存Memcached、redis实现,...

KKys
2017/02/07
0
0

没有更多内容

加载失败,请刷新页面

加载更多

kibana汉化

kibana5 / 6 需要下载补丁包,https://github.com/anbai-inc/Kibana_Hanization 其中 v6 版本原生支持国际化,只需要添加资源文件并且配置即可 kibana7 v7版本官方内置汉化资源,在配置文件 ...

细肉云吞
10分钟前
2
0
spring boot 自定义日志 log4j2

使用默认的日志在实际开发中会存在很多问题,比如备份文件名称无法自动重命名、各个等级的日志被放在一个文件中等,所以实际开发中为了更好满足我们的需求,我们一般都会自定义采用配置的方式...

雷开你的门
14分钟前
1
0
PCB设计-Allegro软件入门系列-设计参数配置(上)

前言 经历了导入网表,和放置器件后,我们就要画板子了,但是必要的设计参数也要先准备好,磨刀不误砍柴工。 《一》显示参数 这里主要设置DRC报错标志大小和飞线显示类型 (1)DRC标志可以适当...

demyar
15分钟前
2
0
js实现微博、微信分享

html <!-- 分享 --><div class="share-box"> <b style="vertical-align: middle;">分享到:</b> <a title="分享到新浪微博" class="shareSina"><span class="share-icon"></span><......

张兴华ZHero
31分钟前
3
0
创龙TMS320DM8168浮点DSP C674x + ARM Cortex-A8的CPU、NAND FLASH、NOR FLASH

TL6678-EasyEVM是广州创龙基于SOM-TL6678核心板而研发的一款多核高性能DSP开发板。开发板采用核心板+底板方式,底板采用沉金无铅工艺的四层板设计,尺寸为200mm*106.65mm,它为用户提供了SOM...

Tronlong创龙
34分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部