引入pom依赖
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.73</version>
</dependency>
application.properties配置文件
#redis配置
spring.redis.database=2
spring.redis.host=xx.xx.xx.xx
spring.redis.port=xxx
spring.redis.password=xxxx
spring.redis.pool.max-active=8
spring.redis.pool.max-wait=-1
spring.redis.pool.max-idle=8
spring.redis.pool.min-idle=0
spring.redis.timeout=1000
Redis配置类,RedisConfig.java
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import com.fasterxml.jackson.annotation.JsonInclude.Include;
import com.fasterxml.jackson.databind.ObjectMapper;
import redis.clients.jedis.JedisPoolConfig;
@Configuration("RedisConfig")
public class RedisConfig {
private static Logger log = LoggerFactory.getLogger(RedisConfig.class);
@Value("${spring.redis.host}")
private String host;
@Value("${spring.redis.port}")
private int port;
@Value("${spring.redis.password}")
private String password;
@Value("${spring.redis.database}")
private int database;
@Value("${spring.redis.timeout}")
private int timeout;
@Value("${spring.redis.pool.max-active}")
private int maxActive;
@Value("${spring.redis.pool.max-idle}")
private int maxIdle;
@Value("${spring.redis.pool.min-idle}")
private int minIdle;
@Value("${spring.redis.pool.max-wait}")
private long maxWait;
@Bean
public JedisConnectionFactory jedisConnectionFactory() {
JedisConnectionFactory factory = new JedisConnectionFactory();
factory.setHostName(host);
factory.setPort(port);
factory.setPassword(password);
factory.setDatabase(database);
factory.setTimeout(timeout);
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
jedisPoolConfig.setMaxTotal(maxActive);
jedisPoolConfig.setMaxIdle(maxIdle);
jedisPoolConfig.setMinIdle(minIdle);
jedisPoolConfig.setMaxWaitMillis(maxWait);
factory.setPoolConfig(jedisPoolConfig);
return factory;
}
@Bean(name = "redisTemplate")
public RedisTemplate<String, Object> redisTemplate(JedisConnectionFactory factory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
redisTemplate.setConnectionFactory(factory);
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setSerializationInclusion(Include.ALWAYS);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringRedisSerializer);
redisTemplate.setHashKeySerializer(stringRedisSerializer);
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
}
项目重启恢复对象数据,InitRedis.java
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
import com.alibaba.fastjson.JSON;
import com.nfz.demo.entity.PersonBean;
import com.nfz.demo.global.StatusMap;
@Component
public class InitRedis implements ApplicationRunner {
@Autowired
private RedisTemplate<String, ?> redisTemplate;
@Override
@Async
public void run(ApplicationArguments args) throws Exception {
Set<String> keys = redisTemplate.keys("*");
Map<String, PersonBean> hashMap = new HashMap<String, PersonBean>();
if (keys != null) {
for (String name : keys) {
Object one = redisTemplate.opsForValue().get(name);
PersonBean dto = JSON.parseObject(JSON.toJSONString(one), PersonBean.class);
hashMap.put(name, dto);
}
if (null != hashMap) {
StatusMap.setallStatusMap (hashMap);
}
}
}
}
缓存全局变量,StatusMap.java
package com.nfz.demo.global;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import com.nfz.demo.entity.PersonBean;
public class StatusMap implements Serializable {
private static final long serialVersionUID = 7196410776097983398L;
public static Map<String, PersonBean> allStatusMap = new HashMap<String, PersonBean>();;
public static synchronized Map<String, PersonBean> getallStatusMap () {
return allStatusMap ;
}
public synchronized static void setAllStatusMap (Map<String, PersonBean> allStatusMap ) {
StatusMap.AllStatusMap = allStatusMap ;
}
public static void addPersonStatus(String name, PersonBean person) {
allStatusMap.put(name, person);
}
public static void removePersonStatus(String name) {
allStatusMap.remove(name);
}
}
Redis操作展示(增加、删除、查询)
@Autowired
private RedisTemplate<String, ?> redisTemplate;
public static void main(String[] args) {
Object one = redisTemplate.opsForValue().get(name);
if (one != null) {
redisTemplate.delete(name);
}
redisTemplate.opsForValue().set(name, StatusMap.getallStatusMap().get(name));
redisTemplate.opsForValue().set(name, StatusMap.getallStatusMap().get(name), 5, TimeUnit.MINUTES);
Set<String> keys = redisTemplate.keys("*");
if (keys != null) {
for (String name : keys) {
Object one = redisTemplate.opsForValue().get(name);
System.out.println("当前的name:" + name + " - PersonBean:" + one);
}
}
}