本文讲解Spring Boot基础下,如何整合Redis,编写数据访问。

环境依赖

修改 POM 文件,添加 spring-boot-starter-redis 依赖。

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-redis</artifactId>
  4. </dependency>

数据源

方案一 使用 Spring Boot 默认配置

在 src/main/resources/application.properties 中配置数据源信息。

  1. spring.redis.host=localhost
  2. spring.redis.port=6379
  3. spring.redis.password=
  4. spring.redis.database=1
  5. spring.redis.pool.max-active=8
  6. spring.redis.pool.max-wait=-1
  7. spring.redis.pool.max-idle=500
  8. spring.redis.pool.min-idle=0
  9. spring.redis.timeout=0

方案二 手动创建

在 src/main/resources/config/redis.properties 中配置数据源信息。

  1. # redis
  2. redis.host=localhost
  3. redis.port=6379
  4. redis.password=
  5. redis.database=1

通过 Java Config 创建redisTemplate。

  1. @Configuration
  2. @PropertySource("classpath:config/redis.properties")
  3. public class RedisConfig {
  4. @Autowired
  5. private Environment env;
  6. @Bean
  7. public RedisConnectionFactory redisConnectionFactory() {
  8. JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
  9. JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
  10. jedisConnectionFactory.setHostName(env.getProperty("redis.host").trim());
  11. jedisConnectionFactory.setPort(Integer.parseInt(env.getProperty("redis.port").trim()));
  12. jedisConnectionFactory.setPassword(env.getProperty("redis.password").trim());
  13. jedisConnectionFactory.setDatabase(Integer.parseInt(env.getProperty("redis.database").trim()));
  14. jedisConnectionFactory.setUsePool(true);
  15. jedisConnectionFactory.setPoolConfig(jedisPoolConfig);
  16. return jedisConnectionFactory;
  17. }
  18. @Bean
  19. public RedisTemplate<String, String> redisTemplate() {
  20. RedisTemplate<String, String> redisTemplate = new StringRedisTemplate();
  21. redisTemplate.setConnectionFactory(redisConnectionFactory());
  22. redisTemplate.afterPropertiesSet();
  23. return redisTemplate;
  24. }
  25. }

使用 redisTemplate 操作

工具类

  1. @Repository
  2. public class RedisBaseDao {
  3. @Resource(name="redisTemplate")
  4. protected ValueOperations<String, String> valueOperations;
  5. public void addValue(String key, String value){
  6. valueOperations.set(key, value);
  7. }
  8. public String getValue(String key){
  9. return valueOperations.get(key);
  10. }
  11. }

测试类

  1. @Repository
  2. public class ValueRedisDao {
  3. @Autowired
  4. public RedisBaseDao redisBaseDao;
  5. private String getKey(){
  6. return "param";
  7. }
  8. public void save(String param){
  9. this.redisBaseDao.addValue(this.getKey(), param);
  10. }
  11. public String getParam(){
  12. return this.redisBaseDao.getValue(this.getKey());
  13. }
  14. }

单元测试用例

编写单元测试用例,测试Redis是否正常工作。

  1. @RunWith(SpringJUnit4ClassRunner.class)
  2. @SpringApplicationConfiguration(WebMain.class)
  3. public class RedisTest {
  4. @Autowired
  5. private ValueRedisDao valueRedisDao;
  6. @Test
  7. public void test() throws Exception {
  8. this.valueRedisDao.save("LiangGzone");
  9. System.out.println(this.valueRedisDao.getParam());
  10. }
  11. }

总结

上面这个简单的案例,让我们看到了 Spring Boot 整合 Redis 的整个流程。实际上,与 Spring 4 中 通过 Spring Data Redis 整合 Redis 并无二意, Spring Boot 默认集成了一些配置信息,但是个人更加偏向于方案二的手动创建方式,为什么呢,因为更方便扩展。

源代码

相关示例完整代码: springboot-action

(完)

如果觉得我的文章对你有帮助,请随意打赏。

