Spring Boot使用Redis實現session共享

來源 - 素文宅博客:https://blog.yoodb.com/yoodb/article/detail/1421
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>

可以注入一個自動配置的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

<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*’,查看緩存是否成功。
推薦↓↓↓↓↓↓
這裏寫圖片描述
更多推薦:微信公衆號《優哉遊哉》
關注微信公衆號“優哉遊哉”(w_z90110),回覆關鍵字領取資料:如Hadoop,Dubbo,CAS源碼等等,免費領取資料視頻和項目等。
微信公衆號涵蓋:程序人生、搞笑視頻、算法與數據結構、黑客技術與網絡安全、前端開發、Java、Python、Redis緩存、spring源碼、各大主流框架、Web開發、大數據技術、Storm、Hadoop、MapReduce、Spark、elasticsearch、單點登錄統一認證、分佈式框架、集羣、安卓開發、iOS開發、C/C++、.NET、Linux、MySQL、Oracle、NoSQL非關係型數據庫、運維等。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章