范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

Redis高可用原理

  Redis 的高可用,太重要啦!之前找工作面试,这个问题面试的频率都能排到前几,尤其是一些大厂,先不要着急看文章,如果面试官给你抛这么个问题,你会怎么回答呢,可以先想 5 分钟。
  这里要等待 5 分钟 ...
  其实我也可以偷个懒,完全转载其它博客,但是没有找到我想要的,为了不辜负广大粉丝,楼哥还是单独给大家写一篇,主要根据这块知识,再结合之前的一些面试情况,给大家唠唠。1. Redis 分片策略1.1 Hash 分片
  我们都知道,对于 Redis 集群,我们需要通过 hash 策略,将 key 打在 Redis 的不同分片上。
  假如我们有 3 台机器,常见的分片方式为 hash(IP)%3,其中 3 是机器总数。
  目前很多小公司都这么玩,上手快,简单粗暴,但是这种方式有一个致命的缺点:当增加或者减少缓存节点时,总节点个数发生变化,导致分片值发生改变,需要对缓存数据做迁移。
  那如何解决该问题呢,答案是一致性 Hash。1.2 一致性 Hash
  一致性哈希算法是 1997 年由麻省理工学院提出的一种分布式哈希实现算法。
  环形空间:按照常用的 hash 算法来将对应的 key 哈希到一个具有 2^32 次方个桶的空间中,即 0~(2^32)-1 的数字空间中,现在我们可以将这些数字头尾相连,想象成一个闭合的环形。
  Key 散列 Hash 环:现在我们将 object1、object2、object3、object4 四个对象通过特定的 Hash 函数计算出对应的 key 值,然后散列到 Hash 环上。
  机器散列 Hash 环:假设现在有 NODE1、NODE2、NODE3 三台机器,以顺时针的方向计算,将所有对象存储到离自己最近的机器中,object1 存储到了 NODE1,object3 存储到了 NODE2,object2、object4 存储到了 NODE3。
  节点删除:如果 NODE2 出现故障被删除了,object3 将会被迁移到 NODE3 中,这样仅仅是 object3 的映射位置发生了变化,其它的对象没有任何的改动。
  添加节点:如果往集群中添加一个新的节点 NODE4,object2 被迁移到了 NODE4 中,其它对象保持不变。
  通过对节点的添加和删除的分析,一致性哈希算法在保持了单调性的同时,还使数据的迁移达到了最小,这样的算法对分布式集群来说是非常合适的,避免了大量数据迁移,减小了服务器的的压力。
  如果机器个数太少,为了避免大量数据集中在几台机器,实现平衡性,可以建立虚拟节点(比如一台机器建立 3-4 个虚拟节点),然后对虚拟节点进行 Hash。2. 高可用方案
  很多时候,公司只给我们提供一套 Redis 集群,至于如何计算分片,我们一般有 2 套成熟的解决方案。
  客户端方案:也就是客户端自己计算 Redis 分片,无论你使用Hash 分片,还是一致性 Hash,都是由客户端自己完成。
  客户端方案简单粗暴,但是只能在单一语言系统之间复用,如果你使用的是 PHP 的系统,后来 Java 也需要使用,你需要用 Java 重新写一套分片逻辑。
  为了解决多语言、不同平台复用的问题,就衍生出中间代理层方案。
  中间代理层方案:将客户端解决方案的经验移植到代理层中,通过通用的协议(如 Redis 协议)来实现在其他语言中的复用,用户无需关心缓存的高可用如何实现,只需要依赖你的代理层即可。
  代理层主要负责读写请求的路由功能,并且在其中内置了一些高可用的逻辑。
  你可以看看,你们公司的 Redis 使用的是哪种方案呢?对于"客户端方案",其实有的也不用自己去写,比如负责维护 Redis 的部门会提供不同语言的 SDK,你只需要去集成对应的 SDK 即可。3. 高可用原理3.1 Redis 主从
  Redis 基本都通过"主 - 从"模式进行部署,主从库之间采用的是读写分离的方式。
  同 MySQL 类似,主库支持写和读,从库只支持读,数据会先写到主库,然后定时同步给从库,具体的同步规则,主要将 RDB 日志从主库同步给从库,然后从库读取 RDB 日志,这里比较复杂,其中还涉及到 replication buffer,就不再展开。
  这里有个问题,一次同步过程中,主库需要完成 2 个耗时操作:生成 RDB 文件和传输 RDB 文件。
  如果从库数量过多,主库忙于 fock 子进程生成 RDB 文件和数据同步,会阻塞主库正常请求。
  这个如何解决呢?答案是 "主 - 从 - 从" 模式。
  为了避免所有从库都从主库同步 RDB 日志,可以借助从库来完成同步:比如新增 3、4 两个 Slave,可以等 Slave 2 同步完后,再通过 Slave 2 同步给 Slave 3 和 Slave 4。
  如果我是面试官,我可能会继续问,如果数据同步了 80%,网络突然中断,当网络后续又恢复后,Redis 会如何操作呢?3.2 Redis 分片
  这个有点像 MySQL 分库分表,将数据存储到不同的地方,避免查询时全部集中到一个实例。
  其实还有一个好处,就是数据进行主从同步时,如果 RDB 数据过大,会严重阻塞主线程,如果用分片的方式,可以将数据分摊,比如原来有 10 GB 的数据,分摊后,每个分片只有 2 GB。
  可能有同学会问,Redis 分片,和"主 - 从"模式有啥关系呢? 你可以理解,图中的每个分片都是主库,每个分片都有自己的"主 - 从"模式结构。
  那么数据如何找到对应的分片呢,前面其实已经讲过,假如我们有 3 台机器,常见的分片方式为 hash(IP)%3,其中 3 是机器总数,hash 值为机器 IP,这样每台机器就有自己的分片号。
  对于 key,也可以采用同样的方式,找到对应的机器分片号 hash(key)%3,hash 算法有很多,可以用 CRC16(key),也可以直接取 key 中的字符,通过 ASCII 码转换成数字。3.3 Redis 哨兵机制3.3.1 什么是哨兵机制 ?
  在主从模式下,如果 master 宕机了,从库不能从主库同步数据,主库也不能提供读写功能。
  怎么办呢 ?这时就需要引入哨兵机制 !
  哨兵节点是特殊的 Redis 服务,不提供读写服务,主要用来监控 Redis 实例节点。
  那么当 master 宕机,哨兵如何执行呢?3.3.2 判断主机下线
  哨兵进程会使用 PING 命令检测它自己和主、从库的网络连接情况,用来判断实例的状态,如果哨兵发现主库或从库对 PING 命令的响应超时了,哨兵就会先把它标记为"主观下线"。
  那是否一个哨兵判断为"主观下线",就直接下线 master 呢?
  答案肯定是不行的,需要遵循 "少数服从多数" 原则:有 N/2+1 个实例判断主库"主观下线",才判定主库为"客观下线"。
  比如上图有 3 个哨兵,有 2 个判断 "主观下线",那么就标记主库为 "客观下线"。3.3.3 选取新主库
  我们有 5 个从库,需要选取一个最优的从库作为主库,分 2 步:筛选:检查从库的当前在线状态和之前的网络连接状态,过滤不适合的从库;打分:根据从库优先级、和旧主库的数据同步接近度进行打分,选最高分作为主库。
  如果分数一致怎么办 ? Redis 也有一个策略:ID 号最小的从库得分最高,会被选为新主库。
  当 slave 3 选举为新主库后,会通知其它从库和客户端,对外宣布自己是新主库,大家都得听我的哈!
  今天就讲这么多,我们下期见,大家都学废了么 ?
  作者:楼仔
  原文出处:https://juejin.cn/post/7115001649189355556

