电商项目mall-learning学习笔记(4)——整合redis

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、引入依赖
  • 二、配置
  • 三、使用
    • i、 创建共用的redis服务代码
  • 总结


前言

这种整合操作一般都是三部曲:


提示:以下是本篇文章正文内容,下面案例可供参考

一、引入依赖

这一步在第一篇中已经引入

<!--redis依赖配置-->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

二、配置

在spring节点下配置,注意是spring节点

 redis:
    host: localhost # Redis服务器地址
    database: 0 # Redis数据库索引(默认为0)
    port: 6379 # Redis服务器连接端口
    password: # Redis服务器连接密码(默认为空)
    jedis:
      pool:
        max-active: 8 # 连接池最大连接数(使用负值表示没有限制)
        max-wait: -1ms # 连接池最大阻塞等待时间(使用负值表示没有限制)
        max-idle: 8 # 连接池中的最大空闲连接
        min-idle: 0 # 连接池中的最小空闲连接
    timeout: 3000ms # 连接超时时间(毫秒)

三、使用

i、 创建共用的redis服务代码

public interface RedisService {

    /**
     * 存储数据
     */
    void set(String key, String value);

    /**
     * 获取数据
     */
    String get(String key);

    /**
     * 设置超期时间
     */
    boolean expire(String key, long expire);

    /**
     * 删除数据
     */
    void remove(String key);

    /**
     * 自增操作
     * @param delta 自增步长
     */
    Long increment(String key, long delta);
}

创建接口后肯定需要实现类,而实现类中会发现有这么一个组件,StringRedisTemplate ,这就是依赖自带的。,后面的就可以使用这个作为工具类对redis进行操作了。

@Service
public class RedisServiceImpl implements RedisService {
    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    @Override
    public void set(String key, String value) {
        stringRedisTemplate.opsForValue().set(key, value);
    }

    @Override
    public String get(String key) {
        return stringRedisTemplate.opsForValue().get(key);
    }

    @Override
    public boolean expire(String key, long expire) {
        return stringRedisTemplate.expire(key, expire, TimeUnit.SECONDS);
    }

    @Override
    public void remove(String key) {
        stringRedisTemplate.delete(key);
    }

    @Override
    public Long increment(String key, long delta) {
        return stringRedisTemplate.opsForValue().increment(key,delta);
    }

}


总结

redis和数据库不用的是,一般持久化的我们会对数据库进行操作,而这种临时性的、验证的我们都可以放在redis中。当然要是数据够多,那就得考验你的内存了。

你可能感兴趣的:(redis,学习,spring,boot)