码迷,mamicode.com
首页 > 编程语言 > 详细

Spring+redis整合遇到的问题集以及注意事项

时间:2018-01-24 12:32:07      阅读:387      评论:0      收藏:0      [点我收藏+]

标签:move   string   区分   符号   hash   default   哈希类型   bsp   nbsp   

  redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

  1.缓存的对象必须实现序列化接口

  2.使用redis存储数据的时候,有时候为了查看的方便,通常会有层级或者说是目录,这时候我们在set的时候,需要将key值使用“:”的符号来区分层级关系,比如:@Cacheable(value = "users",key = "‘user:‘ + #user.userId "),那么在redis中就是user目录下的

  key值为userId.

  3.配置缓存管理器:

  

@Configuration
@EnableCaching
public class RedisCacheConfig extends CachingConfigurerSupport {

    @Bean
    public JedisConnectionFactory redisConnectionFactory() {
        JedisConnectionFactory redisConnectionFactory = new JedisConnectionFactory();
        // Defaults
        redisConnectionFactory.setHostName("127.0.0.1");
        redisConnectionFactory.setPort(6379);
        return redisConnectionFactory;
    }
@Bean
public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory cf) { RedisTemplate<String, String> redisTemplate = new RedisTemplate<String, String>(); redisTemplate.setConnectionFactory(cf); return redisTemplate; }
@Bean
public CacheManager cacheManager(RedisTemplate redisTemplate) { RedisCacheManager cacheManager = new RedisCacheManager(redisTemplate); // 设置默认的缓存过期时间 默认为无限 单位:秒 cacheManager.setDefaultExpiration(60*60); return cacheManager; }

   4.持续更新。。。

Spring+redis整合遇到的问题集以及注意事项

标签:move   string   区分   符号   hash   default   哈希类型   bsp   nbsp   

原文地址:https://www.cnblogs.com/AmbitiousMice/p/8340854.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!