Spring Boot使用Redis实现session共享

Redis是一个缓存消息中间件及具有丰富特性的键值存储系统。Spring Boot为Jedis客户端库和由Spring Data Redis提供的基于Jedis客户端的抽象提供自动配置。spring-boot-starter-redis'Starter POM'为收集依赖提供一种便利的方式。


引入spring-boot-starter-redis,在pom.xml配置文件中增加配置如下(基于之前章节“Spring Boot 构建框架”中的pom.xml文件):


<dependency>  
   <groupId>org.springframework.boot</groupId>  
   <artifactId>spring-boot-starter-redis</artifactId>  
</dependency>

注意Spring Boot1.4版本开始,spring-boot-starter-redis依赖改成了spring-boot-starter-data-redis


可以注入一个自动配置的RedisConnectionFactory,StringRedisTemplate或普通的跟其他Spring Bean相同的RedisTemplate实例。默认情况下,这个实例将尝试使用localhost:6379连接Redis服务器。


@Component
public class MyBean {
   private StringRedisTemplate template;
   
   @Autowired
   public MyBean(StringRedisTemplate template)
{
       this.template = template;
   }
   // ...
}


如果添加一个自己的任何自动配置类型的@Bean,它将替换默认的(除了RedisTemplate的情况,它是根据bean的名称'redisTemplate'而不是它的类型进行排除的)。如果在classpath路径下存在commons-pool2,默认会获得一个连接池工厂。


应用使用Redis案例


添加配置文件,配置内容如下:


# REDIS (RedisProperties)
# Redis服务器地址
spring.redis.host=192.168.0.58
# Redis服务器连接端口
spring.redis.port=6379  
# 连接超时时间(毫秒)
spring.redis.timeout=0


redis配置类,具体代码如下:


import org.springframework.boot.context.properties.ConfigurationProperties;  
import org.springframework.stereotype.Component;  
 
@Component  
@ConfigurationProperties(prefix = "spring.redis")  
public class RedisConn {  
     
   private String host;  
     
   private int port;  
     
   private int timeout;  
 
 
   public String getHost() {  
       return host;  
   }  
 
   public void setHost(String host) {  
       this.host = host;  
   }  
 
   public int getPort() {  
       return port;  
   }  
 
   public void setPort(int port) {  
       this.port = port;  
   }  
 
   public int getTimeout() {  
       return timeout;  
   }  
 
   public void setTimeout(int timeout) {  
       this.timeout = timeout;  
   }  
 
   @Override  
   public String toString() {  
       return "Redis [localhost=" + host + ", port=" + port + ", timeout=" + timeout + "]";  
   }  
     
 
}


注意:在RedisConn类中注解@ConfigurationProperties(prefix = "spring.Redis")的作用是读取springboot的默认配置文件信息中以spring.redis开头的信息。


配置cache类


import java.lang.reflect.Method;  
import java.util.HashMap;  
import java.util.Map;  

import org.springframework.beans.factory.annotation.Autowired;  
import org.springframework.beans.factory.annotation.Value;  
import org.springframework.cache.CacheManager;  
import org.springframework.cache.annotation.CachingConfigurerSupport;  
import org.springframework.cache.annotation.EnableCaching;  
import org.springframework.cache.interceptor.KeyGenerator;  
import org.springframework.context.annotation.Bean;  
import org.springframework.context.annotation.ComponentScan;  
import org.springframework.context.annotation.Configuration;  
import org.springframework.context.annotation.PropertySource;  
import org.springframework.data.redis.cache.RedisCacheManager;  
import org.springframework.data.redis.connection.RedisConnectionFactory;  
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;  
import org.springframework.data.redis.core.RedisTemplate;  
import org.springframework.data.redis.core.StringRedisTemplate;  
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;  
import org.springframework.stereotype.Component;  

import com.cachemodle.RedisConn;  
import com.fasterxml.jackson.annotation.JsonAutoDetect;  
import com.fasterxml.jackson.annotation.PropertyAccessor;  
import com.fasterxml.jackson.databind.ObjectMapper;  

