软件环境:springboot 1.5.2,redis 3.2.1java
在application.properties,增长redis的配置,主要配置项包括redis的ip,端口,密码等,具体以下:redis
# redis # Redis数据库索引(默认为0) spring.redis.database=0 # Redis服务器地址 spring.redis.host=localhost # Redis服务器链接端口 spring.redis.port=6379 # Redis服务器链接密码(默认为空) spring.redis.password=123456 # 链接池最大链接数(使用负值表示没有限制) 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=0
在任意包(package)下添加类spring
/** * redis缓存配置 */ @Configuration @EnableCaching public class RedisConfig extends CachingConfigurerSupport { // @Bean // 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(); // } // }; // } @SuppressWarnings("rawtypes") @Bean public CacheManager cacheManager(RedisTemplate redisTemplate) { RedisCacheManager rcm = new RedisCacheManager(redisTemplate); //设置缓存过时时间 //rcm.setDefaultExpiration(60);//秒 return rcm; } /** * redis模板配置 * * @param factory * @return */ @Bean public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) { StringRedisTemplate template = new StringRedisTemplate(factory); //RedisTemplate序列化类设置 //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); //value的序列化类 template.setValueSerializer(jackson2JsonRedisSerializer); //hash的value的序列化类 template.setHashValueSerializer(jackson2JsonRedisSerializer); template.afterPropertiesSet(); return template; } }
redis序列化类说明(关键!!)数据库
根本上来讲,redis只能保存字符串。若是要保存对象(javabean),就须要序列化,因此要设置序列化的类json
在上方代码的redisTemplate方法中,其中有一行缓存
//value的序列化类 template.setValueSerializer(jackson2JsonRedisSerializer);
这是设置对value的序列化类的设置,当value的类型不是string时,就会用他作序列化springboot
下面还有一行服务器
//hash的value的序列化类 template.setHashValueSerializer(jackson2JsonRedisSerializer);
经过名字能够看出是对HashValue的序列化,那HashValue跟value有什么区别?这涉及到redis的几种数据类型,对于string和list类型,他们的整个值的结构是key和value,对于hash类型,结构就是key,hashKey,hashValue,因此setHashValueSerializer是设置hash结构的hashValue的session
若是没有setHashValueSerializer,而在对hashValue赋值时传入了javabean,就会报错app
如下例子使用hash类型,场景是保存全部登陆用户的信息,其中key固定是loginToken,hashKey是token(每一个用户惟一随机生成的string),hashValue是一个叫LoginUser的类
在须要操做redis的类先添加RedisTemplate的注入
ops.put方法表明插入,3个参数分别对应key,hashKey,hashValue
在这里能够把key理解为表名,hashKey理解为表的id,hashValue就是一行的全部列的值
HashOperations<String, Object, Object> ops = redisTemplate.opsForHash(); //登陆用户信息 LoginUser loginUser = new LoginUser(); loginUser.setToken(token); loginUser.setUserName(userName); //插入到redis ops.put("LoginUser", token, loginUser);
ops.hasKey的两个参数,第一个是key,第二是hashKey
HashOperations<String, String, Object> ops = redisTemplate.opsForHash(); return ops.hasKey("LoginUser", token);
ops.hasKey的两个参数,第一个是key,第二是hashKey,跟上面的检查差很少
HashOperations<String, String, LoginUser> ops = redisTemplate.opsForHash(); LoginUser loginUser = ops.get("LoginUser", token);
能够像session同样,设置一个有效时间,超过了自动删除
参数1是key,参数2是时间的值,参数3是时间单位,下面例子是30分钟的意思
redisTemplate.expire("LoginUser", 30, TimeUnit.MINUTES);
下图是本例子写入数据后的样子