设为首页 收藏本站
查看: 781|回复: 0

[经验分享] 美团在Redis上踩过的一些坑-5.redis cluster遇到的一些问题

[复制链接]

尚未签到

发表于 2018-11-3 07:58:35 | 显示全部楼层 |阅读模式
  转载请注明出处哈:http://carlosfu.iteye.com/blog/2254154
   
  由于演讲时间有限,有关Redis-Cluster,演讲者没做太多介绍,简单的介绍了一些Redis-Cluster概念作用和遇到的两个问题,我们在Redis-Cluster也有很多运维经验,将来的文章会介绍。
  但是讲演者反复强调,不要听信网上对于Redis-Cluster的毁谤(实践出真知),对于这一点我很赞同,我们从Redis-Cluster beta版 RC1~4 到现在的3.0-release均没有遇到什么大问题(线上维护600个实例)。
  一、Redis-Cluster
  有关Redis-Cluster的详细介绍有很多这里就不多说了,可以参考:
  1. redis-cluster研究和使用
  2. Redis Cluster 3.0.5集群实践
  3. 本博客的一些Redis-Cluster的介绍(未更新完毕)
  4. Redis设计与实现那本书(作者:黄建宏):非常的推荐看这本书。
DSC0000.jpg

  总之Redis-Cluster是一个无中心的分布式Redis存储架构,解决了Redis高可用、可扩展等问题。
DSC0001.jpg

  二、两个问题:
  1. Redis-Cluster主从节点不要在同一个机器部署
  (1) 以我们的经验看redis实例本身基本不会挂掉,通常是机器出了问题(断电、机器故障)、甚至是机架、机柜出了问题,造成Redis挂掉。
  (2) 如果Redis-Cluster的主从都在一个机器上,那么如果这台机器挂了,主从全部挂掉,高可用就无法实现。(如果full converage=true,也就意味着整个集群挂掉)
  (3) 通常来讲一对主从所在机器:不跨机房、要跨机架、可以在一个机柜。
  2. Redis-Cluster误判节点fail进行切换
  (1) Redis-Cluster是无中心的架构,判断节点失败是通过仲裁的方式来进行(gossip和raft),也就是大部分节点认为一个节点挂掉了,就会做fail判定。
  (2) 如果某个节点在执行比较重的操作(flushall, slaveof等等)(可能短时间redis客户端连接会阻塞(redis单线程))或者由于网络原因,造成其他节点认为它挂掉了,会做fail判定。
  (3) Redis-Cluster提供了cluster-node-timeout这个参数(默认15秒),作为fail依据(如果超过15秒还是没反应,就认为是挂掉了),具体可以参考这篇文章:Redis-Cluster的FailOver失败案例分析
  以我们的经验看15秒完全够用。
DSC0002.jpg

  三、未来要介绍的问题:
  1. Redis-Cluster客户端实现Mget操作。
  2. Redis-Cluster--Too many Cluster redirections异常。
  3. Redis-Cluster无底洞问题解析。
  4. 两个Redis-Cluster集群,meet操作问题后的恶果。
  5. Redis-Cluster配置之full converage问题。
  6. Redis-Cluster故障转移测试。
  7. Redis-Cluster常用运维技巧。
  8. Redis-Cluster一键开通。
  9. Redis-Cluster客户端jedis详解。
  四、附赠一些不错的资料:

  •   Redis-Cluster的FailOver失败案例分析
  •   Redis Cluster 迁移遇到的各种坑及解决方案
  •   Redis Cluster架构优化
  •   Redis常见集群方案、Codis实践及与Twemproxy比较
  •   Redis Cluster架构优化
  •   【运维实践】鱼与熊掌:使用redis-cluster需要注意些什么?
  •   Docker及和Redis Cluster的化学反应(上)By 芒果TV
  •   Docker及和Redis Cluster的化学反应(下)By 芒果TV
  •   Redis cluster使用经验——网易有道
  •   Redis Cluster浅析和Bada对比
  •   互联网Redis应用场景探讨
  •   Redis集群技术及Codis实践
  •   谈Twitter的百TB级Redis缓存实践
  •   Hadoop、Spark、HBase与Redis的适用性讨论
  •   Codis作者黄东旭细说分布式Redis架构设计和踩过的那些坑们


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-630025-1-1.html 上篇帖子: redis笔记-对象系统篇 下篇帖子: 部署redis cluster-8227162
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表