Redis实现商品信息对象缓存

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis实现商品信息对象缓存

优化秒杀系统性能:使用Redis实现商品信息对象缓存

在秒杀系统的开发中,为了提高系统性能和降低数据库压力,使用Redis进行对象缓存是一种常见的优化策略。本文将详细介绍如何在Spring Boot项目中,通过Redis缓存实现商品信息的对象缓存,以提高系统性能和响应速度。

1. 添加依赖

首先,确保在pom.xml中添加了Spring Boot和Redis的相关依赖:

<!-- Spring Boot -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

2. 配置Redis

在application.properties或application.yml中配置Redis连接信息:

# Redis configuration
spring.redis.host=localhost
spring.redis.port=6379
spring.redis.database=0
spring.redis.timeout=5000

3. 商品实体类

创建商品实体类,用于表示商品信息:

public class Goods {
    private Long id;
    private String name;
    private double price;
    // 省略构造函数、getter和setter等
}

4. 商品服务

创建商品服务类,负责从数据库中获取商品信息并进行缓存:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;
import java.util.concurrent.TimeUnit;
@Service
public class GoodsService {
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;
    // 模拟从数据库中获取商品信息
    public Goods getGoodsById(Long goodsId) {
        // 实际中可以从数据库中查询商品信息
        Goods goods = new Goods();
        goods.setId(goodsId);
        goods.setName("Sample Goods");
        goods.setPrice(99.99);
        return goods;
    }
    // 获取商品信息,并进行缓存
    public Goods getCachedGoodsById(Long goodsId) {
        // 先尝试从缓存中获取商品信息
        Goods cachedGoods = (Goods) redisTemplate.opsForValue().get("goods:" + goodsId);
        // 如果缓存中不存在,则从数据库中获取,并放入缓存
        if (cachedGoods == null) {
            cachedGoods = getGoodsById(goodsId);
            // 将商品信息缓存到Redis中,设置过期时间为10分钟
            redisTemplate.opsForValue().set("goods:" + goodsId, cachedGoods, 10, TimeUnit.MINUTES);
        }
        return cachedGoods;
    }
}

5. 控制层

在控制层中调用商品服务,获取商品信息:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class GoodsController {
    @Autowired
    private GoodsService goodsService;
    @GetMapping("/goods/{id}")
    public Goods getGoodsById(@PathVariable Long id) {
        return goodsService.getCachedGoodsById(id);
    }
}

在上述代码中,getCachedGoodsById方法先尝试从Redis缓存中获取商品信息,如果缓存中不存在,则从数据库中获取并放入缓存中。这样,下一次获取相同商品信息时就可以直接从Redis缓存中读取,避免频繁访问数据库。

6. 验证

运行应用程序,访问/goods/{id}接口,可以通过该接口获取商品信息,首次获取时从数据库中读取并放入Redis缓存,后续获取时直接从缓存中读取。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2天前
|
缓存 NoSQL Java
使用Redis进行Java缓存策略设计
【4月更文挑战第16天】在高并发Java应用中,Redis作为缓存中间件提升性能。本文探讨如何使用Redis设计缓存策略。Redis是开源内存数据结构存储系统,支持多种数据结构。Java中常用Redis客户端有Jedis和Lettuce。缓存设计遵循一致性、失效、雪崩、穿透和预热原则。常见缓存模式包括Cache-Aside、Read-Through、Write-Through和Write-Behind。示例展示了使用Jedis实现Cache-Aside模式。优化策略包括分布式锁、缓存预热、随机过期时间、限流和降级,以应对缓存挑战。
|
11天前
|
存储 缓存 NoSQL
Java手撸一个缓存类似Redis
`LocalExpiringCache`是Java实现的一个本地缓存类,使用ConcurrentHashMap存储键值对,并通过ScheduledExecutorService定时清理过期的缓存项。类中包含`put`、`get`、`remove`等方法操作缓存,并有`clearCache`方法来清除过期的缓存条目。初始化时,会注册一个定时任务,每500毫秒检查并清理一次过期缓存。单例模式确保了类的唯一实例。
11 0
|
1月前
|
缓存 NoSQL Java
spring cache整合redis实现springboot项目中的缓存功能
spring cache整合redis实现springboot项目中的缓存功能
45 1
|
1月前
|
缓存 NoSQL 数据库
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
|
存储 NoSQL 算法
Redis之小对象压缩
Redis之小对象压缩
834 1
|
8天前
|
NoSQL Linux Redis
06- 你们使用Redis是单点还是集群 ? 哪种集群 ?
**Redis配置:** 使用哨兵集群,结构为1主2从,加上3个哨兵节点,总计分布在3台Linux服务器上,提供高可用性。
17 0
|
16天前
|
负载均衡 监控 NoSQL
Redis的集群方案有哪些?
Redis集群包括主从复制(基础,手动故障恢复)、哨兵模式(自动高可用)和Redis Cluster(官方分布式解决方案,自动分片和容错)。此外,还有如Codis、Redisson和Twemproxy等第三方工具用于代理和负载均衡。选择方案需考虑应用场景、数据规模和并发需求。
17 2
|
22天前
|
NoSQL Redis
Redis集群(六):集群常用命令及说明
Redis集群(六):集群常用命令及说明
15 0
|
2月前
|
运维 NoSQL 算法
Redis-Cluster 与 Redis 集群的技术大比拼
Redis-Cluster 与 Redis 集群的技术大比拼
46 0
|
16天前
|
NoSQL Java 测试技术
面试官:如何搭建Redis集群?
**Redis Cluster** 是从 Redis 3.0 开始引入的集群解决方案,它分散数据以减少对单个主节点的依赖,提升读写性能。16384 个槽位分配给节点,客户端通过槽位信息直接路由请求。集群是无代理、去中心化的,多数命令直接由节点处理,保持高性能。通过 `create-cluster` 工具快速搭建集群,但适用于测试环境。在生产环境,需手动配置文件,启动节点,然后使用 `redis-cli --cluster create` 分配槽位和从节点。集群动态添加删除节点、数据重新分片及故障转移涉及复杂操作,包括主从切换和槽位迁移。
28 0
面试官:如何搭建Redis集群?

热门文章

最新文章