This application claims priority to Chinese Patent Application No. 201911161173.0, filed to the China National Intellectual Property Administration on Nov. 24, 2019 and entitled “Method, Apparatus and Device for Determining Cluster Network Card, and Readable Storage Medium”, which is hereby incorporated herein by reference in its entirety.
The disclosure relates to the technical field of distributed storage clusters, more specifically to a method, apparatus and device for determining a cluster network card, and a computer readable storage medium.
A distributed storage cluster is a cluster composed of a plurality of storage node servers, which supports a piece of data to be stored on a plurality of nodes, and each node can acquire complete data through inter-node communication. When a node goes down, complete data recovery can be performed according to a configuration strategy.
In the distributed storage cluster, each node contains a CTDB, which is high-availability management software used to monitor statuses of cluster nodes and allocation of virtual IPs. When a cluster node fails, the virtual IP allocated to this node will drift to other nodes, and read and write services of the failed node will also drift to other nodes accordingly, so that the cluster forms a high-availability cluster. When the node CTDB is started and monitors a cluster network card, each node needs to find the cluster network card of this node, so as to monitor the cluster network card in real time, so that when the cluster network card fails, the CTDB can timely notify the cluster of failover to reduce the impact on services of a client. The cluster network card is a network card used for communication between modules (mainly OSD modules) in the cluster, that is, a network card where a Cluster IP (the IP used for the communication of the OSD modules inside the cluster) is located. However, them is currently no configuration file that indicates which network card on the current node is the cluster network card, and only a network segment of the Cluster IP is known. The OSD will randomly select any IP that uses this network segment during operation.
In conclusion, how to automatically and accurately determine the cluster network card of the node so as to facilitate the real-time monitoring of the cluster network card is a technical problem to be solved urgently by those skilled in the art.
In view of this, the disclosure aims to provide a method, apparatus and device for determining a cluster network card, and a computer readable storage medium, used to automatically and accurately determining a cluster network card of a current node so as to monitor the cluster network card in real time.
In order to achieve the above objective, the disclosure provides the following technical solutions.
A method for determining a cluster network card includes:
Preferably, when the type of the network segment of the Cluster IP is an IPv4 type of network segment, obtaining IPs and network cards corresponding to the type of the network segment of Cluster IP on the current node includes:
Preferably, calculating the network segment of each IP, comparing the network segment of each IP with the address string, and determining the IP corresponding to the same network segment as that of the address string to be a Cluster IP includes:
Preferably, when the type of the network segment of the Cluster IP is an IPv6 type of network segment, obtaining IPs and network cards corresponding to the type of the network segment of Cluster IP on the current node includes:
Preferably, when the IPs and the network cards corresponding to the IPv6 type of network segment on the current node am obtained by means of the getifaddrs function, the method further includes:
Preferably, if the mask length of the IP is consistent with the length of the mask in the network segment of Cluster IP, calculating a network segment of each IP, comparing the network segment of each IP with the address string, and determining the IP corresponding to the same network segment as that of the address string to be a Cluster IP includes:
An apparatus for determining a cluster network card includes:
Preferably, the obtaining module includes:
A device for determining a cluster network card includes:
A computer readable storage medium is provided. The computer readable storage medium stores a computer program; and the computer program implements the steps of any one of the above method for determining a cluster network card when executed by a processor.
The disclosure provides a method, apparatus and device for determining a cluster network card, and a computer readable storage medium. The method includes: reading a network segment of Cluster IP from a configuration file of a current node; determining the type of the network segment of Cluster IP by means of an address string in the network segment of Cluster IP; obtaining IPs and network cards corresponding to the type of the network segment of Cluster IP on the current node; and calculating the network segment of each IP, comparing the network segment of each IP with the address string, determining the IP determined by the same network segment as that of the address string to be a Cluster IP, and determining the network card where the Cluster IP is located to be a cluster network card.
In the above technical solution disclosed by the disclosure, the network segment of Cluster IP is read, and the type of the network segment of Cluster IP is determined by means of the address string in the network segment of Cluster IP; the IPs and the network segments corresponding to the type of the network segment of Cluster IP am obtained; then, the network segment of each IP is calculated, and the IP corresponding to the same network segment as that of the same address string in the network segment of Cluster IP is determined to be the Cluster IP; the network card where the Cluster IP is located is determined to be the cluster network card, so as to automatically find the cluster network card according to the configuration file; the Cluster IP and the cluster network card are accurately determined by means of comparing the network segment of each IP in the current node with the address string in the network segment of Cluster IP, so that it is convenient to monitor the cluster network card in real time; and when the cluster network card fails, the cluster can be timely notified, and failover can be performed, so as to ensure the high availability of the cluster.
In order to describe the embodiments of the disclosure or the technical solutions in the prior art more clearly, drawings required to be used in description of the embodiments or the prior art will be briefly introduced below. Apparently, the drawings in the description below are only some embodiments of the disclosure. Those ordinarily skilled in the art also can obtain other drawings according to the provided drawings without creative work.
The technical solutions in the embodiments of the disclosure in combination with the accompanying drawings of the embodiments of the disclosure. Apparently, the described embodiments are only part of the embodiments of the disclosure, not all embodiments. Based on the embodiments in the disclosure, all other embodiments obtained by those of ordinary skill in the art without creative work shall fall within the protection scope of the disclosure.
Referring to
S11: reading a network segment of Cluster IP from a configuration file of a current node.
When a CTDB of each node of a cluster is started, the network segment of Cluster IP is read from the configuration file of the current node. The network segment includes an address string addrstr and a mask length mask_len (or referred to as a mask and a mask string). Specifically, the form of the network segment of Cluster IP is, for example: 192.168.2.0/24, wherein 192.168.2.0 is the address string addrstr, and 24 is the mask length mask_len.
S12: determining the type of the network segment of Cluster IP by means of an address string in the network segment of Cluster IP.
After the network segment of Cluster IP is read, the network segment of Cluster IP is analyzed to respectively obtain the address string addrstr and the mask length mask_len, and then whether the type of the network segment of Cluster IP is an IPv4 type of network segment or an IPv6 type of network segment is determined by means of the address string in the network segment of Cluster IP.
IPv4 can be expressed as such a format as 100.7.4.2, which occupies 32 bits in total, that is, a length of one integer. IPv6 can be expressed as such a format as 4444:AABB:1A4B::40, which occupies 128 bits in total, that is, a length of four integers. Therefore, when it is determined whether the type of the network segment of the Cluster IP is an IPv4 type of network segment or an IPv6 type of network segment by means of the address string in the network segment of Cluster IP, if there is “:” in the address string addrstr, the type of the network segment can be regarded as an IPv6 type of network segment, otherwise the type of the network segment is regarded as an IPv4 type of network segment.
S13: obtaining IPs and network cards corresponding to the type of the network segment of Cluster IP on the current node.
After it is determined that the type of the network segment of Cluster IP is IPv4, IPs corresponding to all IPv4s in the current node and network cards where the IPs am located (specifically, network card names of the network cards where the IPs are located can be obtained) can be found. Similarly, after it is determined that the type of the network segment of Cluster IP is IPv6, IPs corresponding to all IPv6s in the current node and network cards where the IPs am located (specifically, network card names of the network cards where the IPs are located can be obtained) can be found.
S14: calculating the network segment of each IP, comparing the network segment of each IP with the address string, determining the IP corresponding to the same network segment as that of the address string to be a Cluster IP, and determining the network card where the Cluster IP is located to be a cluster network card.
The network segment of each IP is calculated, the network segment of each IP is compared with the address string in the network segment of Cluster IP, the IP corresponding to the same network segment as that of the address string is determined to be a Cluster IP, and the network card where the IP (i.e., the Cluster IP) is located is determined to be a cluster network card. Considering that the IP of the same network segment is not assigned to different network cards in a normal case during network partitioning of a node, the screened cluster network card is unique.
Therefore, the cluster network card can be automatically screened by the above method, and the cluster network card can be accurately determined. Therefore, the cluster network card can be monitored in real time in the later stage, so that when the cluster network card fails, the cluster can be timely notified, and failover can be performed, thus ensuring the high availability and stability of the cluster. Furthermore, a user does not need to manually configure the cluster network card when using a CTDB cluster network monitoring function. At the same time, various check problems and a configuration error problem possibly caused by the manual configuration of the cluster network card are also avoided. That is, by the above method, the steps of using and configuring the cluster network card monitoring function are simplified. The method for automatically determining the cluster network card supports both IPv4 and IPv6.
In the above technical solution disclosed by the disclosure, the network segment of Cluster IP is read, the type of the network segment of Cluster IP is determined by means of the address string in the network segment of Cluster IP; the IPs and the network segments corresponding to the type of the network segment of Cluster IP are obtained; then, the network segment of each IP is calculated, and the IP corresponding to the same network segment as that of the same address string in the network segment of Cluster IP is determined to be a Cluster IP, and the network card where the Cluster IP is located is determined to be a cluster network card, so as to automatically find the cluster network card according to the configuration file; the Cluster IP and the cluster network card are accurately determined by means of comparing the network segment of each IP in the current node with the address string in the network segment of Cluster IP, so that it is convenient to monitor the cluster network card in real time; and when the cluster network card fails, the cluster can be timely notified, and failover can be performed, so as to ensure the high availability of the cluster.
According to the method for determining a cluster network card provided in the embodiment of the disclosure, when the type of the network segment of the Cluster IP is an IPv4 type of network segment, obtaining IPs and network cards corresponding to the type of the network segment of Cluster IP on the current node may include:
obtaining IPs and network cards corresponding to the IPv4 type of network segment on the current node by means of an ioctl function.
When it is determined that the type of the network segment of the Cluster IP is IPv4, the IPs and the network cards corresponding to the IPv4 type of network segment on the current node can be obtained by means of the ioctl function, so as to improve the efficiency and accuracy of obtaining the IPs and the network cards.
According to the method for determining a cluster network card provided in the embodiment of the disclosure, calculating the network segment of each IP, comparing the network segment of each IP with the address string, and determining the IP corresponding to the same network segment as that of the address string to be a Cluster IP may include:
When the type of the network segment of Cluster IP is IPv4, the process of determining the Cluster IP and the cluster network card is specifically as follows:
The above process may specifically correspondingly refer to
According to the method for determining a cluster network card provided in the embodiment of the disclosure, when the type of the network segment of the Cluster IP is an IPv6 type of network segment, obtaining IPs and network cards corresponding to the type of the network segment of Cluster IP on the current node may include:
According to the method for determining a cluster network card, when the IPs and the network cards corresponding to the IPv6 type of network segment on the current node are obtained by means of the getifaddrs function, the method may further include:
When the IPs and the network cards corresponding to the IPv6 type of network segment on the current node am obtained by means of the getifaddrs function, the getifaddrs function can be used to obtain the mask of each IP at the same time, and the mask length of each IP can be then calculated and is denoted as mask_len_item. Later, the mask length mask_len_item of each IP can be compared with the length mask_len of the mask in the network segment of Cluster IP; if they are inconsistent, it is determined that the IP is not the Cluster IP; and at this time, the IP can be directly discarded, so as to improve the efficiency of determining the Cluster IP and the cluster network card.
According to the method for determining a cluster network card provided in the embodiment of the disclosure, if the mask length of the IP is consistent with the length of the mask in the network segment of Cluster IP, calculating a network segment of each IP, comparing the network segment of each IP with the address string, and determining the IP corresponding to the same network segment as that of the address string to be a Cluster IP may include:
If the mask length mask_len_item of the IP is consistent with the length mask_len of the mask in the network segment of Cluster IP, the process of determining the Cluster IP and the cluster network card is specifically as follows:
The above process may specifically correspondingly refer to
An embodiment of the disclosure further provides an apparatus for determining a cluster network card. Referring to
According to the apparatus for determining a cluster network card provided in the embodiment of the disclosure, the obtaining module 43 may include:
According to the apparatus for determining a cluster network card provided in the embodiment of the disclosure, the second determination module 44 may include:
According to the apparatus for determining a cluster network card provided in the embodiment of the disclosure, the obtaining module 43 may include:
The apparatus for determining a cluster network card provided in one embodiment of the disclosure may further include:
According to the apparatus for determining a cluster network card provided in the embodiment of the disclosure, the second determination module 44 may include:
An embodiment of the disclosure further provides a device for determining a cluster network card. Referring to
An embodiment of the disclosure further provides a computer readable storage medium which stores a computer program. The computer program, when executed by a processor, may implement the following steps:
The descriptions of related parts in the apparatus and device for determining a cluster network card, and the computer readable storage medium provided in the embodiments of the disclosure may refer to the detailed description of the corresponding part in the method for determining a cluster network card provided in the embodiment of the disclosure, and am not repeatedly described here.
It should be noted that in this context, relational terms such as first and second are used merely to distinguish one entity or operation from another entity or operation, instead of necessarily requiring or implying that these entities or operations have any of these actual relationships or orders. The terms “include”, “including” or any other variation thereof are intended to encompass a non-exclusive inclusion, so that elements inherent to a process, method, article, or device of a list of elements am included. Without more restrictions, elements defined by a sentence “includes a/an . . . ” do not exclude that the process, method, object or device that includes the elements still includes other identical elements. In addition, parts of the above technical solutions provided in the embodiments of the disclosure that am consistent with the implementation principles of the corresponding technical solutions in the prior art are not described in detail, so as to avoid redundant descriptions.
The foregoing description of the disclosed embodiments enables those skilled in the art to be able to implement or use the disclosure. Various modifications to these embodiments will be apparent to those skilled in the art, and the general principles defined herein can be implemented in other embodiments without departing from the spirit or scope of the disclosure. Therefore, the disclosure will not be limited to these embodiments shown in this text, but should conform to the widest scope consistent with the principles and novel features disclosed herein.
Number | Date | Country | Kind |
---|---|---|---|
201911161173.0 | Nov 2019 | CN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2020/103698 | 7/23/2020 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2021/098259 | 5/27/2021 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6636499 | Dowling | Oct 2003 | B1 |
6928485 | Krishnamurthy | Aug 2005 | B1 |
7219160 | Buchsbaum | May 2007 | B1 |
7725603 | Kanevsky | May 2010 | B1 |
9479475 | Mazarick | Oct 2016 | B1 |
20030046343 | Krishnamurthy | Mar 2003 | A1 |
20040236991 | Brundridge | Nov 2004 | A1 |
20050198049 | Ho | Sep 2005 | A1 |
20050268151 | Hunt | Dec 2005 | A1 |
20070171842 | Dow | Jul 2007 | A1 |
20130223441 | Meyer | Aug 2013 | A1 |
20140025920 | Stark | Jan 2014 | A1 |
20140153573 | Ramesh | Jun 2014 | A1 |
20140376402 | Dutt | Dec 2014 | A1 |
20150003237 | Guerra | Jan 2015 | A1 |
20150146724 | Leung | May 2015 | A1 |
20150264008 | Li | Sep 2015 | A1 |
20160380984 | Johnson | Dec 2016 | A1 |
20170048223 | Anantha Padmanaban et al. | Feb 2017 | A1 |
20170142016 | Shichino | May 2017 | A1 |
Number | Date | Country |
---|---|---|
102223289 | Oct 2011 | CN |
106412039 | Feb 2017 | CN |
106559246 | Apr 2017 | CN |
107222320 | Sep 2017 | CN |
108989476 | Dec 2018 | CN |
109039723 | Dec 2018 | CN |
109167687 | Jan 2019 | CN |
109474683 | Mar 2019 | CN |
110233767 | Sep 2019 | CN |
110995805 | Apr 2020 | CN |
2012209625 | Oct 2012 | JP |
Entry |
---|
International Search Report, PCT/CN2020/103698, dated Oct. 29, 2020. |
Written Opinion of the International Searching Authority, PCT/CN2020/103698, dated Oct. 29, 2020. |
First Office Action, 201911161173.0, dated May 7, 2021. |
Number | Date | Country | |
---|---|---|---|
20220407839 A1 | Dec 2022 | US |