Redis触发的主从切换研究
创新互联建站主营望都网站建设的网络公司,主营网站建设方案,成都App定制开发,望都h5微信平台小程序开发搭建,望都网站营销推广欢迎望都等地区企业咨询
Redis是一个开源的,基于内存的数据结构存储系统,被广泛应用于缓存、队列、发布/订阅等场景。Redis中的数据可以被持久化到磁盘中,实现数据的可靠性和持久性。
在Redis中,可以通过主从复制的方式实现数据的高可用性和可扩展性。主从复制中,一个Redis实例扮演主节点的角色,负责处理写请求,而其他Redis实例扮演从节点的角色,负责复制主节点中的数据,并且可以处理读请求。主从复制有助于提升系统的读写性能,并且可以对Redis进行水平扩展。
在主从复制中,一般情况下,主节点是稳定的,从节点是动态的。当主节点发生故障或不可用时,从节点就需要扮演主节点的角色,而这种自动的主从切换是需要保证数据的一致性和正确性的。
Redis中的主从切换是基于Sentinel机制实现的。sentinel是一个专门的进程,负责监控Redis节点的可用性,当主节点不可用时,sentinel会自动将从节点升级为主节点,并且将原本的从节点作为新主节点的从节点,以此来保证系统的可用性。
那么,在Redis中,当主从切换发生时会发生什么呢?我们可以从以下几个方面来分析:
1.判断主节点是否可用。sentinel会定期检测主节点的可用性,如果主节点不可用,则sentinel会发出切换请求。
“`python
class Sentinel:
def check_Master_state(self, master):
“””
检查主节点的状态
“””
try:
ping_result = master.ping()
info_result = master.info(‘replication’)
if ping_result and “role” in info_result and info_result[“role”] == “master”:
return True
except Exception as e:
self.logger.warning(“Error when checking master state: {}”.format(e))
return False
2.选举新的主节点。当sentinel收到切换请求后,会进行一次选举来决定哪个从节点成为新的主节点。sentinel会将收到切换请求的所有从节点进行评分,并选取评分最高的节点作为新的主节点。
```python
class Sentinel:
def elect_new_master(self, sentinel_marks):
"""
选举新的主节点
"""
candidates = set()
for name, marks in sentinel_marks.items():
if marks.get('s_down', 0)
candidates.add(name)
top_score, top_name = None, None
for name in candidates:
try:
info = self.sentinel_conn(name).sentinel_get_master_info(self.master_name)
except:
continue
if info is None:
continue
score = self.master_monitor.monitored_state.score(info, self.sentinels)
if top_score is None or score > top_score:
top_score, top_name = score, name
if top_name:
self.logger.info('Leader sentinel is [%s]', top_name)
return top_name
3.进行主从切换。选举出新的主节点后,sentinel会发出切换命令,执行主从切换。此时,原本的从节点变为新的主节点,而原本的主节点变为从节点。
“`python
class Sentinel:
def flover(self, new_master_addr):
“””
进行主从切换
“””
self.logger.info(“Flover to {}”.format(new_master_addr))
old_master_addr, next_master_addr = self.master_addr, new_master_addr
try:
next_master = redis.StrictRedis.from_url(“redis://{}”.format(next_master_addr))
# 将主节点转为从节点
next_master.slaveof()
# 新主节点已经升级完成
self.master_monitor.set_master(new_master_addr)
self.master_addr = new_master_addr
old_master = redis.StrictRedis.from_url(“redis://{}”.format(old_master_addr))
# 使原主节点成为从节点
if self.slave_of_no_one:
old_master.slaveof()
else:
old_master.slaveof(*self.slave_of_no_one.split())
# sentinel开始新一轮监控
self.master_monitor.reset()
except Exception as e:
self.logger.warning(“flover fl {}”.format(e))
综上所述,Redis中的主从切换是基于sentinel机制实现的,当主节点不可用时,sentinel会自动将从节点升级为主节点,并且将原本的从节点作为新主节点的从节点,以此来保证系统的可用性。通过以上代码的分析,我们可以更深入地了解Redis的主从切换的实现原理,以及如何保证数据的一致性和正确性。
创新互联【028-86922220】值得信赖的成都网站建设公司。多年持续为众多企业提供成都网站建设,成都品牌网站设计,成都高端网站制作开发,SEO优化排名推广服务,全网营销让企业网站产生价值。
当前标题:Redis触发的主从切换研究(redis触发主从切换)
新闻来源:http://www.shufengxianlan.com/qtweb/news40/221090.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联