电商项目高级篇06-缓存

电商项目高级篇06-缓存

缓存

流程图:

复制代码
data = cache.load(id);//从缓存加载数据
If(data == null){
data = db.load(id);//从数据库加载数据
cache.put(id,data);//保存到 cache 中
}
return data;

在我们的单体项目中可以用Map作为本地缓存,速度还很快。但是分布式项目。由于有多个服务。每次负载均衡到服务时,可能都不命中本地缓存,本地缓存不会在多个服务间生效。所以应该集成分布式缓存:比如redis

1、docker下启动redis

docker下载redis镜像

复制代码
docker pull redis

创建镜像挂载

在redis文件夹下网络下载redis.conf文件

复制代码
wget http://download.redis.io/redis-stable/redis.conf

去编辑redis.conf文件

注释后代表任意ip访问

设置redis密码

appendonly yes:redis持久化

##最后挂载永久启动redis

复制代码
docker run --restart=always --log-opt max-size=100m --log-opt max-file=2 -p 6379:6379 --name myredis -v /mydata/redis/redis.conf:/etc/redis/redis.conf -v /home/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes  --requirepass 123456

然后我们用rdm工具连上redis

2、项目整合redis

1、pom.xml引入依赖

复制代码
 <!--整合redis-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

2、application.yml配置redis配置信息

3、使用RedisTemplate操作redis

复制代码
	@Autowired
    StringRedisTemplate stringRedisTemplate;

	@Test
    public void testRedis(){
        ValueOperations<String, String> ops = stringRedisTemplate.opsForValue();
        ops.set("hello","world_"+ UUID.randomUUID().toString());
        String hello = ops.get("hello");
        System.out.println(hello);
    }

测试用例执行成功,控制台输出redis的值。

检查redis里是否有这个值

集成redis是成功的

3、redis改造三级分类业务

CategoryServiceImpl

复制代码
	 @Autowired
    private StringRedisTemplate redisTemplate;


 	@Override
    public Map<String, List<Catelog2Vo>> getCatalog() {
        // 1、获取缓存中的数据
        String catalog = redisTemplate.opsForValue().get("catalog");
        if (StrUtil.isBlank(catalog)) {
            // 2、从数据库中获取数据
            Map<String, List<Catelog2Vo>> catalogDb = this.getCatalogDb();
            // 3、缓存数据
            redisTemplate.opsForValue().set("catalog", JSON.toJSONString(catalogDb));
            return catalogDb;
        }
       // 将缓存中的数据返回
        return JSON.parseObject(catalog,Map.class);
    }
相关推荐
EndingCoder1 小时前
Electron 新特性:2025 版本更新解读
前端·javascript·缓存·electron·前端框架·node.js·桌面端
鼠鼠我捏,要死了捏2 小时前
Caffeine 本地缓存最佳实践与性能优化指南
缓存·性能优化·caffeine
好多173 小时前
《Redis的缓存策略》
数据库·redis·缓存
李游Leo3 小时前
npm / yarn / pnpm 包管理器对比与最佳实践(含国内镜像源配置与缓存优化)
前端·缓存·npm
tjjingpan4 小时前
mosdns缓存dns服务器配置记录
运维·服务器·缓存
EkihzniY14 小时前
OCR 识别表现好坏离不开什么?
缓存
爱吃烤鸡翅的酸菜鱼17 小时前
【Redis】常用数据结构之Hash篇:从常用命令到使用场景详解
数据结构·数据库·redis·后端·缓存·哈希算法
Pretend° Ω17 小时前
LRU缓存详解:用C语言实现高效数据管理
运维·c语言·spring·缓存·lru·双向链表
不良人天码星18 小时前
Redis单线程模型为什么快?
数据库·redis·缓存
爱吃烤鸡翅的酸菜鱼18 小时前
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
数据结构·redis·后端·缓存·list