Nginx 负载均衡条件下 Redis 共享Session (Java)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nginx 负载均衡条件下 Redis 共享Session (Java)相关的知识,希望对你有一定的参考价值。
关于Session的问题 网上有各个方面的针对,有在nginx 上处理: ip_hash的session,有在 tomcat 做处理:修改Context文件,有针对项目做处理。本篇就是对项目处理
1、首先我的项目是用Maven(如果没有用maven可以去下载),使用到的jar包有下:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session</artifactId>
<version>1.3.1.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
<version>1.3.1.RELEASE</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
<type>jar</type>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.4.2</version>
</dependency>
<!-- 日志文件管理包 -->
<!-- log start -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.version}</version>
</dependency>
<!-- log end -->
2、配置spring 配置文件 applicationContext-redis.xml
<context:annotation-config /> <context:property-placeholder location="classpath:redis.properties"/> <bean id="redisHttpSessionConfiguration" class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> <property name="maxInactiveIntervalInSeconds" value="3600"/> </bean> <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"> <property name="maxTotal" value="100" /> <property name="maxIdle" value="10" /> </bean> <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" destroy-method="destroy"> <property name="hostName" value="${redis.host}"/> <property name="port" value="${redis.port}"/> <property name="password" value="${redis.pass}" /> <property name="timeout" value="3000"/> <property name="usePool" value="true"/> <property name="poolConfig" ref="jedisPoolConfig"/> </bean>
3、web.xml 加入
<filter> <filter-name>springSessionRepositoryFilter</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> </filter> <filter-mapping> <filter-name>springSessionRepositoryFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath*:applicationContext*.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener>
项目结构图
5、成功界面
三台服务器
IP:10.13.5.10 作为负载均衡服务器 和 redis 服务器
IP:10.13.5.11 项目服务器01
IP: 10.13.5.12 项目服务器02
第一张对比: 出现了两个IP 不同的服务器
第二张对比(向Session 存值):
如上面 两组图片,其中 SessionID没有变,redis中的
最后是注意事项:
1、一定要保证nginx.conf 中的location / {} , ‘/’ 之后不要加任何uri 加了就实现不了。
2、一定要保证是同一个项目,就算只是改了html 中的几个字符,有时候Session 共享还是会失效!!!
以上是关于Nginx 负载均衡条件下 Redis 共享Session (Java)的主要内容,如果未能解决你的问题,请参考以下文章
nginx+tomcat+redis负载均衡,实现session共享
转载tomcat+nginx+redis实现均衡负载session共享
nginx-tomcat负载均衡redis-session共享,静态资源分离