建设网站费用计入什么科目山东企业展厅设计公司
news/
2025/10/7 12:16:12/
文章来源:
建设网站费用计入什么科目,山东企业展厅设计公司,网站黏度,浙江省建设厅网站首页缓存技术在现代Web开发中至关重要#xff0c;尤其是在高并发的环境中#xff0c;缓存能够有效减少数据库访问压力、提高系统性能。Redis作为最流行的内存数据存储系统之一#xff0c;常用于缓存管理。本节将讲解如何在Spring Boot项目中集成Redis#xff0c;实现缓存管理尤其是在高并发的环境中缓存能够有效减少数据库访问压力、提高系统性能。Redis作为最流行的内存数据存储系统之一常用于缓存管理。本节将讲解如何在Spring Boot项目中集成Redis实现缓存管理并深入探讨Redis的基础、缓存失效策略以及如何使用Redis构建分布式缓存。 1. Redis基础与Spring Data Redis
1.1 Redis简介
Redis是一个开源的内存数据结构存储系统它可以用作数据库、缓存以及消息队列系统。Redis支持多种数据结构包括字符串String、哈希Hash、列表List、集合Set、有序集合Sorted Set等。Redis的特点是高效、持久化支持、发布订阅机制和简单的API。
1.2 Spring Data Redis
Spring Data Redis是Spring Data项目的一部分旨在简化Redis的使用它封装了Jedis和Lettuce等Redis客户端并提供了与Spring的其他部分如Spring Boot、Spring Cache等无缝集成的功能。通过Spring Data Redis可以轻松实现Redis的存取操作支持常见的数据结构操作。
1.3 配置Redis连接
首先我们需要在Spring Boot项目中配置Redis连接。在application.properties或application.yml文件中进行以下配置
spring:redis:host: localhostport: 6379password: # 如果有密码的话可以配置timeout: 3000jedis:pool:max-active: 10max-idle: 5min-idle: 1max-wait: 2000
这里的配置包括Redis的主机地址、端口、连接池配置等。Spring Boot通过spring-boot-starter-data-redis自动装配了Redis的相关组件。
1.4 RedisTemplate与StringRedisTemplate
Spring Data Redis提供了两个常用的类RedisTemplate和StringRedisTemplate。
RedisTemplate: 用于支持所有类型的Redis数据结构。StringRedisTemplate: 继承自RedisTemplate专门用于操作字符串类型的数据。
通常情况下推荐使用StringRedisTemplate处理简单的字符串缓存RedisTemplate适合处理复杂的数据类型。
2. 在项目中集成Redis缓存
在Spring Boot中集成Redis缓存十分简单Spring Cache提供了对Redis的支持。接下来我们将实现一个简单的缓存管理系统使用Redis作为缓存存储。
2.1 添加依赖
在pom.xml中添加Spring Data Redis和缓存相关的依赖
dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId
/dependency
dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-cache/artifactId
/dependency
2.2 开启缓存支持
在主启动类中例如Application.java开启Spring缓存支持
SpringBootApplication
EnableCaching // 开启缓存支持
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
2.3 使用缓存注解
使用Cacheable注解实现缓存。当某个方法被调用时Spring首先会检查缓存中是否已有数据。如果有直接返回缓存数据如果没有执行方法并将结果存入缓存。
Service
public class ProductService {Cacheable(value products, key #productId)public Product getProductById(Long productId) {// 模拟数据库查询return productRepository.findById(productId).orElseThrow(() - new RuntimeException(Product not found));}
}
在此示例中Cacheable会根据productId作为缓存的键将返回的Product对象存储在products缓存中。如果同样的productId再次被请求Spring会直接从Redis中读取数据。
2.4 缓存管理与清除
除了缓存数据我们还可以使用CachePut来更新缓存使用CacheEvict来清除缓存。
CachePut(value products, key #product.id)
public Product updateProduct(Product product) {return productRepository.save(product);
}CacheEvict(value products, key #productId)
public void deleteProduct(Long productId) {productRepository.deleteById(productId);
}
CachePut: 在每次方法执行后都更新缓存。CacheEvict: 清除缓存当缓存失效时会重新加载数据。
3. 缓存失效策略与分布式缓存
缓存管理不仅仅是将数据存入缓存还需要考虑缓存的失效策略、过期时间设置以及如何实现分布式缓存。
3.1 缓存失效策略
Redis支持多种缓存失效策略常见的有以下几种
设置过期时间使用expire命令设置缓存过期时间。当缓存超过指定时间后Redis会自动删除该缓存项。LRULeast Recently Used淘汰策略Redis支持设置最大内存限制当缓存占用内存达到上限时Redis会根据LRU算法淘汰最久未使用的数据。定期删除Redis会定期扫描缓存删除已经过期的键。
在Spring中可以通过Cacheable的ttl过期时间来配置缓存失效时间。例如缓存15分钟
Cacheable(value products, key #productId, ttl 900)
public Product getProductById(Long productId) {return productRepository.findById(productId).orElseThrow(() - new RuntimeException(Product not found));
}
3.2 分布式缓存设计
在分布式系统中缓存通常不仅仅部署在单个Redis实例上而是需要支持多个Redis节点。Spring Boot通过Redis集群、Redis哨兵等方案支持分布式缓存。
Redis集群通过Redis Cluster可以实现数据的水平分片确保缓存可以跨多个Redis节点分布。Redis哨兵Redis Sentinel可以实现高可用性和自动故障切换。
为了支持分布式缓存我们可以使用Redis Cluster或哨兵的配置来确保高可用性。在application.yml中配置Redis集群
spring:redis:cluster:nodes:- 127.0.0.1:7000- 127.0.0.1:7001- 127.0.0.1:7002password: yourpassword
Spring Boot会自动识别Redis集群配置连接多个Redis节点并进行缓存数据的分布式存储和管理。
3.3 缓存穿透与击穿解决方案
在实际应用中缓存穿透和缓存击穿是两个常见问题
缓存穿透指查询不存在的数据直接访问数据库而绕过缓存。解决方法是使用布隆过滤器Bloom Filter来判断数据是否存在。缓存击穿指缓存中的数据过期后多个请求同时访问该数据导致大量并发请求直接访问数据库。解决方法是使用互斥锁或Cacheable的sync参数确保只有一个请求去加载数据。 总结
本文详细介绍了如何在Spring Boot中集成Redis缓存管理。通过Spring Data Redis能够快速地将Redis引入到Spring Boot应用中实现缓存功能。通过使用Cacheable、CachePut、CacheEvict等注解我们能够方便地管理缓存的增删改查。
此外我们还讨论了Redis的缓存失效策略以及如何设计分布式缓存系统。对于高并发、大规模数据的应用Redis提供的各种缓存策略和高可用性解决方案能够显著提高系统的性能和稳定性。通过合理设计缓存失效策略和处理缓存穿透、缓存击穿等问题我们能够构建一个高效的缓存管理系统。 关于作者
15年互联网开发、带过10-20人的团队多次帮助公司从0到1完成项目开发在TX等大厂都工作过。当下为退役状态写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料需要可联系我
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/930395.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!