1. 程式人生 > 其它 >saas解決redis資料庫分離的一種方案

saas解決redis資料庫分離的一種方案

package com.xf.config;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

import javax.annotation.PostConstruct;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.RedisStandaloneConfiguration;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;

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

@Configuration
public class RedisConfig { // redis地址 @Value("${spring.redis.host}") private String host; // redis埠號 @Value("${spring.redis.port}") private int port; // redis密碼 @Value("${spring.redis.password}") private String password; // 預設資料庫 @Value("${spring.redis.database}
") private int defaultDB; // 多個數據庫集合 @Value("${spring.redis.dbs}") private Set<Integer> dbList; // RedisTemplate例項 private static Map<Integer, RedisTemplate<String, Object>> redisTemplateMap = new HashMap<>(); /** * 初始化連線池 */ @PostConstruct
public void initRedisTemplate() { dbList.add(defaultDB); for (Integer db : dbList) { // 儲存多個RedisTemplate例項 redisTemplateMap.put(db, redisTemplate(db)); } } public LettuceConnectionFactory redisConnection(int db) { RedisStandaloneConfiguration server = new RedisStandaloneConfiguration(); server.setHostName(host); // 指定地址 server.setDatabase(db); // 指定資料庫 server.setPort(port); // 指定埠 server.setPassword(password); // 指定密碼 LettuceConnectionFactory factory = new LettuceConnectionFactory(server); factory.afterPropertiesSet(); // 重新整理配置 return factory; } // RedisTemplate模板 public RedisTemplate<String, Object> redisTemplate(int db) { // 為了開發方便,一般直接使用<String,Object> RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(redisConnection(db)); // 設定連線 // Json序列化配置 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); // String的序列化 StringRedisSerializer stringRedisSerializer = new StringRedisSerializer(); // key採用String的序列化方式 template.setKeySerializer(stringRedisSerializer); // hash的key採用String的序列化方式 template.setHashKeySerializer(stringRedisSerializer); // value序列化方式採用jackson template.setValueSerializer(jackson2JsonRedisSerializer); // hash序列化方式採用jackson template.setHashValueSerializer(jackson2JsonRedisSerializer); template.afterPropertiesSet(); return template; } @Bean @Primary public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); RedisSerializer<String> redisSerializer = new StringRedisSerializer(); 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.setConnectionFactory(factory); // key序列化方式 template.setKeySerializer(redisSerializer); // value序列化 template.setValueSerializer(jackson2JsonRedisSerializer); // value hashmap序列化 template.setHashValueSerializer(jackson2JsonRedisSerializer); return template; } /** * 指定資料庫進行切換 * * @param db 資料庫索引 * @return */ public RedisTemplate<String, Object> getRedisTemplateByDb(int db) { return redisTemplateMap.get(db); } /** * 使用預設資料庫 * * @return */ public RedisTemplate<String, Object> getRedisTemplate() { return redisTemplateMap.get(defaultDB); } }