1.创建Cache配置类

  1. @Configuration
  2. @EnableCaching
  3. public class RedisCacheConfig extends CachingConfigurerSupport {
  4.  
  5. @Value("${redis.cache.expiration}")
  6. private Long expiration;
  7.  
  8. /**
  9. *
  10. * 管理缓存
  11. */
  12. @Bean
  13. public CacheManager cacheManager(RedisTemplate<Object, Object> redisTemplate) {
  14. RedisCacheManager cacheManager = new RedisCacheManager(redisTemplate);
  15. cacheManager.setDefaultExpiration(expiration);// 设置缓存默认过期时间(全局的)秒
  16. return cacheManager;
  17. }
  18.  
  19. /**
  20. * 自定义生成的redis key
  21. * 在使用@Cacheable时,如果不指定key,则使用找个默认的key生成器生成的key
  22. * @return
  23. */
  24. @Bean
  25. @Override
  26. public KeyGenerator keyGenerator() {
  27. return new KeyGenerator() {
  28. @Override
  29. public Object generate(Object target, Method method, Object... params) {
  30. StringBuilder sb = new StringBuilder();
  31. sb.append(target.getClass().getName());
  32. sb.append(method.getName());
  33. for (Object obj : params) {
  34. sb.append(obj.toString());
  35. }
  36. return sb.toString();
  37. }
  38. };
  39. }
  40.  
  41. @Bean
  42. public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
  43. StringRedisTemplate template = new StringRedisTemplate(factory);
  44. Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
  45. ObjectMapper om = new ObjectMapper();
  46. om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
  47. om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
  48. jackson2JsonRedisSerializer.setObjectMapper(om);
  49. template.setValueSerializer(jackson2JsonRedisSerializer);
  50. template.afterPropertiesSet();
  51. return template;
  52. }
  53. }

