集群的session问题解决方案

Posted geekdc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了集群的session问题解决方案相关的知识,希望对你有一定的参考价值。

一、nginx ip_hash

  同一个ip的请求转发到同一个服务器,太low不解释。

二、spring-session

原理:存入session中的key-value,同时存放到redis中,如果session中没有找到,就去redis中去获取。

添加依赖

    <!--spring boot 与redis应用基本环境配置 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-redis</artifactId>
        </dependency>
        <!--spring session 与redis应用基本环境配置,需要开启redis后才可以使用,不然启动Spring boot会报错 -->
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
        </dependency>

添加配置

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 1800)
public class SessionConfig {

    // 冒号后的值为没有配置文件时,制动装载的默认值
    @Value("${redis.hostname:localhost}")
    String HostName;
    @Value("${redis.port:6379}")
    int Port;

    @Bean
    public JedisConnectionFactory connectionFactory() {
        JedisConnectionFactory connection = new JedisConnectionFactory();
        connection.setPort(Port);
        connection.setHostName(HostName);
        return connection;
    }
}
//初始化Session配置
public class SessionInitializer extends AbstractHttpSessionApplicationInitializer{
    public SessionInitializer() {
        super(SessionConfig.class);
    }
}

 

以上是关于集群的session问题解决方案的主要内容,如果未能解决你的问题,请参考以下文章

分布式集群架构场景优化解决方案:Session共享问题

session原理及实现集群session的方案原理

集群的session问题解决方案

集群环境下session共享解决方案

负载均衡集群中的session解决方案

负载均衡集群中的session解决方案