/**
*  
* @author sandsa redis cache service
*
*/
 

@Configuration  
@EnableCaching  
public class RedisConfig extends CachingConfigurerSupport {  

  @Autowired  
  private RedisConn redisConn;  
   
  /**
   * 生产key的策略
   *  
   * @return
   */
 

  @Bean  
  @Override  
  public KeyGenerator keyGenerator() {  
      return new KeyGenerator() {  

          @Override  
          public Object generate(Object target, Method method, Object... params) {  
              StringBuilder sb = new StringBuilder();  
              sb.append(target.getClass().getName());  
              sb.append(method.getName());  
              for (Object obj : params) {  
                  sb.append(obj.toString());  
              }  
              return sb.toString();  
          }  
      };  

  }  

  /**
   * 管理缓存
   *  
   * @param redisTemplate
   * @return
   */
 

  @SuppressWarnings("rawtypes")  
  @Bean  
  public CacheManager CacheManager(RedisTemplate redisTemplate) {  
      RedisCacheManager rcm = new RedisCacheManager(redisTemplate);  
      // 设置cache过期时间,时间单位是秒  
      rcm.setDefaultExpiration(60);  
      Map<String, Long> map = new HashMap<String, Long>();  
      map.put("test", 60L);  
      rcm.setExpires(map);  
      return rcm;  
  }  
   
  /**
   * redis 数据库连接池
   * @return
   */
 

  @Bean  
  public JedisConnectionFactory redisConnectionFactory() {  
      JedisConnectionFactory factory = new JedisConnectionFactory();  
      factory.setHostName(redisConn.getHost());  
      factory.setPort(redisConn.getPort());  
      factory.setTimeout(redisConn.getTimeout()); // 设置连接超时时间  
      return factory;  
  }  

  /**
   * redisTemplate配置
   *  
   * @param factory
   * @return
   */
 
  @SuppressWarnings({ "rawtypes", "unchecked" })  
  @Bean  
  public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {  
      StringRedisTemplate template = new StringRedisTemplate(factory);  
      Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);  
      ObjectMapper om = new ObjectMapper();  
      om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);  
      om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);  
      jackson2JsonRedisSerializer.setObjectMapper(om);  
      template.setValueSerializer(jackson2JsonRedisSerializer);  
      template.afterPropertiesSet();  
      return template;  
  }  

}


分析:缓存类继承的是CachingConfigurerSupport,它把读取的配置文件信息的RedisConn类对象注入到这个类中。在这个类中keyGenerator()方法是key的生成策略,CacheManager()方法是缓存管理策略,redisConnectionFactory()是redis连接,redisTemplate()方法是redisTemplate配置信息,配置后使redis中能存储Java对象。


测试配置是否成功,实例:


@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(Application.class)
public class TestRedis {
   @Autowired
   private StringRedisTemplate stringRedisTemplate; // 处理字符串
   
   @Autowired
   private RedisTemplate redisTemplate; // 处理对象
   @Test
   public void test() throws Exception {
       stringRedisTemplate.opsForValue().set("yoodb", "123");
       Assert.assertEquals("123", stringRedisTemplate.opsForValue().get("yoodb"));
   }
}


简单封装的Redis工具类,代码如下:


import java.io.Serializable;  
import java.util.Set;  
import java.util.concurrent.TimeUnit;  
 
import org.springframework.beans.factory.annotation.Autowired;  
import org.springframework.data.redis.core.RedisTemplate;  
import org.springframework.data.redis.core.ValueOperations;  
import org.springframework.stereotype.Component;  
 
@Component  
public class RedisUtils {  
 
   @SuppressWarnings("rawtypes")  
   @Autowired  
   private RedisTemplate redisTemplate;  
 
   /**
    * 批量删除对应的value
    *  
    * @param keys
    */
 
   public void remove(final String... keys) {  
       for (String key : keys) {  
           remove(key);  
       }  
   }  
 
   /**
    * 批量删除key
    *  
    * @param pattern
    */
 