2.使用

  1.手动方式:

    Jedis工具类

  1. @Component
  2. public class RedisUtil {
  3.  
  4. private Logger log = LoggerFactory.getLogger(getClass());
  5.  
  6. @Autowired
  7. private StringRedisTemplate stringRedisTemplate;
  8.  
  9. @Autowired
  10. private RedisTemplate<Object, Object> redisTemplate;
  11.  
  12. /**
  13. * 根据redis key 获取 value
  14. *
  15. * @param key 键
  16. * @return String
  17. */
  18. public String get(String key) {
  19. return this.stringRedisTemplate.opsForValue().get(key);
  20. }
  21.  
  22. /**
  23. * 根据redis key 设置 value
  24. *
  25. * @param key
  26. * @param value
  27. * @param overwrite
  28. */
  29. public void set(String key, String value, boolean overwrite) {
  30. if(!overwrite) {//setIfAbsent(key, value):如果key不存在则新增,并返回true;存在则不改变已经有的值,并返回false。
  31. boolean isSet = this.stringRedisTemplate.opsForValue().setIfAbsent(key, value);
  32.  
  33. if (!isSet) {
  34. log.warn("key值已存在且不进行覆写");
  35. }
  36.  
  37. }else {
  38. this.stringRedisTemplate.opsForValue().set(key, value);
  39. }
  40. }
  41.  
  42. /**
  43. * 根据redis key 设置 value 同时设置失效时间
  44. *
  45. * @param key
  46. */
  47. public void set(String key, String value, long timeout) {
  48. boolean isSet = this.stringRedisTemplate.opsForValue().setIfAbsent(key, value);
  49.  
  50. if (isSet) {
  51. this.stringRedisTemplate.expire(key, timeout, TimeUnit.SECONDS);
  52. } else {
  53. log.warn("key值已存在");
  54. }
  55. }
  56.  
  57. /**
  58. * 根据key检查是否已存在
  59. *
  60. * @param key
  61. * @return boolean
  62. */
  63. public boolean exists(String key) {
  64. boolean result = false;
  65. result = this.stringRedisTemplate.hasKey(key);
  66. return result;
  67. }
  68.  
  69. /**
  70. * 根据key值删除value
  71. *
  72. * @param key
  73. */
  74. public void del(String key) {
  75. this.stringRedisTemplate.delete(key);
  76. }
  77.  
  78. /**
  79. * 获取hashKey对应的所有键值
  80. *
  81. * @param key 键
  82. * @return 对应的多个键值
  83. */
  84. public Map<Object, Object> hmget(String key) {
  85. return this.redisTemplate.opsForHash().entries(key);
  86. }
  87.  
  88. /**
  89. * HashSet 并设置时间
  90. *
  91. * @param key 键
  92. * @param map 对应多个键值
  93. * @param time 时间(秒)
  94. * @return true成功 false失败
  95. */
  96. public boolean hmset(String key, Map<String, Object> map, long timeout) {
  97. try {
  98. this.redisTemplate.opsForHash().putAll(key, map);
  99. if (timeout > 0) {
  100. this.redisTemplate.expire(key, timeout, TimeUnit.SECONDS);
  101. }
  102. return true;
  103. } catch (Exception e) {
  104. e.printStackTrace();
  105. return false;
  106. }
  107. }
  108.  
  109. /**
  110. * 根据key删除hash
  111. *
  112. * @param key
  113. */
  114. public void delhm(String key) {
  115. this.redisTemplate.delete(key);
  116. }
  117.  
  118. /**
  119. * redis分布式锁(同步锁)
  120. * setIfAbsent(key, value):如果key不存在则新增,并返回true;存在则不改变已经有的值,并返回false。
  121. * 1.第一次key不存在,返回true,并新增key,设置过期时间;
  122. * 2.第二次进来,key存在,返回false说明已经锁了。
  123. * @param key
  124. * @param seconds
  125. * @return boolean
  126. */
  127. public boolean lock(String key, int seconds) {
  128. log.info("{}开始加锁", key);
  129.  
  130. boolean result = this.stringRedisTemplate.opsForValue().setIfAbsent(key, "LOCKED");
  131. log.info("{}锁定完成-{}", key, result);
  132.  
  133. if(result) {
  134. boolean expired = this.stringRedisTemplate.expire(key, seconds, TimeUnit.SECONDS);
  135. log.info("{}设置过期时间{}-{}", key, seconds, expired);
  136. }
  137.  
  138. return result;
  139. }
  140. }

  2.自动方式:

    添加@Cacheable注解实现缓存添加

    添加@CacheEvict注解实现缓存删除

   具体实现参考上一篇文章:八、springboot整合redis

九、springboot整合redis二之缓冲配置的更多相关文章

  1. SpringBoot整合Shiro 二:Shiro配置类

    环境搭建见上篇:SpringBoot整合Shiro 一:搭建环境 Shiro配置类配置 shiro的配置主要集中在 ShiroFilterFactoryBean 中 关于权限: anon:无需认证就可 ...

  2. Springboot整合Redis入门完整篇,零基础入门教学教程

    记录一次简易集成Redis缓存 自定义Redisconfig配置 自定义序列化操作 加深印像 整合前提工具环境准备: 1.redis官网 https://redis.io/download 下载安装r ...

  3. SpringBoot整合Redis、ApachSolr和SpringSession

    SpringBoot整合Redis.ApachSolr和SpringSession 一.简介 SpringBoot自从问世以来,以其方便的配置受到了广大开发者的青睐.它提供了各种starter简化很多 ...

  4. SpringBoot整合Redis及Redis工具类撰写

            SpringBoot整合Redis的博客很多,但是很多都不是我想要的结果.因为我只需要整合完成后,可以操作Redis就可以了,并不需要配合缓存相关的注解使用(如@Cacheable). ...

  5. springboot整合redis——redisTemplate的使用

    一.概述 相关redis的概述,参见Nosql章节 redisTemplate的介绍,参考:http://blog.csdn.net/ruby_one/article/details/79141940 ...

  6. SpringBoot整合Redis使用Restful风格实现CRUD功能

    前言 本篇文章主要介绍的是SpringBoot整合Redis,使用Restful风格实现的CRUD功能. Redis 介绍 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-valu ...

  7. 【SpringBoot | Redis】SpringBoot整合Redis

    SpringBoot整合Redis 1. pom.xml中引入Redis相关包 请注意,这里我们排除了lettuce驱动,采用了jedis驱动 <!-- redis的依赖 --> < ...

  8. Redis-基本概念、java操作redis、springboot整合redis,分布式缓存,分布式session管理等

    NoSQL的引言 Redis数据库相关指令 Redis持久化相关机制 SpringBoot操作Redis Redis分布式缓存实现 Resis中主从复制架构和哨兵机制 Redis集群搭建 Redis实 ...

  9. SpringBoot系列十:SpringBoot整合Redis

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.概念:SpringBoot 整合 Redis 2.背景 Redis 的数据库的整合在 java 里面提供的官方工具包:jed ...