Spring Boot 揭秘与实战(二) 数据存储篇 - Redis的更多相关文章

  1. Spring Boot 揭秘与实战(二) 数据存储篇 - 声明式事务管理

    文章目录 1. 声明式事务 2. Spring Boot默认集成事务 3. 实战演练4. 源代码 3.1. 实体对象 3.2. DAO 相关 3.3. Service 相关 3.4. 测试,测试 本文 ...

  2. Spring Boot 揭秘与实战(二) 数据存储篇 - ElasticSearch

    文章目录 1. 版本须知 2. 环境依赖 3. 数据源 3.1. 方案一 使用 Spring Boot 默认配置 3.2. 方案二 手动创建 4. 业务操作5. 总结 4.1. 实体对象 4.2. D ...

  3. Spring Boot 揭秘与实战(二) 数据存储篇 - MongoDB

    文章目录 1. 环境依赖 2. 数据源 2.1. 方案一 使用 Spring Boot 默认配置 2.2. 方案二 手动创建 3. 使用mongoTemplate操作4. 总结 3.1. 实体对象 3 ...

  4. Spring Boot 揭秘与实战(二) 数据存储篇 - JPA整合

    文章目录 1. 环境依赖 2. 数据源 3. 脚本初始化 4. JPA 整合方案一 通过继承 JpaRepository 接口 4.1. 实体对象 4.2. DAO相关 4.3. Service相关 ...

  5. Spring Boot 揭秘与实战(二) 数据存储篇 - MyBatis整合

    文章目录 1. 环境依赖 2. 数据源3. 脚本初始化 2.1. 方案一 使用 Spring Boot 默认配置 2.2. 方案二 手动创建 4. MyBatis整合5. 总结 4.1. 方案一 通过 ...

  6. Spring Boot 揭秘与实战(二) 数据存储篇 - 数据访问与多数据源配置

    文章目录 1. 环境依赖 2. 数据源 3. 单元测试 4. 源代码 在某些场景下,我们可能会在一个应用中需要依赖和访问多个数据源,例如针对于 MySQL 的分库场景.因此,我们需要配置多个数据源. ...

  7. Spring Boot 揭秘与实战(二) 数据存储篇 - MySQL

    文章目录 1. 环境依赖 2. 数据源3. 脚本初始化 2.1. 方案一 使用 Spring Boot 默认配置 2.2. 方案二 手动创建 4. 使用JdbcTemplate操作5. 总结 4.1. ...

  8. Spring Boot 揭秘与实战(二) 数据缓存篇 - 快速入门

    文章目录 1. 声明式缓存 2. Spring Boot默认集成CacheManager 3. 默认的 ConcurrenMapCacheManager 4. 实战演练5. 扩展阅读 4.1. Mav ...

  9. Spring Boot 揭秘与实战(二) 数据缓存篇 - Redis Cache

    文章目录 1. Redis Cache 集成 2. 源代码 本文,讲解 Spring Boot 如何集成 Redis Cache,实现缓存. 在阅读「Spring Boot 揭秘与实战(二) 数据缓存 ...

随机推荐

  1. ES6 开发常用新特性以及简述ES7

    一.关于变量 ES6新增:块级作用域变量 1.let定义块级作用域变量 没有变量的提升,必须先声明后使用 let声明的变量,不能与前面的let,var,conset声明的变量重名 { { consol ...

  2. JAVA 两个对象不同为什么他们的hashcode有可能相同

    hashCode是所有java对象的固有方法,如果不重载的话,返回的实际上是该对象在jvm的堆上的内存地址,而不同对象的内存地址肯定不同,所以这个hashCode也就肯定不同了.如果重载了的话,由于采 ...

  3. qt 调用zlib压缩与解压缩功能

    Zlib是一种免费且通用的压缩库,由于Zlib压缩效果比LZW好,而且解压缩速度快,更重要的是商业软件中使用Zlib不需要缴纳版权费,所以很多游戏都使用Zlib压缩资源文件. Zlib是由Jean-l ...

  4. js正则表达式取{}中的值

    var reg = /[^\{}]*\{(.*)\}[^\}]*/; var str = "1111{122}"; console.log(str.replace(reg,'$1' ...

  5. 把旧系统迁移到.Net Core 2.0 日记 (15) --Session 改用Redis

    安装Microsoft.Extensions.Caching.Redis.Core NuGet中搜索Microsoft.Extensions.Caching.Redis.Core并安装,此NuGet包 ...

  6. Struts 2 初步入门(六)之处理结果类型

    Struts2 处理流程: 用户请求--->struts框架--->Action控制器--->struts框架--->视图资源 xml配置文件里: <result nam ...

  7. 程序从sqlserver2008搬家到MySQL5.6

    1.数据表结构的搬家 SqlServer的建表sql语句在MySQL中肯定不能运行 这里使用转换工具 下载地址: https://download.csdn.net/download/zhutouai ...

  8. Factory,工厂设计模式,C++描述

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  9. AVL平衡二叉树实现,图解分析,C++描述,完整可执行代码

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  10. 生成器 Generators

    function* quips(name) { yield "你好 " + name + "!"; yield "希望你能喜欢这篇介绍ES6的译文&q ...