大街网Redis集群实践与挑战:从单节点到RedisCluster
版权申诉
46 浏览量
更新于2024-07-08
收藏 6.89MB PDF 举报
DTCC2016会议中,代晓磊分享了大街网在使用Redis缓存技术上的实践历程。起初,大街网采用单节点的Redis实现,通过LVS负载均衡器、Keepalive心跳检测以及主从复制架构,允许程序通过域名VIP和端口访问Redis。这种方式存在单点故障风险,只有当主服务器全盘失效才会触发备份。
进一步,大街网尝试了自建hash集群,利用多个Redis节点通过一致性哈希算法分散数据。这种架构避免了单节点性能瓶颈,但中间层负责hash路由规则导致程序复杂度增加,并未完全解决高可用问题,因为任何一个节点的故障都会影响整体服务。
随着业务需求的增长,大街网引入了RedisCluster。RedisCluster的优势在于其高可用性、高性能、扩展性好,支持在线分片,并提供了丰富的集群管理命令。然而,它也存在局限,如不支持多keys操作,仅使用0号数据库,且在大规模线上应用中可能存在未知的问题。
在大街网的实际应用中,RedisCluster集群每天处理超过20亿次命令,涉及300多个实例,分布在几十台服务器上,占用的内存达到了1TB。集群设计采用了基于配置中心的方式,确保即使部分服务器故障,也能通过至少一个可用链接保持服务连续性。此外,为了减少业务间的干扰,大街网按照业务逻辑划分了不同的RedisCluster集群。
然而,在实践中,大街网遇到了一些挑战,比如如何设置最大内存限制、内存过期策略,以及优化keys过期时间以降低内存碎片率。这些细节管理和优化对于保证Redis集群的稳定性和性能至关重要。
总结来说,代晓磊的分享详细阐述了大街网在Redis缓存技术从单节点到hash集群,再到RedisCluster的演进过程,以及在此过程中遇到的关键问题和解决方案,为其他企业在类似场景下的决策和实践提供了有价值的参考。
2017-12-14 上传
2019-05-22 上传
2019-05-21 上传
2019-05-21 上传
2015-04-28 上传
2015-04-28 上传
2021-12-15 上传
qishuying1022
- 粉丝: 0
- 资源: 6万+
最新资源
- C语言快速排序算法的实现与应用
- KityFormula 编辑器压缩包功能解析
- 离线搭建Kubernetes 1.17.0集群教程与资源包分享
- Java毕业设计教学平台完整教程与源码
- 综合数据集汇总:浏览记录与市场研究分析
- STM32智能家居控制系统:创新设计与无线通讯
- 深入浅出C++20标准:四大新特性解析
- Real-ESRGAN: 开源项目提升图像超分辨率技术
- 植物大战僵尸杂交版v2.0.88:新元素新挑战
- 掌握数据分析核心模型,预测未来不是梦
- Android平台蓝牙HC-06/08模块数据交互技巧
- Python源码分享:计算100至200之间的所有素数
- 免费视频修复利器:Digital Video Repair
- Chrome浏览器新版本Adblock Plus插件发布
- GifSplitter:Linux下GIF转BMP的核心工具
- Vue.js开发教程:全面学习资源指南