[发明专利]一种心跳连接的建立方法及装置有效
申请号: | 202010246544.1 | 申请日: | 2020-03-31 |
公开(公告)号: | CN111506263B | 公开(公告)日: | 2022-07-12 |
发明(设计)人: | 金朴堃;杨潇 | 申请(专利权)人: | 新华三技术有限公司成都分公司 |
主分类号: | G06F3/06 | 分类号: | G06F3/06 |
代理公司: | 暂无信息 | 代理人: | 暂无信息 |
地址: | 610000 四川省成都市中国(四川)自由*** | 国省代码: | 四川;51 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 心跳 连接 建立 方法 装置 | ||
1.一种心跳连接的建立方法,其特征在于,所述方法应用于分布式存储系统Ceph集群中的监视器,所述方法包括:
根据Ceph集群的对象存储设备OSD拓扑信息,构建多个由OSD组成的心跳连接环,每个心跳连接环上的每个OSD均从所述Ceph集群中不同的存储节点中的OSD中选择;
将每个心跳连接环上的每个OSD的邻居OSD分别发送给每个OSD,以使每个OSD分别与其邻居OSD建立心跳连接;
其中,根据Ceph集群的OSD拓扑信息,构建多个由OSD组成的心跳连接环,具体包括:
根据Ceph集群的OSD拓扑信息,判断所有存储节点中的OSD的总数量是否均相同;
若是,将每个存储节点中的每个OSD分别与其他存储节点中的一个未被构建过心跳连接环的OSD构建一个第一心跳连接环,其中,不同的第一心跳连接环上的OSD均不相同;
否则,根据每个存储节点中的OSD,构建M个第一心跳连接环和N个第二心跳连接环;
其中,N个第二心跳连接环上的OSD中部分OSD为复用的OSD,每个复用的OSD为复用各自所属存储节点中已构建过心跳连接环的OSD;
M的取值为OSD的数量最少的存储节点中所有OSD的总数量;
N的取值为OSD的数量最多的存储节点中所有OSD的总数量与OSD的数量最少的存储节点中所有OSD的总数量的差值。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
针对所述Ceph集群中的每个心跳连接环,如果确定出该心跳连接环未被标记为用于表征心跳连接环上OSD数量减少的降级状态且发生异常的OSD的数量不小于该心跳连接环上所有OSD的总数量的一半,或者确定出该心跳连接环被标记为降级状态且发生异常的OSD的累计数量不小于该心跳连接环上所有OSD的总数量的一半,则通知该心跳连接环上未发生异常的OSD断开与其邻居OSD之间的连接,并删除该心跳连接环;
如果确定出该心跳连接环未被标记为降级状态且发生异常的OSD的数量小于该心跳连接环上所有OSD的总数量的一半,或者确定出该心跳连接环被标记为降级状态且发生异常的OSD的累计数量小于该心跳连接环上所有OSD的总数量的一半,则判断该心跳连接环上其他未发生异常的OSD是否均为复用的OSD;
若是,则删除该心跳连接环;
否则,进一步判断该心跳连接环上当前发生异常的OSD所属的存储节点中是否存在复用次数不大于设定阈值的OSD;
在判断结果为是时,从复用次数不大于设定阈值的OSD中选择一个OSD替换当前发生异常的OSD,并分别通知该心跳连接环上当前发生异常的OSD的邻居OSD重新与替换后的OSD建立心跳连接;
在判断结果为否时,如果该心跳连接环上未发生异常前所有OSD的总数量为3个,通知该心跳连接环上当前发生异常的OSD的邻居OSD彼此建立心跳连接,并将该心跳连接环标记为降级状态;
如果该心跳连接环上未发生异常前所有OSD的总数量大于3个且该心跳连接环未被标记为降级状态,在当前发生异常的OSD的邻居OSD均正常时,通知当前发生异常的OSD的邻居OSD彼此建立心跳连接,在当前发生异常的OSD为至少两个相邻的OSD时,通知该心跳连接环上至少两个相邻的OSD中邻居OSD为正常的OSD彼此建立心跳连接,并将该心跳连接环标记为降级状态;
如果该心跳连接环上未发生异常前所有OSD的总数量大于3个且该心跳连接环被标记为降级状态,在当前发生异常的OSD的邻居OSD均正常时,通知当前发生异常的OSD的邻居OSD彼此建立心跳连接,在当前发生异常的OSD为至少两个相邻的OSD时,通知该心跳连接环上至少两个相邻发生异常的OSD中邻居OSD为正常的OSD彼此建立心跳连接。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于新华三技术有限公司成都分公司,未经新华三技术有限公司成都分公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010246544.1/1.html,转载请声明来源钻瓜专利网。