Redis性能优化的18招
前言
Redis在我们的日常开发工作中,使用频率非常高,已经变成了必不可少的技术之一。
Redis的使用场景也很多。
比如:保存用户登录态,做限流,做分布式锁,做缓存提升数据访问速度等等。
那么问题来了,Redis的性能要如何优化?
为了充分发挥Redis的性能,这篇文章跟大家一起聊聊Redis性能优化的18招,希望对你会有所帮助。
1. 选择合适的数据结构
Redis支持多种数据结构,如字符串、哈希、列表、集合和有序集合。根据实际需求选择合适的数据结构可以提高性能。
如果要存储用户信息,考虑使用哈希而不是多个字符串:
jedis.hset("user:1001", "name", "Alice");
jedis.hset("user:1001", "age", "30");
这样可以高效地存储和访问多个属性。
2. 避免使用过大的key和value
较长的key和value会占用更多内存,还可能影响性能。
保持key简短,并使用简洁的命名约定。
比如:
将“user:1001:profile”简化为“u:1001:p”。
还可以做压缩等其他优化。
如果对大key问题,比较感兴趣可以看看我的另一篇文章《从2s优化到0.1s,我用了这5步》,里面有非常详细的介绍。
3. 使用Redis Pipeline
对多个命令的批量操作,使用Pipeline可以显著降低网络延迟,提升性能。
比如,批量设置key可以这样做:
Pipeline p = jedis.pipelined();
for (int i = 0; i < 1000; i++) {
p.set("key:" + i, "value:" + i);
}
p.sync();
这样一次性可以发送多个命令,减少了网络往返时间,能够提升性能。
4. 控制连接数量
过多的连接会造成资源浪费,使用连接池可以有效管理连接数量。
比如,使用JedisPool:
JedisPool pool = new JedisPool("localhost");
try (Jedis jedis = pool.getResource()) {
jedis.set("key", "value");
}
有了连接池,这样连接就会被复用,而不是每次都创建新连接,使用完之后,又放回连接池。
能有效的节省连接的创建和销毁时间。
5. 合理使用过期策略
设置合理的过期策略,能防止内存被不再使用的数据占满。
例如,缓存热点数据可以设置过期时间。
比如,对会话数据设置过期时间:
jedis.setex("session:12345", 3600, "data");
Redis内部会定期清理过期的缓存。
6. 使用Redis集群
数据量增大时,使用Redis集群可以将数据分散到多个节点,提升并发性能。
可以将数据哈希分片到多个Redis实例。
这样可以避免单个Redis实例,数据太多,占用内存过多的问题。
7. 充分利用内存优化
选择合适的内存管理策略,Redis支持LRU(Least Recently Used)策略,可以自动删除不常用的数据。
比如,配置Redis的maxmemory:
maxmemory 256mb
maxmemory-policy allkeys-lru
8. 使用Lua脚本
Lua脚本让多条命令在Redis中原子性执行,减少网络延迟。
比如,使用Lua防止多个命令的网络延迟:
EVAL "redis.call('set', KEYS[1], ARGV[1]) return redis.call('get', KEYS[1])" 1 "key" "value"
使用Lua脚本,可以保证Redis的多个命令是原子性操作。
9. 监控与调优
使用INFO命令监控Redis性能数据,如命令支持、内存使用等,及时调优。
比如,使用命令获取监控信息:
INFO memory
INFO clients
10. 避免热点key
热点key会造成单一节点的压力,通过随机化访问来避免。
比如,可以为热点key加随机后缀:
String key = "hotkey:" + (System.currentTimeMillis() % 10);
jedis.incr(key);
11. 使用压缩
存储大对象时,考虑使用压缩技术来节省内存。
比如,可以使用GZIP压缩JSON数据:
byte[] compressed = gzipCompress(jsonString);
jedis.set("data", compressed);
12. 使用Geo位置功能
Redis支持地理位置存储和查询,使用GEOADD可以高效管理地理数据。
比如,存储地点信息:
jedis.geoadd("locations", longitude, latitude, "LocationName");
13. 控制数据的持久化
合理设置RDB和AOF的持久化策略,避免频繁写盘造成性能下降。
示例:
设置持久化的时间间隔:
save 900 1
appendonly yes
14. 尽量减少事务使用
在高并发场景下,避免过度使用MULTI/EXEC,因为事务会锁住key。
可以直接使用单条命令替代事务。
15. 合理配置客户端
调整客户端的连接超时和重连策略,以适应高负载场景,确保连接稳定。
例如:
JedisPoolConfig poolConfig = new JedisPoolConfig();
poolConfig.setMaxTotal(128); // 最大连接数
poolConfig.setMaxIdle(64); // 最大空闲连接
poolConfig.setMinIdle(16); // 最小空闲连接
poolConfig.setTestOnBorrow(true);
poolConfig.setTestOnReturn(true);
poolConfig.setTestWhileIdle(true);
JedisPool jedisPool = new JedisPool(poolConfig, "localhost", 6379, 2000); // 连接超时2000ms
16. 使用Redis Sentinel
使用Sentinel进行监控,实现高可用性,确保系统在故障时能够快速切换。
配置Sentinel进行主从复制。
17. 优化网络配置
保证Redis服务器有良好的网络带宽,避免网络瓶颈。
使用服务器内部专线,减少延迟。
18. 定期清理不必要的数据
生命周期管理很关键,定期删除过期或不必要的数据,保持内存高效利用。
可以设置Cron任务定期清理。
虽说Redis内部会清理过期的数据,但有些长期存在的垃圾数据,也建议及时清理。
总结
以上就是Redis性能优化的18条军规,灵活应用这些策略能够为你的项目带来显著的性能提升。希望能帮助到你,欢迎分享你的优化经验!
最后说一句(求关注,别白嫖我)
如果这篇文章对您有所帮助,或者有所启发的话,帮忙扫描下发二维码关注一下,您的支持是我坚持写作最大的动力。
求一键三连:点赞、转发、在看。
关注公众号:【苏三说技术】,在公众号中回复:进大厂,可以免费获取我最近整理的10万字的面试宝典,好多小伙伴靠这个宝典拿到了多家大厂的offer。
Redis性能优化的18招的更多相关文章
- redis性能优化、内存分析及优化
redis性能优化.内存分析及优化 1.优化网络延时 2.警惕执行时间长的操作 3.优化数据结构.使用正确的算法 4.考虑操作系统和硬件是否影响性能 5.考虑持久化带来的开销 5.1 RDB 全量持久 ...
- 《吐血整理》Redis 性能优化的 13 条军规!史上最全
Redis 是基于单线程模型实现的,也就是 Redis 是使用一个线程来处理所有的客户端请求的,尽管 Redis 使用了非阻塞式 IO,并且对各种命令都做了优化(大部分命令操作时间复杂度都是 O(1) ...
- 吊打面试官系列:Redis 性能优化的 13 条军规大全
1.缩短键值对的存储长度 键值对的长度是和性能成反比的,比如我们来做一组写入数据的性能测试,执行结果如下: 从以上数据可以看出,在 key 不变的情况下,value 值越大操作效率越慢,因为 Redi ...
- redis性能优化——生产中实际遇到的问题排查总结
背景 redis-K,V数据库,因其高性能的操作性和支持丰富的数据结构,目前大量被用于衔接应用层和关系数据库中间的缓存层.随着使用的场景越来越多,和数据量快速的递增,在生产环境中经常会遇到相关的性能瓶 ...
- Redis 性能优化
一.Linux 操作系统 [1]ulimit 与 TCP backlog:1).修改 ulimit:通过 ulimit 修改 open files 参数,redis 建议把 open files 至少 ...
- 大型系统的Redis性能优化
问题描述 系统背景:大型线上Java服务集群(活跃用户数上千万),业务重度使用Redis存储个管理Session,业务并发量>1WQPS,基本上每个请求都需要访问Redis(可能是多次),使用了 ...
- redis性能优化
redis日志截图:
- Redis性能优化之redis.cnf配置参数
redis调优总结 1.相应的参数调优 加内存2.redis使用结构调优3.使用合理的数据类型说明:redis存储的数据为redis hash(字符映射表) 单key多字段结构. 1)调整配置文件中配 ...
- Android 性能优化(18)JNI优化:JNI Tips 提升性能技巧
JNI Tips 1.In this document JavaVM and JNIEnv Threads jclass, jmethodID, and jfieldID Local and Glob ...
- Redis各种数据结构性能数据对比和性能优化实践
很对不起大家,又是一篇乱序的文章,但是满满的干货,来源于实践,相信大家会有所收获.里面穿插一些感悟和生活故事,可以忽略不看.不过听大家普遍的反馈说这是其中最喜欢看的部分,好吧,就当学习之后轻松一下. ...
随机推荐
- dig 使用
dig dig(Domain Information Groper)是一个用于 DNS 查询的命令行工具,广泛用于查看域名系统的相关信息. 基本用法 # 查询域名的 A 记录(IPv4 地址): di ...
- 以Top-Down思维去解决问题——递归
目录 递归的基础 递归的底层实现(不是重点) 递归的应用场景 编程中 两种解决问题的思维 自下而上(Bottom-Up) 自上而下(Top-Down) 自上而下的思考过程--求和案例 台阶问题 案例 ...
- Feign 动态设定服务器名称 与 调用接口
1. 新增编码器(由于使用了动态的Feign,所以不能像正常使用Feign一样指定configuration配置编码器) import feign.RequestTemplate; import fe ...
- sql server create table 给字段添加注释说明
EXEC sys.sp_addextendedproperty @name=N'MS_Description',@level1name=N'a_jcgl_data',@level2name=N'id' ...
- 在stable diffussion中控制生成图片的光线
在摄影中,光线起着至关重要的作用,它对图像的整体质量和氛围有着显著的影响.您可以使用光线来增强主题,创造深度和维度,传达情感,以及突出重要细节. 在这篇文章中,我会告诉你如何在stable diffu ...
- 【题目全解】ACGO排位赛#12
ACGO 排位赛#12 - 题目解析 别问为什么没有挑战赛#11,因为挑战赛#11被贪心的 Yuilice 吃掉了(不是). 本次挑战赛难度相比较前面几次有所提升. 爆料:小鱼现在已经入职了研发部门, ...
- Angular 18+ 高级教程 – Component 组件 の Control Flow
前言 Control Flow 是 Angular v17 版本后推出的新模板语法,用来取代 NgIf.NgForOf.NgSwitch 这 3 个 Structure Directive. Stru ...
- ASP.NET Core – Thread, Task, Async 线程与异步编程
前言 平常写业务代码, 很少会写到多线程. 久了很多东西都忘光光了. 刚好最近在复习 RxJS. 有一篇是讲 scheduler 的. 会讲到 JavaScript 异步相关的资讯. 既然如此那就一次 ...
- BOM – 操作 Query
前言 ASP.NET Core 写过一篇关于操作 query 的 ASP.NET Core – 操作 Uri 和 Query. 前端偶尔也会需要做出 query. URLSearchParams 之前 ...
- nginx缓存加速笔记
目录 1 服务端缓存原理 1.1 定义一个缓存目录 1.2 启用缓存 1.3 Nginx 作反代 1.4 缓存一时爽,全家火葬场. 1.5 ngx_cache_purge 1 服务端缓存原理 主要是缓 ...