随机推荐

  1. 【模考】2018.04.08 Travel

    Description 有N个人出去旅行,第i个人去A国有Ai种游玩方式,去B国有Bi种游玩方式,问至少有C个人去A国的情况下,所有人的游玩方式有多少种不同的可能. 两种所有人的游玩方式不同当且仅当存 ...

  2. Valid Parentheses - LeetCode

    目录 题目链接 注意点 解法 小结 题目链接 Valid Parentheses - LeetCode 注意点 考虑输入为空的情况 解法 解法一:如果是'('.'{'.'['这三者就入栈,否则就判断栈 ...

  3. 滥用DNSAdmins权限进行Active Directory提权

      0x00 前言 除了在实现自己的DNS服务器功能之外,Microsoft还为该服务器实现自己的管理协议以便于管理与Active Directory域集成.默认情况下,域控制器也是DNS服务器; 大 ...

  4. %1$s %1$d Android string (java & Android 格式化字符串)

    1$s // String%1$d // int //R.string.old:<string name="old">我今年%1$d岁了</string> ...

  5. 解题:TJOI 2015 组合数学

    题面 通过这个题理解了一下反链的概念,更新在图论知识点里了 每个点向右和下连边可以建出一张图,这个题事实上是让我们求图的最小链覆盖.Dilworth定理告诉我们,最小链覆盖等于最长反链(反链:DAG中 ...

  6. 【纪中集训2019.3.23】IOer

    题目 描述 你要在\(m\)天内,刷\(n\)道题,每天可以刷的题的数目不限: 第\(i\)天可以刷的题目的种类是\(ui+v\): 两种刷题的方案不同当且仅当某天刷题的数量不同或者依次刷题的种类不同 ...

  7. R语言外部数据读取

    0  引言 使用R语言.Python等进行数据处理的第一步就是要导入数据(也可以使用UCI数据集),下文主要根据R语言的帮助文档来介绍外部文件数据的导入方法和注意事项.下面先附上一些指令. 1 格式r ...

  8. C陷阱与缺陷的个人知识点摘录

    编译过程的一点心得体会: .h文件其实只在预处理的过程用到,用来将类似#include <stdio.h>这样的行展开为具体内容. 那些标准库或者其他库中的函数,是在链接的过程中连接器把相 ...

  9. Redis3未授权访问漏洞导致服务器被入侵

    今天在腾讯云上搭的开发环境里的一台机器cpu load飚升老高,然后还能登陆上去,top后发现两个可疑进程./root/目录下有修改过的文件./opt目录被干掉了, 后经分析,这台机器上有redis外 ...

  10. python实现将IP地址转换为数字

    话不多说,直接代码 ip_addr='192.168.2.10' # transfer ip to int def ip2long(ip): ip_list=ip.split('.') result= ...