A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

巧用Spring Boot中的Redis

Redis 是目前业界使用最广泛的内存数据存储。相比 Memcached,Redis 支持更丰富的数据结构,例如 hashes, lists, sets 等,同时支持数据持久化。除此之外,Redis 还提供一些类数据库的特性,比如事务,HA,主从库。可以说 Redis 兼具了缓存系统和数据库的一些特性,因此有着丰富的应用场景。本文介绍 Redis 在 Spring Boot 中两个典型的应用场景。

1、引入依赖包
[Java] 纯文本查看 复制代码
<dependency>
    
<groupId>
org.springframework.boot
</groupId>
    
<artifactId>
spring-boot-starter-data-redis
</artifactId>
</dependency>
<dependency>
    
<groupId>
org.apache.commons
</groupId>
    
<artifactId>
commons-pool2
</artifactId>
</dependency>


Spring Boot 提供了对 Redis 集成的组件包:spring-boot-starter-data-redis,spring-boot-starter-data-redis依赖于spring-data-redis 和 lettuce 。Spring Boot 1.0 默认使用的是 Jedis 客户端,2.0 替换成 Lettuce,但如果你从 Spring Boot 1.5.X 切换过来,几乎感受不大差异,这是因为 spring-boot-starter-data-redis 为我们隔离了其中的差异性。

Lettuce 是一个可伸缩线程安全的 Redis 客户端,多个线程可以共享同一个 RedisConnection,它利用优秀 netty NIO 框架来高效地管理多个连接。

2、添加配置文件
  • # Redis数据库索引(默认为0)
  • spring.redis.database=0  
  • # Redis服务器地址
  • spring.redis.host=localhost
  • # Redis服务器连接端口
  • spring.redis.port=6379  
  • # Redis服务器连接密码(默认为空)
  • spring.redis.password=
  • # 连接池最大连接数(使用负值表示没有限制) 默认 8
  • spring.redis.lettuce.pool.max-active=8
  • # 连接池最大阻塞等待时间(使用负值表示没有限制) 默认 -1
  • spring.redis.lettuce.pool.max-wait=-1
  • # 连接池中的最大空闲连接 默认 8
  • spring.redis.lettuce.pool.max-idle=8
  • # 连接池中的最小空闲连接 默认 0
  • spring.redis.lettuce.pool.min-idle=0

3、添加 cache 的配置类
[Java] 纯文本查看 复制代码
@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();
            }
        };
}
}

4、好了,接下来就可以直接使用了
[Java] 纯文本查看 复制代码
@RunWith(SpringRunner.class)
@SpringBootTest
public class TestRedis {
    @Autowired
    private StringRedisTemplate stringRedisTemplate;
    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void test() throws Exception {
        stringRedisTemplate.opsForValue().set("aaa", "111");
       Assert.assertEquals("111", stringRedisTemplate.opsForValue().get("aaa"));
    }

    @Test
    public void testObj() throws Exception {
        User user=new User("aa@126.com", "aa", "aa123456", "aa","123");
        ValueOperations<String, User> operations=redisTemplate.opsForValue();
        operations.set("com.neox", user);
       operations.set("com.neo.f", user,1, TimeUnit.SECONDS);
       Thread.sleep(1000);

        boolean exists=redisTemplate.hasKey("com.neo.f");
        if(exists){
            System.out.println("exists is true");
        }else{
            System.out.println("exists is false");
       }

    }
}





0 个回复

您需要登录后才可以回帖 登录 | 加入黑马