【中间件】redis使用

一、redis介绍
redis是一种NoSQL类型的数据库,其数据存储在内存中,因此其数据查询效率很高,很快。常被用作数据缓存分布式锁 等。SpringBoot集成了Redis,可查看开发文档Redis开发文档。Redis有自己的可视化工具Redis Desktop Manager

Redis使用RedisTemplateStringRedisTemplate类提供的方法操作redis数据。

redis使用场景:

1、即时性、数据一致性要求不高的

2、访问量大且更新频率不高的数据(读多,写少)

二、redis使用方法

  1. 导包
bash 复制代码
<!--        redis依赖包-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
    </dependencies>

说明:具体依赖包名可在Maven仓库搜索redis即可查询到

  1. 写配置
bash 复制代码
spring:
	redis:
    	host: 192.168.195.131(redis地址)

说明:redis可配置项可以ctrl+点击redis查看所有RedisProperties

  1. 使用RedisTemplateStringRedisTemplate类提供的方法操作redis数据。
bash 复制代码
@Override
    public Map<String, List<Level2CategoryVO>> getCatalogJson() {
        // 先从缓存中查,如果有则直接返回,如果没有则查数据库,再返回
        String catalogJson = redisTemplate.opsForValue().get("catalogJson");
        // 如果缓存中没有,则查数据库,将结果存到redis,再返回
        if (StringUtil.isNullOrEmpty(catalogJson)) {
            Map<String, List<Level2CategoryVO>> catalogJsonDB = this.getCatalogJsonDB();
            redisTemplate.opsForValue().set("catalogJson", JSON.toJSONString(catalogJsonDB));
            return catalogJsonDB;
        }
        return JSON.parseObject(catalogJson, new HashMap<String, List<Level2CategoryVO>>().getClass());
    }

redis可视化结果:

说明:StringRedisTemplate类是专门在redis中操作key和value均为String类型的数据。RedisTemplate则value可为对象类型。

相关推荐
pan3035074799 分钟前
mysql 回表查询(二次查询,如何检查,如何规避)
数据库·mysql
Michaelwubo21 分钟前
elasticsearch-7.17.29 集群案例,k8s方式和原始方式
数据库
TDengine (老段)34 分钟前
TDengine 选择函数 Last() 用户手册
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
echoyu.37 分钟前
消息队列-初识kafka
java·分布式·后端·spring cloud·中间件·架构·kafka
little_xianzhong41 分钟前
关于对逾期提醒的定时任务~改进完善
java·数据库·spring boot·spring·mybatis
Sally璐璐44 分钟前
Go正则表达式实战指南
数据库·mysql·golang
小猪咪piggy1 小时前
【JavaEE】(23) 综合练习--博客系统
java·数据库·java-ee
bikong71 小时前
一种高效绘制余晖波形的方法Qt/C++
数据库·c++·qt
一叶飘零_sweeeet1 小时前
从 0 到 1 攻克订单表分表分库:亿级流量下的数据库架构实战指南
java·数据库·mysql·数据库架构·分库分表
xianyinsuifeng1 小时前
Oracle 10g → Oracle 19c 升级后问题解决方案(Pro*C 项目)
c语言·数据库·oracle