[发明专利]一种存储系统及存储节点管理方法有效
申请号: | 201611109234.5 | 申请日: | 2016-12-06 |
公开(公告)号: | CN108156203B | 公开(公告)日: | 2021-01-08 |
发明(设计)人: | 丁光凯;汪渭春;林起芊;王伟 | 申请(专利权)人: | 杭州海康威视数字技术股份有限公司 |
主分类号: | H04L29/08 | 分类号: | H04L29/08;G06F16/22;G06F16/23 |
代理公司: | 北京柏杉松知识产权代理事务所(普通合伙) 11413 | 代理人: | 孙翠贤;项京 |
地址: | 310051 浙*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 存储系统 存储 节点 管理 方法 | ||
本发明实施例公开了一种存储系统及存储节点管理方法,系统包括至少两台存储节点:角色信息为管理者的第一存储节点、及角色信息不为管理者的第二存储节点;每台存储节点中运行管理服务;第二存储节点检测到第一存储节点出现故障后,通过各存储节点中运行的管理服务下的选举机制,判断自身角色信息是否为管理者;如果是,判断自身是否配置有访问存储系统的地址信息,如果未配置,则获取并配置地址信息。应用本方案,在作为管理者的存储节点出现故障后,利用各存储节点中运行的管理服务下的选举机制,各存储节点都有可能成为新的管理者,新的管理者配置访问该存储系统的地址信息,该存储系统能够继续提供存储服务;因此,提高了存储系统的可靠性。
技术领域
本发明涉及数据处理技术领域,特别涉及一种存储系统及存储节点管理方法。
背景技术
现有的存储系统一般包括管理节点和存储节点,存储节点为存储数据的物理介质,管理节点对系统中各存储节点存储的数据进行管理。
在一些存储数据量较小的存储系统中,通常不设置独立的管理节点,而是选定一台或少数几台存储节点作为管理者,管理者对存储系统中各存储节点存储的数据进行管理。
上述方案中,管理者数量较少,如果管理者都出现故障,则该存储系统瘫痪,不能继续提供存储服务,也就是说,该存储系统的可靠性较差。
发明内容
本发明实施例的目的在于提供一种存储系统及存储节点管理方法,提高存储系统的可靠性。
为达到上述目的,本发明实施例公开了一种存储系统,包括至少两台存储节点,每台存储节点中运行管理服务;所述至少两台存储节点中包含角色信息为管理者的第一存储节点、及角色信息不为管理者的第二存储节点;
所述第二存储节点,用于检测到所述第一存储节点出现故障后,通过各存储节点中运行的管理服务下的选举机制,判断自身角色信息是否为管理者;如果是,判断自身是否配置有访问所述存储系统的地址信息,如果未配置,则获取并配置所述地址信息。
可选的,所述第二存储节点,还可以用于通过所述选举机制,判断自身是否为临时管理者:
如果是,发起选举,根据每个选举参与者发送的投票信息,确定所述存储系统中各存储节点的角色信息,并利用所述各存储节点中运行的管理服务,对所述各存储节点的角色信息进行标识,以使所述各存储节点根据所述标识确定自身角色信息;
如果否,判断自身是否为选举参与者,如果是选举参与者,在临时管理者发起选举后,将投票信息发送给临时管理者。
可选的,所述第二存储节点,还可以用于在判断自身角色信息不为管理者的情况下,判断自身是否配置有访问所述存储系统的地址信息,如果已配置,则删除所述地址信息。
可选的,所述第二存储节点,还可以用于通过自身运行的管理服务,接收故障提示信息,所述故障提示信息表示所述第一存储节点出现故障;
所述第二存储节点,还可以用于选举结束后,根据自身运行的管理服务中标识的角色信息,判断自身角色信息是否管理者。
可选的,所述第二存储节点,还可以用于通过自身运行的管理服务,接收数据变更信息;根据所述数据变更信息,更新自身存储的数据库。
可选的,所述数据库中存储有所述存储系统中存储数据的索引信息、及所述存储系统中各存储节点的节点信息;
所述第二存储节点,还可以用于根据所述数据变更信息中包含的变更数据的索引信息,更新所述数据库中的索引信息;根据所述数据变更信息中包含的变更存储节点的节点信息,更新所述数据库中的节点信息。
可选的,所述数据库中存储有所述存储系统中存储数据的索引信息、及所述存储系统中各存储节点的节点信息;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州海康威视数字技术股份有限公司,未经杭州海康威视数字技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201611109234.5/2.html,转载请声明来源钻瓜专利网。