[發明專利]一種節點選舉方法及裝置有效
| 申請號: | 201710114257.3 | 申請日: | 2017-02-28 |
| 公開(公告)號: | CN106878083B | 公開(公告)日: | 2019-12-06 |
| 發明(設計)人: | 易莉;張鑫 | 申請(專利權)人: | 新華三技術有限公司 |
| 主分類號: | H04L12/24 | 分類號: | H04L12/24;H04L29/08 |
| 代理公司: | 暫無信息 | 代理人: | 暫無信息 |
| 地址: | 310052 浙*** | 國省代碼: | 浙江;33 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 一種 節點 選舉 方法 裝置 | ||
本發明提供一種節點選舉方法及裝置,應用于集群系統中的任一主控節點,所述方法包括:接收鄰居主控節點發送的握手交互報文,所述握手交互報文攜帶所述鄰居主控節點感知的本主控節點的鄰居狀態;根據所述鄰居主控節點感知的本主控節點的鄰居狀態,更新本地記錄的所述鄰居主控節點的鄰居狀態;根據本地記錄的包括本主控節點在內的主控節點的鄰居狀態,從非初始狀態的主控節點中選舉全局主用主控節點,所述非初始狀態為單向狀態或雙向狀態,其中,本地記錄的本主控節點的鄰居狀態默認為雙向狀態;從除全局主用主控節點以外的鄰居狀態為雙向狀態的主控節點中選舉全局備份主控節點。本發明的選舉過程簡單,易于實現,可有效提高選舉效率。
技術領域
本發明涉及網絡通信技術領域,尤其涉及一種節點選舉方法及裝置。
背景技術
分布式IRF(Intelligent Resilient Framework,智能彈性架構)系統通過交互STM(Stacking Management,堆疊管理)協議報文實現堆疊選舉,堆疊選舉過程涉及大量報文交互以及成員角色狀態遷移,且只有框內本地主用主控節點可以參與選舉,本地備份主控節點只能做數據備份,最終選舉出一個全局主用主控節點和N個全局備份主控節點。
集群系統支持單框、背靠背(B2B)和N+M(N表示交換框數目,M表示線卡框數目)多框。集群系統中各主控節點也需要進行選舉,最終選舉出一個全局主用主控節點、一個全局備份主控節點和N個全局普通主控節點,但目前尚無適用于集群系統的選舉方案。
發明內容
本發明的目的在于提供一種節點選舉方法及裝置,用以簡化節點選舉流程,提高選舉效率。
為實現上述發明目的,本發明提供了如下技術方案:
本發明提供一種節點選舉方法,應用于集群系統中的任一主控節點,所述方法包括:
接收鄰居主控節點發送的握手交互報文,所述握手交互報文攜帶所述鄰居主控節點感知的本主控節點的鄰居狀態;
根據所述鄰居主控節點感知的本主控節點的鄰居狀態,更新本地記錄的所述鄰居主控節點的鄰居狀態;
根據本地記錄的包括本主控節點在內的主控節點的鄰居狀態,從非初始狀態的主控節點中選舉全局主用主控節點,所述非初始狀態為單向狀態或雙向狀態,其中,本地記錄的本主控節點的鄰居狀態默認為雙向狀態;從除全局主用主控節點以外的鄰居狀態為雙向狀態的主控節點中選舉全局備份主控節點。
本發明還提供一種節點選舉裝置,應用于集群系統中的任一主控節點,所述裝置包括:
報文接收單元,用于接收鄰居主控節點發送的握手交互報文,所述握手交互報文攜帶所述鄰居主控節點感知的本主控節點的鄰居狀態;
狀態更新單元,用于根據所述鄰居主控節點感知的本主控節點的鄰居狀態,更新本地記錄的所述鄰居主控節點的鄰居狀態;
全局主選舉單元,用于根據本地記錄的包括本主控節點在內的主控節點的鄰居狀態,從非初始狀態的主控節點中選舉全局主用主控節點,所述非初始狀態為單向狀態或雙向狀態,其中,本地記錄的本主控節點的鄰居狀態默認為雙向狀態;
全局備選舉單元,用于從除全局主用主控節點以外的鄰居狀態為雙向狀態的主控節點中選舉全局備份主控節點。
由以上描述可以看出,本發明中各主控節點通過交互握手交互報文,實現鄰居主控節點的鄰居狀態的更新,并基于獲取的包括本主控節點在內的主控節點的鄰居狀態,完成全局主用主控節點和全局備份主控節點的選舉,該選舉過程報文交互簡單,涉及的鄰居狀態較少,易于實現,可有效提高選舉效率。
附圖說明
圖1是本發明實施例示出的一種節點選舉方法流程圖;
圖2是本發明實施例示出的一種集群系統組網示意圖;
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于新華三技術有限公司,未經新華三技術有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201710114257.3/2.html,轉載請聲明來源鉆瓜專利網。
- 上一篇:一種虛擬網卡熱遷移方法及其裝置
- 下一篇:一種權限控制方法和裝置