夫妻合谋骗公款带情人迪拜度假!体坛又一大鱼被查,比李铁还坏体总局又一大鱼被查!夫妻合谋骗公款,伪造邀请函带情人迪拜度假自从李铁被带走调查后,中国足坛便掀起一场反贪风暴,如今正在朝着整个中国体坛蔓延。而在这个过程中,前橄榄球运动员刘凯利用自iOS17将放弃这些机型!iOS17和iPadOS17将放弃对iPhone8iPhone8PlusiPhoneX第一代9。7英寸和12。9英寸iPadPro以及第五代iPad的支持。次列表中的设备与2015魔都上海十大超级富豪,你知道几个?上海,简称沪或申,是中华人民共和国直辖市国家中心城市超大城市,中华人民共和国国务院批复确定的中国国际经济金融贸易航运科技创新中心,中国历史文化名城。上海市总面积6340。5平方千米打卡新工体!中超联赛揭幕,韦唯时隔33年在工体再唱亚洲雄风来源环球时报环球时报报道记者卢文骜新赛季中超联赛15日晚在改造复建后的工人体育场举行开幕式。歌手韦唯时隔33年再次在工体唱响亚洲雄风,引发全场欢呼。其间,来自16支中超俱乐部青年队大义灭亲!篮协开重磅罚单后,姚明首度发声这是个痛心的决定4月17日,中国篮协针对CBA季后赛江苏与上海的默契球事件,开出了重磅罚单。两队不仅被取消了本赛季参赛资格,而且各罚500万。同时,两家俱乐部的主教练以及总经理,也都受到了不同程度球迷回来了!中超首轮上座率超过2019年,多场比赛爆满中超联赛时隔三个赛季后终于回归主客场上周末,首轮中超分别进行了4场比赛,数据统计显示,2023中超第1轮8场比赛累计上座191553人次,平均上座23944人。在上一个主客场的20浓眉八村塁手机里存着扣我的视频,没事就给里夫斯看NBA季后赛第二日,西部第七的湖人客场128112击败灰熊,系列赛1比0领先。安东尼戴维斯本场比赛17投10中得到22分12个篮板3次助攻3次抢断7次封盖。7次封盖创造了戴维斯季后徐州云龙湖发生翻船事件4游客落水均无大碍网友爆料,4月15日下午,位于徐州市区的云龙湖上发生一起翻船事件,四名游客驾乘电动游船返回码头时发生翻船,船上人员全部落入水中。4月16日,记者核实了解到,当天下午因突遭大风,云龙淄博烧烤爆火!有游客买饼被宰有游客称遇强制消费烧烤周边火爆有小饼厂家机器快冒烟了中国经济周刊经济网讯3月以来,淄博烧烤持续爆火。热度不单单停留在烤串上。在当地政府的迅速行动下,淄博开通了烧烤公交专线淄博烧烤节淄博政府反应好快等话题持续发酵,将淄博的热度推向新高迎客潮玩三月三广西准备好了!外地游客做桂客本地人享周边游今年壮族三月三假期广西呈现双向旅游热特点外地游客做桂客本地人享周边游滚绣球也很开心今年壮族三月三放3天假(4月21日至23日),这是广西人专属的假期。壮族三月三,你在广西唱山歌,还黄山风景区2022年接待游客139。69万人大皖新闻讯4月15日,上海证券交易所发布了上市公司黄山旅游发展股份(下称黄山旅游)2022年年度报告(及年报摘要)。报告期内,黄山景区累计接待进山游客139。69万人,较上年同期1
印度的雨季一年有春夏秋冬四个季节,春暖花开,夏日炎炎,秋高气爽,冬雪皑皑。在出国之前,一直认为其他国家的气候也是这样划分的四季,其实并不然,比如印度就没有春夏秋冬。印度的气候可分为三类热季,爱生活爱旅行就在捷途X70!奇瑞控股捷途首款车型捷途X70(图片配置询价)在华山自驾游营地宣布正式上市,本次在西北区域共推出8款车型,产品售价区间为6。99万元12。09万元。活动当日,奇瑞控股集团有限公司捷六月自驾游,少山底下吃大杏自驾云游季青岛少山脚下除了千年古寺法海寺,还有种植了600多年的少山杏好像每个城市都有那么几个所谓当地人不去,外地人挤着去的地方。青岛的少山脚下除了千年古寺法海寺,还有六月里的少山甲状腺结节天敌找到了,不是花生,空闲时多吃,结节散得快花生是一种常见的坚果食品,富含蛋白质,具有很高的药用价值。吃花生有利于人体补充营养,提供能量。那么甲状腺结节患者可以吃花生吗?吃花生可以消散结节吗?甲状腺结节患者可以吃花生,但一定肖复兴古柏树下和其他公园相比,早春时节的天坛,除了零星的迎春花开之外,没有其他的花开,斋宫里的玉兰,也要等到三月末了,有名的西府海棠,要到四月中旬才能见了。灰蒙蒙的天坛,这时候靠古树提气。这确实新疆乌伦古湖现风积冰山奇观进入四月,随着气温不断升高,新疆阿勒泰地区福海县乌伦古湖冰面开始消融,岸边出现了风积冰山的奇观。图为乌伦古湖现风积冰山奇景(庄晓颇摄)4月12日,在乌伦古湖黄金海岸景区内,从空中俯50岁以后,如果不差钱,这3种茶能不喝就不喝,千万别不当回事经常听人说每天一杯茶,活到98!这到底是真是假?喝茶真的有这么神奇吗?相信很多人应该都会有这样的疑问,其实啊,真的不要过于神化茶叶,它就是一种饮品嘛!但不得不说,相对于别的饮料来说50岁后,人人都该定期做体检,提醒少做无效体检,也别过度体检相信很多人对于定期体检这四个字已经耳熟能详了,关注养生保健的人,就会定期去体检,他们对自己的健康会比较在意。当然,更多的人是觉得定期体检没有必要,是既浪费钱又浪费精力的多余事,对于晨起一杯淡盐水的养生真相,你还在傻傻坚持吗?告诉你一个遗憾的消息你苦苦坚持几年的好习惯,可能是错的!有一个养生方是这么说的晨起喝一杯淡盐水,通便又排毒。实际上空腹喝淡盐水非但不能防便秘还可能对健康造成威胁从理论上讲,盐水有钠盘点消失的童年零食,吃过的人现在都老了,来看看有你的童年吗?在过去生活困难的日子里,温饱尚成问题零食更是奢侈品,逢年过节能吃上一块糖对于孩子来说就已经是件幸福的事了,后来随着生活的改善各种零食如雨后春笋般出现,特别是八九十年代那时品牌没那么超市碰见这4类白酒别放过!都是好喝不贵的极品佳酿,行家整箱搬白酒,堪称我国经久不衰的饮品之一。心情畅快时要喝酒,心情不畅时要喝酒,亲友聚餐,商务宴请还要喝酒,对白酒爱好者来说,一杯好酒就是对他最大的敬意。什么才叫极品佳酿?我认为是纯粮酿造,