   @SuppressWarnings("unchecked")  
   public void removePattern(final String pattern) {  
       Set<Serializable> keys = redisTemplate.keys(pattern);  
       if (keys.size() > 0)  
           redisTemplate.delete(keys);  
   }  
 
   /**
    * 删除对应的value
    *  
    * @param key
    */
 
   @SuppressWarnings("unchecked")  
   public void remove(final String key) {  
       if (exists(key)) {  
           redisTemplate.delete(key);  
       }  
   }  
 
   /**
    * 判断缓存中是否有对应的value
    *  
    * @param key
    * @return
    */
 
   @SuppressWarnings("unchecked")  
   public boolean exists(final String key) {  
       return redisTemplate.hasKey(key);  
   }  
 
   /**
    * 读取缓存
    *  
    * @param key
    * @return
    */
 
   @SuppressWarnings("unchecked")  
   public Object get(final String key) {  
       Object result = null;  
       ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();  
       result = operations.get(key);  
       return result;  
   }  
 
   /**
    * 写入缓存
    *  
    * @param key
    * @param value
    * @return
    */
 
   @SuppressWarnings("unchecked")  
   public boolean set(final String key, Object value) {  
       boolean result = false;  
       try {  
           ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();  
           operations.set(key, value);  
           result = true;  
       } catch (Exception e) {  
           e.printStackTrace();  
       }  
       return result;  
   }  
 
   /**
    * 写入缓存
    *  
    * @param key
    * @param value
    * @return
    */
 
   @SuppressWarnings("unchecked")  
   public boolean set(final String key, Object value, Long expireTime) {  
       boolean result = false;  
       try {  
           ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();  
           operations.set(key, value);  
           redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);  
           result = true;  
       } catch (Exception e) {  
           e.printStackTrace();  
       }  
       return result;  
   }  
 
}


查询数据库时自动使用缓存,根据方法生成缓存,参考代码如下:


@Service
public class UserService {
 @Cacheable(value = "redis-key")
 public UserInfo getUserInfo(Long id, String sex, int age, String name) {
     System.out.println("无缓存时调用----数据库查询");
     return new UserInfo(id, sex, age, name);
 }
}


注意:value的值就是缓存到redis中的key,此key是需要自己在进行增加缓存信息时定义的key,用于标识唯一性的。


Session 共享


分布式系统中session共享有很多不错的解决方案,其中托管到缓存中是比较常见的方案之一,下面利用Session-spring-session-data-redis实现session共享。


引入依赖,在pom.xml配置文件中增加如下内容:


<dependency>
   <groupId>org.springframework.session</groupId>
   <artifactId>spring-session-data-redis</artifactId>
</dependency>


Session配置,具体代码如下:


@Configuration
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 86400*30)
public class SessionConfig {
}


maxInactiveIntervalInSeconds: 设置Session失效时间,使用Redis Session之后,原Spring Boot的server.session.timeout属性不再生效。



测试实例,具体代码如下:


@RequestMapping("uid")
String uid(HttpSession session) {
UUID uid = (UUID) session.getAttribute("uid");
if (uid == null) {
uid = UUID.randomUUID();
}
session.setAttribute("uid", uid);
return session.getId();
}


登录redis服务端,输入命令keys 'session*',查看缓存是否成功。


注意Spring Boot1.4版本开始,spring-boot-starter-redis依赖改成了spring-boot-starter-data-redis


来源:素文宅博客

链接:https://blog.yoodb.com/yoodb/article/detail/1412


注意 Spring Boot 1.4 版本开始, spring-boot-starter-redis 依赖改成了 spring-boot-starter-data-redis

来源:素文宅博客

