当前位置: 首页 > news >正文

基于SpringBoot的Redis开发实战教程

配置和集成缓存涉及多个步骤,从选择适当的缓存技术到实现缓存的存取操作。以下是具体的步骤和示例,假设我们使用Redis作为缓存工具,并基于Spring Boot进行开发。

1. 选择和配置缓存技术

a. 选择缓存工具
  • Redis 是一个流行的内存数据结构存储工具,适用于各种缓存需求。
b. 添加依赖

在你的Spring Boot项目中,添加Redis相关的依赖。以下是使用Maven的示例:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId>
</dependency>
c. 配置Redis

application.propertiesapplication.yml 文件中配置Redis连接:

application.properties 示例:

spring.redis.host=localhost
spring.redis.port=6379

application.yml 示例:

spring:redis:host: localhostport: 6379

2. 配置Spring Boot集成Redis

a. 创建Redis配置类

创建一个Redis配置类,配置RedisTemplate和相关的序列化设置:

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {RedisTemplate<String, Object> template = new RedisTemplate<>();template.setConnectionFactory(factory);template.setKeySerializer(new StringRedisSerializer());template.setValueSerializer(new GenericToStringSerializer<>(Object.class));return template;}@Beanpublic LettuceConnectionFactory redisConnectionFactory() {return new LettuceConnectionFactory();}
}
b. 使用RedisTemplate进行缓存操作

创建服务类来实现缓存操作,包括缓存的存取:

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 CachedProductService {@Autowiredprivate RedisTemplate<String, Object> redisTemplate;private static final String PRODUCT_KEY_PREFIX = "product:";public Product getProduct(Long id) {String key = PRODUCT_KEY_PREFIX + id;Product product = (Product) redisTemplate.opsForValue().get(key);if (product == null) {// Cache miss: retrieve data from the databaseproduct = fetchProductFromDatabase(id);// Store data in the cacheredisTemplate.opsForValue().set(key, product, 1, TimeUnit.HOURS);}return product;}public void addProduct(Product product) {// Save product to the databasesaveProductToDatabase(product);// Invalidate cacheredisTemplate.delete(PRODUCT_KEY_PREFIX + product.getId());}public void updateProduct(Product product) {// Update product in the databaseupdateProductInDatabase(product);// Update cacheredisTemplate.opsForValue().set(PRODUCT_KEY_PREFIX + product.getId(), product, 1, TimeUnit.HOURS);}public void deleteProduct(Long id) {// Delete product from the databasedeleteProductFromDatabase(id);// Remove from cacheredisTemplate.delete(PRODUCT_KEY_PREFIX + id);}private Product fetchProductFromDatabase(Long id) {// Implement database fetch logicreturn new Product(); // Placeholder}private void saveProductToDatabase(Product product) {// Implement database save logic}private void updateProductInDatabase(Product product) {// Implement database update logic}private void deleteProductFromDatabase(Long id) {// Implement database delete logic}
}

3. 实现缓存操作

a. 存取缓存
  • 存取数据:使用 redisTemplate.opsForValue().get(key) 从缓存中读取数据,使用 redisTemplate.opsForValue().set(key, value, timeout, unit) 将数据存入缓存。
b. 缓存失效
  • 过期时间:在将数据存入缓存时设置过期时间,以避免缓存数据过期。
c. 缓存更新和删除
  • 更新缓存:在数据更新或删除时,确保缓存中的数据也被相应更新或删除。

4. 测试和优化

a. 测试
  • 单元测试:编写测试用例,验证缓存操作是否正常工作。

    @SpringBootTest
    public class CachedProductServiceTests {@Autowiredprivate CachedProductService cachedProductService;@Testpublic void testGetProduct() {Product product = cachedProductService.getProduct(1L);assertNotNull(product);}@Testpublic void testAddProduct() {Product product = new Product();cachedProductService.addProduct(product);// Verify product addition logic}@Testpublic void testUpdateProduct() {Product product = new Product();cachedProductService.updateProduct(product);// Verify product update logic}@Testpublic void testDeleteProduct() {cachedProductService.deleteProduct(1L);// Verify product deletion logic}
    }
    
b. 优化
  • 缓存配置:根据实际使用情况调整缓存大小、过期时间等配置。
  • 监控和分析:监控缓存命中率和性能,进行优化。

通过以上步骤,你可以成功配置和集成缓存,并定义缓存操作。这将显著提升数据服务的性能和响应速度,同时减轻数据库的负担。

http://www.lryc.cn/news/418984.html

相关文章:

  • mysql 分区操作
  • [网鼎杯 2018]Comment
  • LVS详解
  • Yolo-World初步使用
  • Navicat Premium使用
  • LLC数字控制TMS320F28034,4-DSP的epwm配置介绍
  • MongoDB学习记录
  • vlunstack-2(复现红日安全-ATT CK实战)
  • 【生信入门】预览快速体验Linux-重生之小明闯Linux
  • 用.net core简易搭建webapi托管到IIS
  • 【计算机网络---OSI七层模型】
  • Error updating database. Cause: org.apache.shiro.UnavailableSecurity
  • 【网络安全】本地文件包含及远程文件包含漏洞详解
  • redis启动的三种方式
  • 手机怎么远程控制电脑屏幕?手机远程控制电脑方法分享
  • NET的全称、主要功能以及在计算机网络中的作用?
  • LLM - 使用 HuggingFace + Ollama 部署最新大模型 (GGUF 格式 与 Llama 3.1)
  • 如何实现Redis和Mysql中数据双写一致性
  • three.js 模型高亮效果实现说明(结合react)
  • 入营测评题解
  • 制造知识普及(十)-- 常见的工业软件介绍
  • Windows系统设置网络IPv4和IPv6优先访问级
  • yolov8 剪枝 - DepGraph
  • 【网络】套接字socket编程预备知识
  • 【学习笔记】Day 8
  • springboot整合libreoffice(两种方式,使用本地和远程的libreoffice);docker中同时部署应用和libreoffice
  • 从入门到精通:大学生编程技能提升全攻略
  • C# .NET Framework的特殊委托
  • C# 判断电脑是否联网
  • 爬虫解析代码结构