链接:https://blog.yoodb.com/yoodb/article/detail/1412

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要使用Redis实现Spring Boot应用程序的会话共享,您需要执行以下步骤: 1. 添加Redis依赖项 在您的Spring Boot项目中添加spring-boot-starter-data-redis依赖项,这将为您提供Redis客户端和Spring Session依赖项。 2. 配置Redis 在application.properties文件中添加Redis配置,包括Redis服务器的主机名、端口和密码。 3. 启用Spring SessionSpring Boot应用程序中启用Spring Session,您需要将@EnabaleRedisHttpSession注释添加到Spring Boot主应用程序类上。 4. 配置会话超时 您可以在application.properties文件中设置会话超时时间,例如:spring.session.timeout=30m。 5. 测试 最后,您可以测试您的Spring Boot应用程序是否正在使用Redis进行会话共享,通过多个实例运行应用程序,并在每个实例中访问同一URL并查看结果是否相同。 通过这些步骤,您应该能够在Spring Boot应用程序中使用Redis进行会话共享。 ### 回答2: 在Spring Boot使用Redis实现session共享可以通过以下步骤实现: 1. 首先,确保在pom.xml文件中添加以下依赖项以在Spring Boot使用Redis: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 在application.properties文件中配置Redis连接信息: ```properties spring.redis.host=your-redis-host spring.redis.port=your-redis-port spring.redis.password=your-redis-password ``` 3. 创建一个配置类(如RedisConfig.java),用于配置与Redis的连接以及序列化的设置: ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer; import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession; @Configuration @EnableRedisHttpSession(maxInactiveIntervalInSeconds = 86400) // 设置session的有效时间,单位为秒 public class RedisConfig { @Bean public RedisSerializer<Object> redisSerializer() { // 使用JSON序列化器,存储到Redis中的Session以JSON格式保存,方便阅读 return new GenericJackson2JsonRedisSerializer(); } @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(redisConnectionFactory); // 设置keyvalue的序列化器 template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(redisSerializer()); template.setHashKeySerializer(new StringRedisSerializer()); template.setHashValueSerializer(redisSerializer()); return template; } } ``` 4. 在需要使用session的地方注入`HttpSession`,并使用它来获取、设置和删除session中的属性: ```java import javax.servlet.http.HttpSession; // 注入HttpSession @Autowired private HttpSession session; // 获取session中的属性 Object attributeValue = session.getAttribute("attributeName"); // 设置session中的属性 session.setAttribute("attributeName", attributeValue); // 删除session中的属性 session.removeAttribute("attributeName"); ``` 这样,通过以上步骤,就可以在Spring Boot使用Redis实现session共享了。注意,由于Redis是内存数据库,需要设置session的有效时间以避免占用过多的内存资源。 ### 回答3: 使用Spring Boot实现Session共享的方法有两种:使用Spring Session使用RedisTemplate。 第一种方法是使用Spring Session实现Session共享Spring Session是一个用于在分布式环境下管理SessionSpring项目,它提供了一种基于SpringSession管理解决方案。要使用Spring Session,需要在pom.xml文件中添加相关依赖,然后在Spring Boot配置类中加上@EnableRedisHttpSession注解,配置Redis连接信息。这样,Spring Session会将Session信息存储到Redis中,实现Session共享。 第二种方法是使用RedisTemplate来实现Session共享RedisTemplate是Spring Data Redis提供的一个用于操作Redis的模板类,可以方便地进行Redis的读写操作。要使用RedisTemplate实现Session共享,首先需要在pom.xml文件中添加相关依赖,然后在Spring Boot配置类中创建一个RedisConnectionFactory实例,并将其注入到RedisTemplate中。通过RedisTemplate,可以将Session信息存储到Redis中,并实现Session共享。 无论是使用Spring Session还是使用RedisTemplate,都需要在Spring Boot配置文件中配置Redis连接信息,包括Redis服务器的IP地址、端口号和密码(如果有)。此外,还可以配置Redis的连接池参数,以提高性能和并发能力。 总结起来,要使用Spring Boot实现RedisSession共享,可以使用Spring SessionRedisTemplate两种方式。通过配置相关依赖和连接信息,将Session信息存储到Redis中,实现Session共享。这样,在分布式环境下,不同的应用实例之间就能够共享Session,并实现会话的跨应用访问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值