WO2021238672A1 - 表项同步方法、网关设备、组网系统及存储介质 - Google Patents
表项同步方法、网关设备、组网系统及存储介质 Download PDFInfo
- Publication number
- WO2021238672A1 WO2021238672A1 PCT/CN2021/093684 CN2021093684W WO2021238672A1 WO 2021238672 A1 WO2021238672 A1 WO 2021238672A1 CN 2021093684 W CN2021093684 W CN 2021093684W WO 2021238672 A1 WO2021238672 A1 WO 2021238672A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- message
- opposite end
- arp
- entry
- synchronization
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 52
- 230000006855 networking Effects 0.000 title claims abstract description 28
- 230000002776 aggregation Effects 0.000 claims abstract description 27
- 238000004220 aggregation Methods 0.000 claims abstract description 27
- 230000006854 communication Effects 0.000 claims abstract description 22
- 238000004891 communication Methods 0.000 claims abstract description 21
- 230000004044 response Effects 0.000 claims description 90
- 238000004590 computer program Methods 0.000 claims description 17
- 230000005540 biological transmission Effects 0.000 claims description 16
- 238000010586 diagram Methods 0.000 description 5
- 230000008569 process Effects 0.000 description 4
- 239000013589 supplement Substances 0.000 description 3
- 230000006870 function Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000000737 periodic effect Effects 0.000 description 2
- 230000001360 synchronised effect Effects 0.000 description 2
- 230000032683 aging Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/24—Multipath
- H04L45/245—Link aggregation, e.g. trunking
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D30/00—Reducing energy consumption in communication networks
- Y02D30/50—Reducing energy consumption in communication networks in wire-line communication networks, e.g. low power modes or reduced link rate
Definitions
- the present invention relates to the field of communication technology, in particular to an entry synchronization method, gateway equipment, networking system and storage medium.
- Multi-Chassis Link Aggregation Group (MC-LAG, Multi-Chassis Link Aggregation Group) is a networking mechanism that can link one access device with two other gateway devices running MC-LAG devices.
- the two gateway devices will synchronize the entries learned by their respective aggregation ports to the opposite end through the synchronization link to achieve the connection at the forwarding level.
- a negotiation link between the two gateway devices which is generally called a keepalive link, which is used to check the consistency of the configurations of the devices at both ends and negotiate the role of active and standby at the same time.
- the synchronization of the MC-LAG table entries is a trigger synchronization plus a periodic synchronization method. When there is a new entry, it will be synchronized to the remote end immediately. In addition, all entries will be synchronized at regular intervals.
- the data may not be successfully sent or received due to the busy end of the peer or some factors, as well as the problem of repeated data transmission. Therefore, it is necessary to solve the problem of packet loss or multi-packet in the cross-device link aggregation network. .
- the present disclosure provides an entry synchronization method, a gateway device, a networking system and a storage medium, which can improve the communication efficiency in the cross-device link aggregation networking.
- the present disclosure provides an entry synchronization method, the method includes:
- a synchronization message about the target entry is sent to the opposite end.
- the present disclosure also provides a gateway device, the gateway device includes a memory and a processor; the memory is configured to store a computer program; the processor is configured to execute the computer program and execute the The computer program realizes the above-mentioned table item synchronization method.
- the present disclosure also provides a networking system.
- the networking system includes two gateway modules, and the gateway modules are configured to implement the aforementioned entry synchronization method.
- the present disclosure also provides a computer-readable storage medium, the computer-readable storage medium stores a computer program, and when the computer program is executed by a processor, the processor realizes the table item synchronization as described above. method.
- the present disclosure discloses an entry synchronization method, a gateway device, a networking system, and a storage medium.
- the method includes: when a message to be processed transmitted from the opposite terminal is received, determining that the message stored at the local end is the same as the message to be processed.
- the target entry corresponding to the text, and the SG port status of the opposite end is determined; according to the target entry stored at the local end and the SG port status of the opposite end, a synchronization message about the target entry is sent to the opposite end .
- the gateway device By determining the status of the SG port of the opposite end and the target entry corresponding to the message to be processed at the local end when receiving the pending message transmitted from the opposite end, it is judged whether it is necessary to perform table item synchronization to the opposite end.
- the operation of the gateway device can timely supplement and synchronize the lost data after packet loss occurs in the transmission process of the gateway device.
- this solution can also avoid the problem of repeated transmission of multiple packets after the synchronization operation is judged by multiple factors, which can further improve Communication efficiency in cross-device link aggregation networking.
- FIG. 1 is a schematic block diagram of modules of a cross-device link aggregation networking system provided by an embodiment of the present disclosure
- FIG. 2 is a schematic flowchart of an entry synchronization method provided by an embodiment of the present disclosure
- FIG. 3 is a schematic flowchart of another method for synchronizing entries according to an embodiment of the present disclosure
- FIG. 4 is a schematic flowchart of another method for synchronizing entries provided by an embodiment of the present disclosure.
- FIG. 5 is a schematic block diagram of the structure of a gateway device provided by an embodiment of the present disclosure.
- the embodiments of the present disclosure provide an entry synchronization method, gateway device, networking system, and storage medium.
- some embodiments of the present disclosure will be described in detail with reference to the accompanying drawings. In the case of no conflict, the following embodiments and features in the embodiments can be combined with each other.
- An entry synchronization method provided by the embodiments of the present disclosure is applied to any gateway device in a cross-device link aggregation (MC-LAG, Multi-Chassis Link Aggregation Group) networking system.
- Figure 1 shows cross-device link aggregation.
- the cross-device link aggregation networking system includes an access device and two gateway devices.
- Corresponding configuration will be performed between the two gateway devices to achieve pairing.
- the active and standby status between the two gateway devices can also be determined.
- the relationship between the main gateway device and the standby gateway device does not affect normal traffic forwarding, and only works when the line fails.
- the two gateway devices can periodically send heartbeat packets through the network side link. When both devices can receive the packets sent by the opposite end, the dual-active system starts to work normally .
- the two devices After normal operation, the two devices will send synchronization messages through the peerlink link to synchronize the information of the peer in real time.
- the synchronization messages include MAC table entries, ARP table entries, etc., so that any device failure will not affect the flow. Forwarding, to ensure that normal business will not be interrupted.
- the general synchronization period will not be set too short. If the synchronization happens when the CPU of the peer gateway device is busy, or other factors cause some forwarding entries to be unsuccessfully received or delivered, it may happen.
- the following problems are as follows: (1) For the packet forwarded by looking up the MAC table entry, one more packet will be flooded to the peer gateway device, and the access device as the receiving end will eventually receive double packets. (2) For messages forwarded by looking up ARP/ND entries, because the local gateway device does not have a corresponding entry, it will trigger an ARP/NS request to the access device, and the access device may reply the ARP/NA response to the opposite end. For the gateway device, the local gateway device cannot learn ARP entries, which causes continuous packet loss in traffic.
- the gateway device 100b in FIG. 1 receives an ARP/ND message from the access device 200, and generates the corresponding MAC table and ARP/ND table on the local end. Because the gateway device is configured with MC-LAG, the gateway device 100b will synchronize the MAC table and ARP/ND table to the gateway device 100a. At this time, if the gateway device 100a does not receive the synchronization message for some reason, or receives Later, because the CPU was busy and failed to process, the corresponding MAC table entry and ARP/ND table entry were not formed on the gateway device 100a.
- the gateway device 100a when the gateway device 100a receives a layer 2 message for the access device 200 from the uplink interface, because there is no MAC entry on the gateway device 100a, the gateway device 100a will broadcast the layer 2 message to the A2 link. At the same time, it broadcasts to the gateway device 100b through the peerlink link. The gateway device 100b looks up the MAC table as a known unicast message, and forwards the layer 2 message to the access device 200, so that the access device 200 receives a double message Arts.
- the gateway device 100a when the gateway device 100a receives a layer 3 message destined for the access device 200 from the uplink interface, because there is no ARP/ND entry on the gateway device 100a, the gateway device 100a will trigger AR/NS according to the layer 3 message The request is sent to the access device 200. If the access device 200 replies an ARP/NA response message to the B2 link, the gateway device 100a still cannot generate an ARP/ND entry, and the traffic will continue to be discarded.
- FIG. 2 is a schematic flowchart of an entry synchronization method provided by an embodiment of the present disclosure. As shown in FIG. 2, the entry synchronization method specifically includes steps S101 to S102.
- this method can be applied to any gateway device in the cross-device link aggregation networking system. As shown in FIG. 1, it can be applied to the gateway device 100a or the gateway device 100b.
- the message to be processed may be a message received by the gateway device from the uplink interface. As shown in FIG. 1, the message to be processed may be the message received by the gateway device 100a from the A link, or the gateway device 100b from the B link Received.
- the gateway device After the gateway device receives the pending packet from the uplink interface, it may be because the gateway device has a problem or may be the normal transmission mode of the pending packet, the gateway device will send the pending packet to another gateway device. For example, if the gateway device 100a receives the message to be processed from the A link and then sends it to the gateway device 100b through the peerlink, the gateway device 100b serves as the local end and the gateway device 100a serves as the opposite end. If the gateway device 100b receives the message to be processed from the B link and then sends it to the gateway device 100a through the peerlink, the gateway device 100a serves as the local end and the gateway device 100b serves as the opposite end.
- the message to be processed is generally sent to the corresponding destination device through the gateway device, and the target device can be an access device; therefore, the message to be processed has its corresponding transmission parameters, and the corresponding destination of the message to be processed can be determined according to the transmission parameters.
- the address of the device so the gateway device can send packets to be processed to the destination device.
- the target entry is an entry used to determine the address of the destination device of the message to be processed.
- the target entry includes the address of the destination device. If the target entry corresponding to the message to be processed is stored on the local end, then The address of the destination device corresponding to the message to be processed can be determined from the target table entry.
- the message to be processed may be a layer 2 message, and the corresponding target entry may be a media access control (MAC, Media Access Control) entry.
- MAC Media Access Control
- the SG port is a port set on the gateway device to connect to the access device, and the SG port status is used to reflect whether the communication link between the gateway device and the access device is normal. For example, when the communication link between the gateway device and the access device is normal, the state of the SG port is "up", and when the communication link between the gateway device and the access device fails, the SG port will switch its state to "Down". Therefore, it can be determined whether there is a problem with the communication link of the gateway device according to the status of the SG port.
- S102 Send a synchronization message about the target entry to the opposite end according to the target entry stored at the local end and the SG port status of the opposite end.
- the status of the SG port at the opposite end can directly determine whether the communication link between the gateway device and the access device is normal. If there is a problem with the communication link between the opposite end gateway device and the access device, the opposite end gateway device cannot The packets to be processed are delivered to the access device through the SG port, so they need to be sent to the local gateway device, using the function of cross-device link aggregation networking, and delivered through the local gateway device. In this case, because the communication link of the peer gateway device itself has a problem, it is impossible to accurately determine whether there is a missing target entry in the peer gateway device.
- the peer gateway device If there is no problem with the communication link between the peer gateway device and the access device, the peer gateway device still sends the pending packets to the local gateway device, that is, the peer gateway device has the ability to download the pending packets.
- the normal communication link sent to the access device but the peer gateway device does not locally deliver other information about the message to be processed, so the peer gateway device needs to use the cross-device link aggregation networking function to pass through the local gateway The device is issued. In this case, it may be that the target entry corresponding to the message to be processed is not stored in the gateway device at the opposite end, and it may be because the CPU is busy in the previous communication process and other conditions have caused data loss at the opposite end.
- the synchronization message about the target entry can be sent to the opposite end according to the SG port status of the opposite end and the target entry stored at the local end.
- the synchronization message carries the target entry corresponding to the message to be processed, and the local end sends the target entry corresponding to the message to be processed to the peer gateway device through the synchronization message, so that the peer gateway device
- the target entry corresponding to the message to be processed can be supplemented and stored.
- the operation of sending a synchronization message about the target entry to the opposite end according to the target entry stored on the local end and the SG port status of the opposite end may be implemented in the following manner:
- a synchronization message regarding the target entry is sent to the opposite end.
- the target state is used to indicate that the communication link corresponding to the SG port is normal, and the SG port is the port that the gateway device is set to connect to the access device. Therefore, the target state is used to indicate the communication link between the gateway device and the access device. It is a normal state.
- the target state may be "up”, and the SG port state is "up”, which indicates that the communication link between the gateway device and the access device is normal.
- the local gateway device can initiate a synchronization message about the target entry to the opposite gateway device, so that the opposite gateway device can supplementally store the target entry corresponding to the message to be processed.
- the entry synchronization method determines the status of the SG port of the peer end and the target entry stored on the local end corresponding to the message to be processed when receiving a message to be processed transmitted from the opposite end. To determine whether it is necessary to perform table item synchronization operation to the opposite end, you can timely supplement and synchronize the lost data after packet loss occurs in the transmission process of the gateway device. At the same time, this solution can also determine the synchronization operation through multiple factors. Avoid the problem of repeated sending of multiple packets.
- the method of the embodiment of the present disclosure may be implemented according to the following steps:
- the local end when receiving a message to be processed transmitted from the opposite end, it may first be determined whether the local end stores a target entry corresponding to the message to be processed, and if it is determined that the local end stores a message corresponding to the message to be processed The corresponding target entry indicates that the local end is capable of sending synchronization messages about the target entry to the opposite end, and then it is determined whether the SG port status of the opposite end is the target state. If the SG port state is the target state, a synchronization message about the target entry is sent to the opposite end.
- the method further includes the following operations: if the local end does not store the target entry corresponding to the message to be processed, or if the local end stores the target entry and the status of the SG port of the opposite end is not In the target state, the to-be-processed message is sent according to the cross-device link aggregation transmission rule.
- the message to be processed can be sent according to the cross-device link aggregation transmission rule, which can be sent to the downstream device for cross-device link aggregation transmission
- the rule can be a transmission rule preset in the cross-device link aggregation networking system. For example, it can be sent to the device members of the single-homed ring in the cross-device link aggregation networking system, rather than to the local cross-device chain. It is sent by the device members of the dual-homing ring in the road aggregation network system.
- the target entry is stored at the local end and the status of the SG port of the opposite end is not the target status, it means that the communication link of the gateway device at the opposite end has failed, and the network device at the opposite end may not have stored the message corresponding to the pending message.
- the target entry of the local network device receives the message to be processed also belongs to the normal message forwarding in the cross-device link aggregation networking system, so the message to be processed can also be sent according to the cross-device link aggregation transmission rule .
- the method further includes the following operations:
- the gateway device can continuously detect the status of its own SG port, and when detecting a change in the status of the SG port at the local end, it can send the changed SG port status to the opposite end.
- the SG port status of the local end was originally "up”, and then a communication link failure occurred, and the SG port status changed to "down”. At this time, the changed SG port status "down" can be sent to the opposite end. Gateway equipment.
- the gateway device at the local end receives the SG port status sent by the opposite end, it means that the SG port status of the gateway device at the opposite end has changed, and the SG port status sent by the opposite end can be stored.
- the SG status information stores the historical SG port status of the gateway device at the opposite end.
- the gateway device at the local end needs to determine the SG port status of the opposite end, it can use the latest SG port status in the SG status information. To determine the SG port status of the opposite end at this time.
- the operation of determining the status of the SG port of the opposite end may be implemented in the following manner:
- the local gateway device can not only passively receive the SG port status sent by the opposite end, but also actively query the SG port status of the opposite end to avoid the changed SG port sent by the opposite end after the last SG port status changes.
- the status message is lost, and the gateway device at the local end has not received the latest SG port status of the opposite end.
- the status query message can be sent to the opposite end. After receiving the status query message, the opposite end can return the current SG port status to the local end.
- the operation of sending a synchronization message about the target entry to the opposite end may be implemented in the following manner:
- the target entry after sending a synchronization message about the target entry to the opposite end, if the opposite end is in a normal state, the target entry will be added according to the synchronization message, and if the opposite end is busy, the opposite end It is also not possible to add corresponding target entries based on the synchronization message. At this time, there are still pending messages in the opposite end that correspond to the target entry and cannot be sent out through the opposite end. The opposite end will continue to send the pending messages corresponding to the target entry to the local end, and therefore send the message to the local end.
- the opposite end After the opposite end sends a synchronization message about the target entry, if it receives a message to be processed corresponding to the target entry transmitted by the opposite end, it means that the opposite end has not successfully added the target entry, and the local end It is necessary to send a synchronization message about the target entry to the opposite end again.
- a synchronization message regarding the target entry may be sent to the opposite end again after a certain interval.
- the synchronization message about the target entry may be sent to the opposite end again according to a preset synchronization rule.
- the preset synchronization rule may be preset, and may include the sending time interval and/or the number of sending times.
- the method further includes the following operations:
- S301 When receiving an ARP response message, determine whether the local end has sent an ARP request corresponding to the ARP response message, and determine whether the local end stores an ARP entry corresponding to the ARP response message;
- S302 According to whether the local end has sent an ARP request and/or whether the local end has stored an ARP entry corresponding to the ARP response message, send a synchronization message corresponding to the ARP response message to the opposite end.
- the ARP response message is a response message returned for the ARP request, and the ARP response message includes an ARP table entry corresponding to the ARP request.
- the gateway device receives data from the access device whose IP address is the first address from the uplink interface, but the gateway device does not store the corresponding ARP/ND entry locally, the gateway device can trigger an ARP/NS request at this time.
- the ARP response message may be a Layer 3 message that the gateway device receives from the uplink interface and the destination device is an access device.
- the gateway device 100a may receive an ARP response message from link A.
- the ARP response message may also be received from the access device.
- the gateway device 100a may receive the ARP response message from the A2 link.
- the local gateway device can also perform corresponding operations based on the ARP response message at the same time, according to whether the local terminal has stored the ARP table entry corresponding to the ARP response message, it corresponds to the ARP response executed on the local terminal.
- the operation type corresponding to the message is different.
- the gateway device at the local end stores ARP/ND entries and the local end has not initiated an ARP/NS request, but the local end receives an ARP response message for the gateway address from the access device, it can be explained
- the peer device does not have ARP/ND entries, and the ARP/NS request is initiated by the peer. Therefore, the local end can initiate a synchronization message about ARP/ND entries to the peer device after receiving the ARP response message.
- the peer gateway device can directly generate MAC table entries and normal MAC entries based on the ARP/NA response message. ARP/ND entries.
- the ARP response message corresponding to the ARP response message is sent to the opposite terminal according to whether the local terminal has sent an ARP request and/or whether the local terminal has stored an ARP entry corresponding to the ARP response message.
- the operation of the corresponding synchronization message can be implemented in the following ways:
- the ARP entry is added at the local end according to the ARP response message, and the synchronization corresponding to the ARP response message is sent to the opposite end Message
- the local end sends an ARP request corresponding to the ARP response message, and the local end stores an ARP table entry corresponding to the ARP response message, update the local ARP table entry according to the ARP response message;
- the local end If the local end has not sent an ARP request corresponding to the ARP response message, and the local end stores an ARP entry corresponding to the ARP response message, then send the ARP response message to the opposite end Corresponding synchronization message.
- the local end can add an ARP table at the local end according to the ARP response message Item, it is also possible to send a synchronization message corresponding to the ARP response message to the opposite end.
- the local end stores the ARP entry corresponding to the ARP response message, and the local end has sent an ARP request corresponding to the ARP response message, and the local end, that is, the ARP response message is sent directly to the local end
- the ARP request sent by the local end is used to trigger the keep-alive message before the ARP/ND table entry ages. If the aging time of the ARP/ND table entry is updated normally, it can be updated according to the ARP response message. Local ARP entry.
- the local end stores the ARP entry corresponding to the ARP response message, and the local end has not sent an ARP request corresponding to the ARP response message, it means that the ARP request is sent by the peer device, but because the local The ARP table entry corresponding to the ARP response message is also stored, which means that the gateway device at the opposite end may have experienced data loss during the previous synchronization process, and the gateway device at the opposite end has not stored the corresponding ARP table entry.
- the gateway device at the local end may send a synchronization message corresponding to the ARP response message to the opposite end according to the ARP response message.
- the opposite end when the opposite end initiates an ARP/NS request, it will also send a copy to the local gateway device through the peerlink link. If the local gateway device sends a synchronization message about ARP entries to the opposite end according to the ARP/NS request, and at the same time, the ARP/NA response message will also reply to the opposite end device, which will cause the local status of the opposite end entry and Override between synchronization states, adding additional processing flow.
- Sending a synchronization message corresponding to the ARP response message can avoid the above-mentioned coverage problem and can update the synchronization of the ARP table entries between the two gateway devices in time.
- the gateway device provided by the embodiment of the present disclosure includes a configuration module, a port module, a database module, a message transceiving module, a message processing module, and an MC-LAG system module that are connected to each other.
- the configuration module is set to supplement synchronization messages for newly added entries. If the opposite end is busy with the CPU for a long time, frequent synchronization messages will increase its burden.
- the configuration module is set to allow the user to manually configure the supplementary synchronization interval and the number of synchronizations, and form a preset synchronization rule. When the opposite end is busy , The synchronization message about the target entry may be sent to the opposite end again according to the preset synchronization rule.
- the port module is set to quickly notify the MC-LAG system module to modify the SG port status carried in its keepalive message when the SG port status changes, so that the peer can correctly record the local SG port status according to the received keepalive message.
- the MC-LAG system module can also dynamically obtain the SG port status from the port module. If the status error caused by the loss of the message reported by the port module, it can be corrected in the subsequent keepalive message.
- the database module is set to record the SG port status of the opposite end obtained from the keepalive message to the SG status information of the local end, and determine whether supplementary synchronization is required according to the SG port status of the opposite end in the SG status information as a judgment condition .
- the message transceiver module is set to realize the transceiver of keepalive messages in the cross-device link aggregation networking system.
- the keepalive message adds the field of the local SG port status.
- the sending and receiving of protocol messages is handled by the CPU.
- When filling in the SG port status field fill it in according to the status reported by the port module last time. You can also actively query to avoid the loss of the reported data after the SG port status changes, resulting in a status error. problem.
- the port module actively reports the changed SG port status, it should immediately trigger the sending of a keepalive message carrying the changed SG port status field to the opposite end.
- the message transceiving module may also include the message identification received from the peerlink link. Whether it is a known unicast or an unknown unicast, the MC-LAG system module should be notified to make a judgment.
- the message transceiver module can also include the message identification received from the MC-LAG link.
- the message identification received from the MC-LAG link.
- the message processing module is set to record the field of the SG port status of the opposite end according to the received keepalive message.
- the status field of the opposite SG port should provide a query mode and be visible to the user.
- the MC-LAG system module is set to complete all necessary information collection and make corresponding decisions.
- FIG. 5 is a schematic block diagram of a structure of a gateway device provided by an embodiment of the present disclosure.
- the gateway device can be a switch or a router.
- the gateway device 100 includes a processor 110 and a memory 120 connected through a system bus, where the memory 120 may include a non-volatile storage medium and an internal memory.
- the non-volatile storage medium can store an operating system and a computer program.
- the computer program includes program instructions, and when the program instructions are executed, the processor can execute any type of table entry synchronization method.
- the processor is set to provide computing and control capabilities to support the operation of the entire gateway device.
- the internal memory provides an environment for the operation of the computer program in the non-volatile storage medium.
- the processor can execute any method for synchronizing entries.
- FIG. 5 is only a block diagram of part of the structure related to the solution of the present disclosure, and does not constitute a limitation on the gateway device to which the solution of the present disclosure is applied.
- the specific gateway device may Including more or fewer parts than shown in the figure, or combining some parts, or having a different arrangement of parts.
- the processor may be a central processing unit (Central Processing Unit, CPU), and the processor may also be other general-purpose processors, digital signal processors (Digital Signal Processor, DSP), and application specific integrated circuits (Application Specific Integrated Circuits). Circuit, ASIC), Field-Programmable Gate Array (FPGA) or other programmable logic devices, discrete gates or transistor logic devices, discrete hardware components, etc.
- the general-purpose processor may be a microprocessor or the processor may also be any conventional processor.
- the processor is configured to run a computer program stored in a memory to implement the following steps:
- a synchronization message about the target entry is sent to the opposite end.
- the processor when the processor realizes that according to the target entry stored at the local end and the SG port status of the opposite end, it sends a synchronization message about the target entry to the opposite end, setting To achieve:
- the target entry is stored on the local end, and the SG port status of the opposite end is the target state, a synchronization message about the target entry is sent to the opposite end, and the target status is used to indicate the SG port The corresponding communication link is normal.
- the processor is further configured to implement:
- the processor when the processor realizes the determination of the SG port state of the opposite end, it is set to realize:
- the process includes setting to realize:
- the synchronization message regarding the target entry is sent to the opposite end again according to a preset synchronization rule.
- the preset synchronization rule includes a sending time interval and/or the number of sending times.
- the processor is further configured to implement:
- the transmission is sent according to the cross-device link aggregation transmission rule. Describe messages to be processed.
- the processor is further configured to implement:
- a synchronization message corresponding to the ARP response message is sent to the opposite end.
- the processor sends the ARP entry corresponding to the ARP response message to the opposite end according to whether the local end has sent an ARP request and/or whether the local end has stored an ARP entry corresponding to the ARP response message.
- the synchronization message corresponding to the ARP reply message is set to realize:
- the ARP entry is added at the local end according to the ARP response message, and the synchronization corresponding to the ARP response message is sent to the opposite end Message
- the local end sends an ARP request corresponding to the ARP response message, and the local end stores an ARP table entry corresponding to the ARP response message, update the local ARP table entry according to the ARP response message;
- the local end If the local end has not sent an ARP request corresponding to the ARP response message, and the local end stores an ARP entry corresponding to the ARP response message, then send the ARP response message to the opposite end Corresponding synchronization message.
- the embodiments of the present disclosure also provide a networking system.
- the networking system includes two gateway modules, and the gateway modules are configured to implement any item synchronization method provided in the embodiments of the present disclosure.
- the embodiments of the present disclosure also provide a computer-readable storage medium, the computer-readable storage medium stores a computer program, the computer program includes program instructions, and the processor executes the program instructions to implement the present disclosure Any item synchronization method provided by the embodiment.
- the computer-readable storage medium may be the internal storage unit of the gateway device described in the foregoing embodiment, for example, the hard disk or memory of the gateway device.
- the computer-readable storage medium may also be an external storage device of the gateway device, such as a plug-in hard disk equipped on the gateway device, a smart memory card (Smart Media Card, SMC), and a Secure Digital (SD) ) Card, Flash Card, etc.
- a plug-in hard disk equipped on the gateway device such as a smart memory card (Smart Media Card, SMC), and a Secure Digital (SD) ) Card, Flash Card, etc.
- SD Secure Digital
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本公开涉及通信技术领域,具体公开了一种表项同步方法、网关设备、组网系统及存储介质。其中方法包括:在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项,以及确定所述对端的SG端口状态;根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文。该方法可以提高跨设备链路聚合组网中的通信效率。
Description
本发明涉及通信技术领域,尤其涉及一种表项同步方法、网关设备、组网系统及存储介质。
跨设备链路聚合(MC-LAG,Multi-Chassis Link Aggregation Group)是一种组网机制,可以将一台接入设备和另外两台运行MC-LAG装置的网关设备进行链路聚合。
两台网关设备之间设有同步链路,一般称作peerlink链路,两台网关设备会通过同步链路将各自聚合口学到的表项同步到对端,以实现转发层面的衔接。同时两台网关设备之间还设有协商链路,一般称作keepalive链路,用来对两端设备配置进行一致性检查,同时协商出主备角色。MC-LAG表项的同步是触发同步加周期同步方式。当有新增表项时会立即同步到远端。另外也会间隔固定的时间进行全量的表项同步。
在同步过程中,可能会因为对端繁忙或者一些因素导致数据未能成功发送或者接收,还有重复发送数据的问题,因此需要解决在跨设备链路聚合组网中丢包或者多包的问题。
发明内容
本公开提供了一种表项同步方法、网关设备、组网系统及存储介质,可以提高跨设备链路聚合组网中的通信效率。
第一方面,本公开提供了一种表项同步方法,所述方法包括:
在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项,以及确定所述对端的SG端口状态;
根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文。
第二方面,本公开还提供了一种网关设备,所述网关设备包括存储器和处理器;所述存储器设置为存储计算机程序;所述处理器,设置为执行所述计算机程序并在执行所述计算机程序时实现如上述的表项同步方法。
第三方面,本公开还提供了一种组网系统,所述组网系统包括两个网关模块,所述网关模块设置为实现如上述的表项同步方法。
第四方面,本公开还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时使所述处理器实现如上述的表项同步方法。
本公开公开了一种表项同步方法、网关设备、组网系统及存储介质,该方法包括:在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项,以及确定所述对端的SG端口状态;根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文。通过在接收对端传输来的待处理报文时,确定对 端的SG端口状态以及本端的存储的与所述待处理报文对应的目标表项,来判断是否需要执行向对端进行表项同步的操作,可以在网关设备的传输过程中出现了丢包后及时对丢失的数据进行补充同步,同时本方案通过多个因素判断执行同步操作后也可以避免多包重复发送的问题,进一步可以提高跨设备链路聚合组网中的通信效率。
为了更清楚地说明本公开实施例技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本公开的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本公开实施例提供的跨设备链路聚合组网系统的模块示意框图;
图2是本公开实施例提供的一种表项同步方法的示意流程图;
图3是本公开实施例提供的另一种表项同步方法的示意流程图;
图4是本公开实施例提供的另一种表项同步方法的示意流程图;
图5是本公开的实施例提供的一种网关设备的结构示意性框图。
下面将结合本公开实施例中的附图,对本公开实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本公开一部分实施例,而不是全部的实施例。基于本公开中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本公开保护的范围。
附图中所示的流程图仅是示例说明,不是必须包括所有的内容和操作/步骤,也不是必须按所描述的顺序执行。例如,有的操作/步骤还可以分解、组合或部分合并,因此实际执行的顺序有可能根据实际情况改变。
应当理解,在此本公开说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本公开。如在本公开说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本公开说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
本公开的实施例提供了一种表项同步方法、网关设备、组网系统及存储介质。下面结合附图,对本公开的一些实施方式作详细说明。在不冲突的情况下,下述的实施例及实施例中的特征可以相互组合。
本公开的实施例提供的一种表项同步方法应用在跨设备链路聚合(MC-LAG,Multi-Chassis Link Aggregation Group)组网系统中的任一网关设备,图1是跨设备链路聚合组网系统的模块示意框图,跨设备链路聚合组网系统包括接入设备和两个网关设备。
两个网关设备之间会进行相应的配置以实现配对,配对成功后还可以确定出两个网关设备之间的主备状态。主网关设备和备网关设备的关系不影响正常的流量转发,只有在线路出现故障时才起作用。确定出主备后,两台网关设备之间可以通过网络侧链路周期性地发送心跳报文,当两台设备均能够收到对端发送的报文时,双活系统即开始正常的工作。
正常工作后,两台设备之间会通过peerlink链路发送同步报文实时同步对端的信息,同 步报文中包括MAC表项、ARP表项等,这样任意一台设备故障都不会影响流量的转发,保证正常的业务不会中断。
因为周期性同步为全量同步,所以一般同步周期不会设置太短,如果同步时恰逢对端网关设备的CPU繁忙,或者其它因素导致部分转发表项未能成功接收或者下发,可能会出现如下问题:(1)对于查找MAC表项转发的报文会多泛洪一份到对端网关设备,而作为接收端的接入设备最终会收到双份报文。(2)对于查找ARP/ND表项转发的报文,因本端网关设备没有相应的表项会触发ARP/NS请求至接入设备,接入设备可能会将ARP/NA应答回复到了对端网关设备,同样本端网关设备学不到ARP表项,造成流量持续丢包。
例如,如图1所示,图1中的网关设备100b从接入设备200接收到ARP/ND报文,在本端生成对应的MAC表和ARP/ND表。因网关设备中配置了MC-LAG,所以网关设备100b会把MAC表和ARP/ND表同步到网关设备100a,此时如果网关设备100a由于某些原因未接收到此同步报文,或者接收到后因CPU繁忙没能处理,导致网关设备100a上没有形成对应的MAC表项和ARP/ND表项。
又如,当网关设备100a从上行接口收到目的为接入设备200的二层报文,因网关设备100a上没有MAC表项,网关设备100a会将该二层报文广播到A2链路,同时通过peerlink链路广播到网关设备100b,网关设备100b查找MAC表为已知单播报文,也会将该二层报文转发给接入设备200,这样接入设备200就收到了双份报文。
又如,当网关设备100a从上行接口收到目的为接入设备200的三层报文,因网关设备100a上没有ARP/ND表项,网关设备100a会根据该三层报文触发AR/NS请求并发送至接入设备200,假如接入设备200回复了ARP/NA应答报文至B2链路,网关设备100a仍然无法生成ARP/ND表项,流量会持续被丢弃。
请参阅图2,图2是本公开的实施例提供的一种表项同步方法的示意流程图,如图2所示,该表项同步方法具体包括步骤S101至步骤S102。
S101、在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项,以及确定所述对端的SG端口状态。
其中,本方法可以是应用在跨设备链路聚合组网系统中的任一网关设备,如图1所示,可以是应用在网关设备100a上,也可以是应用在网关设备100b上。待处理报文可以是网关设备从上行接口接收到的报文,如图1所示,待处理报文可以是网关设备100a从A链路接收到的,也可以是网关设备100b从B链路接收到的。
网关设备从上行接口接收到的待处理报文后,可能是因为网关设备出现问题或者可能是该待处理报文的正常传输方式,网关设备会将待处理报文发送至另一个网关设备。例如,如果是网关设备100a从A链路接收到待处理报文,后再通过peerlink发送给网关设备100b,则网关设备100b作为本端,网关设备100a作为对端。如果是网关设备100b从B链路接收到待处理报文,后再通过peerlink发送给网关设备100a,则网关设备100a作为本端,网关设备100b作为对端。
待处理报文一般是通过网关设备发送到对应的目的设备上,目标设备可以是接入设备;因此待处理报文会有其对应的传输参数,根据传输参数可以确定待处理报文对应的目的设备的地址,因此网关设备便可以将待处理报文发送至目的设备。目标表项为用于确定和待处理报文的目的设备的地址的表项,目标表项中包括目的设备的地址,如果本端存储有与所述待 处理报文对应的目标表项,则可以从目标表项中确定待处理报文对应目的设备的地址。待处理报文可以是二层报文,对应的目标表项可以是媒体存取控制(MAC,Media Access Control)表项。
SG端口为网关设备上设置为和接入设备连接的端口,SG端口状态用于体现网关设备和接入设备之间的通信链路是否正常。例如,网关设备和接入设备之间的通信链路正常时,SG端口的状态为“up”,网关设备和接入设备之间的通信链路出现故障时,SG端口会将其状态切换为“down”。因此根据SG端口状态可以确定网关设备的通信链路是否出现问题。
S102、根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文。
其中,对端的SG端口状态可以直接确定网关设备和接入设备之间的通信链路是否正常,如果对端网关设备和接入设备之间的通信链路出现了问题,则对端网关设备无法通过SG端口将待处理报文下发至接入设备,因此需要发送给本端网关设备,利用跨设备链路聚合组网的功能,通过本端网关设备进行下发。这种情况下因为对端网关设备本身的通信链路出现了问题,无法准确确定对端网关设备中是否有缺失的目标表项。
而如果对端网关设备和接入设备之间的通信链路并没有问题,对端网关设备仍然将待处理报文发送给了本端网关设备,即对端网关设备具备将待处理报文下发至接入设备的正常的通信链路,但是对端网关设备本地没有下发待处理报文的其他信息,因此对端网关设备需要利用跨设备链路聚合组网的功能,通过本端网关设备进行下发。这种情况中可能就是对端网关设备中没有存储与所述待处理报文对应的目标表项,可能是因为之前的通信过程中CPU繁忙等状况导致对端出现了数据丢失。
因此可以根据对端的SG端口状态,以及本端存储的所述目标表项,向所述对端发送关于所述目标表项的同步报文。同步报文中携带了与所述待处理报文对应的目标表项,本端通过同步报文将与所述待处理报文对应的目标表项发送到对端网关设备,以便对端网关设备可以补充存储与所述待处理报文对应的目标表项。
在一个实施例中,所述根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文的操作可以通过如下方式实施:
若本端存储有所述目标表项,以及所述对端的SG端口状态为目标状态,则向所述对端发送关于所述目标表项的同步报文。
其中,目标状态用于表示SG端口对应的通信链路正常,SG端口为网关设备设置为和接入设备连接的端口,因此目标状态是用来表示网关设备和接入设备之间的通信链路是正常的状态,可选地,目标状态可以是为“up”,SG端口状态为“up”表示网关设备和接入设备之间的通信链路正常。
如果对端的SG端口状态为目标状态,则表示对端网关设备中没有存储与所述待处理报文对应的目标表项,而本端网关设备中存储有与所述待处理报文对应的目标表项,因此本端网关设备可以向对端网关设备发起关于所述目标表项的同步报文,以便对端网关设备可以补充存储与所述待处理报文对应的目标表项。
本公开实施例提供的表项同步方法,通过在接收对端传输来的待处理报文时,确定对端的SG端口状态以及本端的存储的与所述待处理报文对应的目标表项,来判断是否需要执行向对端进行表项同步的操作,可以在网关设备的传输过程中出现了丢包后及时对丢失的数据进 行补充同步,同时本方案通过多个因素判断执行同步操作后也可以避免多包重复发送的问题。
可选地,如图3所示,本公开实施例的方法可以根据如下步骤实施:
S201、在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项。
S202、若本端存储有与所述待处理报文对应的目标表项,则确定所述对端的SG端口状态。
S203、若所述对端的SG端口状态为目标状态,则向所述对端发送关于所述目标表项的同步报文。
其中,在接收到对端传输来的待处理报文时,可以首先确定本端是否存储有与所述待处理报文对应的目标表项,若确定本端存储有与所述待处理报文对应的目标表项,则表示本端有能力执行向所述对端发送关于所述目标表项的同步报文的操作,后续再判断对端的SG端口状态是否为目标状态,若所述对端的SG端口状态为目标状态,则向所述对端发送关于所述目标表项的同步报文。
在一个实施例中,所述方法还包括如下操作:若本端没有存储与所述待处理报文对应的目标表项,或者若本端存储有所述目标表项以及对端的SG端口状态不是目标状态,则根据跨设备链路聚合传输规则发送所述待处理报文。
其中,如果本端没有存储与所述待处理报文对应的目标表项,可以根据跨设备链路聚合传输规则发送所述待处理报文,可以是发送至下游设备,跨设备链路聚合传输规则可以是跨设备链路聚合组网系统中预设的传输规则,示例性地,可以是往跨设备链路聚合组网系统中的单归环的设备成员发送,而非往本地跨设备链路聚合组网系统中的双归环的设备成员发送。
如果本端存储有所述目标表项以及对端的SG端口状态不是目标状态,则表示对端的网关设备的通信链路出现故障,对端的网络设备中不一定没有存储与所述待处理报文对应的目标表项,本端的网络设备接收到待处理报文也属于跨设备链路聚合组网系统中正常的报文转发,因此也可以根据跨设备链路聚合传输规则发送所述待处理报文。
在一个实施例中,所述方法还包括如下操作:
在本端的SG端口状态发生变化时,将变化后的SG端口状态发送至对端;
在接收到对端发送来的SG端口状态时,将所述对端发送来的SG端口状态存储至SG状态信息中;
相应地,所述确定所述对端的SG端口状态的操作可以通过如下方式实施:
确定所述SG状态信息中最新的SG端口状态,并确定为所述对端的SG端口状态。
其中,网关设备可以持续检测自身的SG端口的状态,在检测到本端的SG端口状态发生变化时,可以将变化后的SG端口状态发送至对端。示例性地,本端的SG端口状态本来是“up”,然后出现了通信链路故障,SG端口状态变成了“down”,此时可以将变化后的SG端口状态“down”发送到对端的网关设备。
相应地,作为本端的网关设备如果接收到对端发送来的SG端口状态,则表示对端的网关设备的SG端口状态发生了变化,可以将对端发送来的SG端口状态进行存储,可以是存储到本端的SG状态信息中,SG状态信息中存储了对端的网关设备的历史的SG端口状态,本端的网关设备在需要确定对端的SG端口状态时,可以根据SG状态信息中最新的SG端口状态来确定对端此时的SG端口状态。
在一个实施例中,所述确定所述对端的SG端口状态的操作可以通过如下方式实施:
向对端发送状态查询报文,并接收所述对端返回的SG端口状态。
其中,本端的网关设备除了可以被动接收对端发送来的SG端口状态,还可以主动查询对端的SG端口状态,避免对端在上一次SG端口状态发生变化后,所发送的变化后的SG端口状态出现消息丢失,本端的网关设备上没有接收到最新的对端的SG端口状态。可以通过发送状态查询报文到对端,对端在接收到状态查询报文后,可以返回当前的SG端口状态至本端。
在一个实施例中,所述向所述对端发送关于所述目标表项的同步报文的操作可以通过如下方式实施:
向所述对端发送关于所述目标表项的同步报文,若接收到对端传输来的和所述目标表项对应的待处理报文,则根据预设同步规则再次向所述对端发送关于所述目标表项的同步报文。
其中,在向对端发送关于所述目标表项的同步报文后,对端如果处于正常状态,则会根据该同步报文添加目标表项,而如果对端处于繁忙的状态,则对端也无法根据同步报文添加相应的目标表项。此时对端中仍有和目标表项对应而无法通过对端发送出去的待处理报文,对端会继续将和所述目标表项对应的待处理报文发送至本端,因此向所述对端发送关于所述目标表项的同步报文后,若接收到对端传输来的和所述目标表项对应的待处理报文,则表示对端没有成功添加目标表项,本端需要再次向所述对端发送关于所述目标表项的同步报文。
为了避免增加对端的CPU繁忙程度,可以间隔一定时间后再次向所述对端发送关于所述目标表项的同步报文。可以根据预设同步规则再次向所述对端发送关于所述目标表项的同步报文,预设同步规则可以是预先设置好的,可以包括发送时间间隔和/或发送次数。
在一个实施例中,如图4所示,所述方法还包括如下操作:
S301、在接收ARP应答报文时,确定本端是否发过与所述ARP应答报文对应的ARP请求,以及确定本端是否存储有与所述ARP应答报文对应的ARP表项;
S302、根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文。
其中,ARP应答报文是针对ARP请求所返回的应答报文,ARP应答报文中包括了和ARP请求相对应的ARP表项。例如,网关设备从上行接口接收到IP地址为第一地址的接入设备的数据时,网关设备本地却没有存储对应的ARP/ND表项,此时网关设备可以触发ARP/NS请求。
ARP应答报文可以是网关设备从上行接口接收的目的设备为接入设备的三层报文,示例性地,如图1所示,网关设备100a可以是从A链路接收到ARP应答报文。ARP应答报文也可以是从接入设备接收的,示例性地,如图1所示,网关设备100a可以是从A2链路接收到ARP应答报文。
确定本端是否发过与所述ARP应答报文对应的ARP请求,可以确定接收的ARP应答报文是否是和对端的网关设备相对应,进而可以确定是否要向对端执行跟ARP应答报文相对应的同步操作。同时,由于本端网关设备也可以同时根据ARP应答报文进行相应的操作,根据本端是否已经存储有跟所述ARP应答报文相对应的ARP表项,对应在本端执行的跟ARP应答报文对应的操作类型有所不同。
进而可以确定本端是否发过与所述ARP应答报文对应的ARP请求,以及确定本端是否存储有与所述ARP应答报文对应的ARP表项,根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文。
示例性地,如果本端的网关设备存储有ARP/ND表项,本端并未发起过ARP/NS请求,而本端却接收到接入设备回复的针对网关地址的ARP应答报文,可以说明对端设备没有ARP/ND表项,ARP/NS请求是对端发起的,因此,本端在接收到ARP应答报文后可以向对端设备发起关于ARP/ND表项的同步报文。而如果接入设备回复的ARP/NA应答报文是直接发送到,发出过ARP/NS请求的对端网关设备时,对端网关设备可以直接根据ARP/NA应答报文正常生成MAC表项和ARP/ND表项。
在一个实施例中,所述根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文的操作可以通过如下方式实施:
若本端没有与所述ARP应答报文对应的ARP表项,则根据所述ARP应答报文在本端添加ARP表项,以及向所述对端发送与所述ARP应答报文对应的同步报文;
若本端发过与所述ARP应答报文对应的ARP请求,以及本端存储有与所述ARP应答报文对应的ARP表项,则根据所述ARP应答报文更新本端的ARP表项;
若本端未发过与所述ARP应答报文对应的ARP请求,以及本端存储有与所述ARP应答报文对应的ARP表项,则向所述对端发送与所述ARP应答报文对应的同步报文。
其中,如果本端没有与所述ARP应答报文对应的ARP表项,则不论ARP请求是由本端发出的还是由对端发出的,本端都可以根据ARP应答报文在本端添加ARP表项,同时也可以向所述对端发送与所述ARP应答报文对应的同步报文。
而如果本端存储有与所述ARP应答报文对应的ARP表项,且本端发过与所述ARP应答报文对应的ARP请求,且本端即ARP应答报文是直接和本端发出过的ARP请求相对应,本端发送的ARP请求是用于ARP/ND表项老化前的保活报文触发,正常更新ARP/ND表项老化时间,则可以根据所述ARP应答报文更新本端的ARP表项。
而如果本端存储有与所述ARP应答报文对应的ARP表项,且本端没有发过与所述ARP应答报文对应的ARP请求,表示ARP请求是对端设备发出的,但是由于本地也存储有和ARP应答报文对应的ARP表项,则表示可能在之前的同步过程中,对端的网关设备出现了数据丢失的问题,对端的网关设备没有存储到对应的ARP表项,此时本端的网关设备可以根据所述ARP应答报文向所述对端发送与所述ARP应答报文对应的同步报文。
需要说明的是,实际上在对端发起ARP/NS请求时,也会通过peerlink链路发出一份给本端的网关设备。本端的网关设备如果根据该ARP/NS请求向对端发出关于ARP表项的同步报文,而同时ARP/NA应答报文也会回复到对端设备,如此会造成对端表项本地状态和同步状态之间覆盖,增加额外的处理流程。本公开实施例通过在接收到在接收ARP应答报文时,根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文,可以避免上述覆盖的问题,又可以及时更新两个网关设备之间关于ARP表项的同步。
在一个实施例中,本公开实施例提供的网关设备包括相互连接的配置模块、端口模块、数据库模块、报文收发模块、报文处理模块和MC-LAG系统模块。
配置模块设置为针对新增的表项补充同步报文。如果对端长时间处于CPU繁忙状态,频繁的同步报文反而会加重其负担,配置模块设置为使用户手工配置补充同步间隔和同步次数,并形成预设同步规则,在对端处于繁忙状态时,可以根据预设同步规则再次向所述对端发送 关于所述目标表项的同步报文。
端口模块设置为在SG端口状态发生变化时,快速通知MC-LAG系统模块修改其keepalive报文中携带的SG端口状态,以便对端根据接收到的keepalive报文正确记录本端的SG端口状态。
对于正常的keepalive报文,MC-LAG系统模块还可以动态从端口模块获取SG端口状态,如果端口模块上报的报文丢失造成的状态出错,可以在后面的keepalive报文中纠正。
数据库模块设置为,将从keepalive报文中获取的对端的SG端口状态,记录到本端的SG状态信息中,根据SG状态信息中对端的SG端口状态作为判断条件来确定是否需要进行补充同步的操作。
报文收发模块,设置为实现跨设备链路聚合组网系统中keepalive报文的收发,keepalive报文中增加了本端的SG端口状态的字段。
协议报文的收发由CPU来处理,在填写SG端口状态的字段时,根据端口模块上一次上报的状态来填写,也可以主动查询,避免SG端口状态变化后上报的数据丢失,导致状态出错的问题。当端口模块主动上报了变化后的SG端口状态,应立即触发发送一个携带变化后的SG端口状态的字段的keepalive报文给对端。
另外的,报文收发模块还可以包括从peerlink链路收到的报文识别,是已知单播还是未知单播均应通知MC-LAG系统模块做判断。
另外的,报文收发模块还可以包括从MC-LAG链路收到的报文识别,当接收到了ARP/NA应答,是否之前发出过ARP/NS请求,均需要通知MC-LAG系统模块做判断。
报文处理模块,设置为将根据接收到的keepalive报文记录下对端的SG端口状态的字段。对端SG端口状态字段应该提供查询方式且对用户可见。
MC-LAG系统模块作为整个网关设备的主导模块,设置为完成所有必需的信息收集并作出相应的决策。
请参阅图5,图5是本公开的实施例提供的一种网关设备的结构示意性框图。该网关设备可以是交换机或路由器。
参阅图5,该网关设备100包括通过系统总线连接的处理器110和存储器120,其中,存储器120可以包括非易失性存储介质和内存储器。
非易失性存储介质可存储操作系统和计算机程序。该计算机程序包括程序指令,该程序指令被执行时,可使得处理器执行任意一种表项同步方法。
处理器设置为提供计算和控制能力,支撑整个网关设备的运行。
内存储器为非易失性存储介质中的计算机程序的运行提供环境,该计算机程序被处理器执行时,可使得处理器执行任意一种表项同步方法。
本领域技术人员可以理解,图5中示出的结构,仅仅是与本公开方案相关的部分结构的框图,并不构成对本公开方案所应用于其上的网关设备的限定,具体的网关设备可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
应当理解的是,处理器可以是中央处理单元(Central Processing Unit,CPU),该处理器还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻 辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
其中,在一个实施例中,所述处理器设置为运行存储在存储器中的计算机程序,以实现如下步骤:
在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项,以及确定所述对端的SG端口状态;
根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文。
在一个实施例中,所述处理器在实现所述根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文时,设置为实现:
若本端存储有所述目标表项,以及所述对端的SG端口状态为目标状态,则向所述对端发送关于所述目标表项的同步报文,所述目标状态用于表示SG端口对应的通信链路正常。
在一个实施例中,所述处理器还设置为实现:
在本端的SG端口状态发生变化时,将变化后的SG端口状态发送至对端;
在接收到对端发送来的SG端口状态时,将所述对端发送来的SG端口状态存储至SG状态信息中;
所述处理器在实现所述确定所述对端的SG端口状态时,设置为实现:
确定所述SG状态信息中最新的SG端口状态,并确定为所述对端的SG端口状态。
在一个实施例中,所述处理器在实现所述确定所述对端的SG端口状态时,设置为实现:
向对端发送状态查询报文,并接收所述对端返回的SG端口状态。
在一个实施例中,所述处理器在实现所述向所述对端发送关于所述目标表项的同步报文,包括,设置为实现:
向所述对端发送关于所述目标表项的同步报文;
若接收到对端传输来的和所述目标表项对应的待处理报文,则根据预设同步规则再次向所述对端发送关于所述目标表项的同步报文。
在一个实施例中,所述预设同步规则包括发送时间间隔和/或发送次数。
在一个实施例中,所述处理器还设置为实现:
若本端没有存储与所述待处理报文对应的目标表项,或者若本端存储有所述目标表项以及对端的SG端口状态不是目标状态,则根据跨设备链路聚合传输规则发送所述待处理报文。
在一个实施例中,所述处理器还设置为实现:
在接收ARP应答报文时,确定本端是否发过与所述ARP应答报文对应的ARP请求,以及确定本端是否存储有与所述ARP应答报文对应的ARP表项;
根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文。
在一个实施例中,所述处理器在实现所述根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文时,设置为实现:
若本端没有与所述ARP应答报文对应的ARP表项,则根据所述ARP应答报文在本端添加ARP表项,以及向所述对端发送与所述ARP应答报文对应的同步报文;
若本端发过与所述ARP应答报文对应的ARP请求,以及本端存储有与所述ARP应答报文对应的ARP表项,则根据所述ARP应答报文更新本端的ARP表项;
若本端未发过与所述ARP应答报文对应的ARP请求,以及本端存储有与所述ARP应答报文对应的ARP表项,则向所述对端发送与所述ARP应答报文对应的同步报文。
本公开的实施例中还提供一种组网系统,所述组网系统包括两个网关模块,所述网关模块设置为实现本公开实施例提供的任一项表项同步方法。
本公开的实施例中还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序中包括程序指令,所述处理器执行所述程序指令,实现本公开实施例提供的任一项表项同步方法。
其中,所述计算机可读存储介质可以是前述实施例所述的网关设备的内部存储单元,例如所述网关设备的硬盘或内存。所述计算机可读存储介质也可以是所述网关设备的外部存储设备,例如所述网关设备上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。
以上所述,仅为本公开的具体实施方式,但本公开的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本公开揭露的技术范围内,可轻易想到各种等效的修改或替换,这些修改或替换都应涵盖在本公开的保护范围之内。因此,本公开的保护范围应以权利要求的保护范围为准。
Claims (12)
- 一种表项同步方法,应用在跨设备链路聚合组网系统中的任一网关设备,所述方法包括:在接收到对端传输来的待处理报文时,确定本端存储的与所述待处理报文对应的目标表项,以及确定所述对端的SG端口状态;根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文。
- 根据权利要求1所述的表项同步方法,其中,所述根据本端存储的所述目标表项以及对端的SG端口状态,向所述对端发送关于所述目标表项的同步报文,包括:若本端存储有所述目标表项,以及所述对端的SG端口状态为目标状态,则向所述对端发送关于所述目标表项的同步报文,所述目标状态用于表示SG端口对应的通信链路正常。
- 根据权利要求1所述的表项同步方法,其中,所述方法还包括:在本端的SG端口状态发生变化时,将变化后的SG端口状态发送至对端;在接收到对端发送来的SG端口状态时,将所述对端发送来的SG端口状态存储至SG状态信息中;所述确定所述对端的SG端口状态包括:确定所述SG状态信息中最新的SG端口状态,并确定为所述对端的SG端口状态。
- 根据权利要求1所述的表项同步方法,其中,所述确定所述对端的SG端口状态包括:向对端发送状态查询报文,并接收所述对端返回的SG端口状态。
- 根据权利要求1所述的表项同步方法,其中,所述向所述对端发送关于所述目标表项的同步报文,包括:向所述对端发送关于所述目标表项的同步报文;若接收到对端传输来的和所述目标表项对应的待处理报文,则根据预设同步规则再次向所述对端发送关于所述目标表项的同步报文。
- 根据权利要求5所述的表项同步方法,其中,所述预设同步规则包括发送时间间隔和/或发送次数。
- 根据权利要求1所述的表项同步方法,其中,所述方法还包括:若本端没有存储与所述待处理报文对应的目标表项,或者若本端存储有所述目标表项以及对端的SG端口状态不是目标状态,则根据跨设备链路聚合传输规则发送所述待处理报文。
- 根据权利要求1至7任一项所述的表项同步方法,其中,所述方法还包括:在接收ARP应答报文时,确定本端是否发过与所述ARP应答报文对应的ARP请求,以及确定本端是否存储有与所述ARP应答报文对应的ARP表项;根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文。
- 根据权利要求8所述的表项同步方法,其中,所述根据本端是否发送过ARP请求和/或本端是否存储有与所述ARP应答报文对应的ARP表项,向所述对端发送与所述ARP应答报文对应的同步报文,包括:若本端没有与所述ARP应答报文对应的ARP表项,则根据所述ARP应答报文在本端添加ARP表项,以及向所述对端发送与所述ARP应答报文对应的同步报文;若本端发过与所述ARP应答报文对应的ARP请求,以及本端存储有与所述ARP应答报文对应的ARP表项,则根据所述ARP应答报文更新本端的ARP表项;若本端未发过与所述ARP应答报文对应的ARP请求,以及本端存储有与所述ARP应答报文对应的ARP表项,则向所述对端发送与所述ARP应答报文对应的同步报文。
- 一种网关设备,所述网关设备包括存储器和处理器;所述存储器设置为存储计算机程序;所述处理器,设置为执行所述计算机程序并在执行所述计算机程序时实现如权利要求1至9中任一项所述的表项同步方法。
- 一种组网系统,所述组网系统包括两个网关模块,所述网关模块设置为实现如权利要求1至9中任一项所述的表项同步方法。
- 一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时使所述处理器实现如权利要求1至9中任一项所述的表项同步方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP21812777.7A EP4161005A4 (en) | 2020-05-29 | 2021-05-13 | INPUT SYNCHRONIZATION METHOD, GATEWAY DEVICE, NETWORKING SYSTEM AND STORAGE MEDIUM |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010478532.1A CN113746733A (zh) | 2020-05-29 | 2020-05-29 | 表项同步方法、网关设备、组网系统及存储介质 |
CN202010478532.1 | 2020-05-29 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2021238672A1 true WO2021238672A1 (zh) | 2021-12-02 |
Family
ID=78724941
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/CN2021/093684 WO2021238672A1 (zh) | 2020-05-29 | 2021-05-13 | 表项同步方法、网关设备、组网系统及存储介质 |
Country Status (3)
Country | Link |
---|---|
EP (1) | EP4161005A4 (zh) |
CN (1) | CN113746733A (zh) |
WO (1) | WO2021238672A1 (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115225468A (zh) * | 2022-07-26 | 2022-10-21 | 苏州盛科通信股份有限公司 | 流量快速切换方法、系统及计算机可读存储介质 |
CN115883489A (zh) * | 2022-11-17 | 2023-03-31 | 浪潮思科网络科技有限公司 | 一种mlag协议表项同步方法、设备及介质 |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115174468A (zh) * | 2022-07-06 | 2022-10-11 | 中国联合网络通信集团有限公司 | 路由同步方法、跨设备链路聚合组、电子设备及介质 |
CN115333991B (zh) * | 2022-08-12 | 2023-06-13 | 迈普通信技术股份有限公司 | 跨设备链路聚合方法、装置、系统及计算机可读存储介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108173691A (zh) * | 2017-12-27 | 2018-06-15 | 杭州迪普科技股份有限公司 | 一种跨设备聚合的方法及装置 |
CN108259635A (zh) * | 2017-09-29 | 2018-07-06 | 新华三技术有限公司 | 一种arp表项学习方法和dr设备 |
CN109462515A (zh) * | 2018-09-11 | 2019-03-12 | 锐捷网络股份有限公司 | 环路处理方法、网络设备、mlag组网及存储介质 |
CN110351127A (zh) * | 2019-06-28 | 2019-10-18 | 迈普通信技术股份有限公司 | 一种优雅重启的方法、设备及系统 |
US20200036577A1 (en) * | 2018-07-25 | 2020-01-30 | Hewlett Packard Enterprise Development Lp | Solution to provide tunneling redundancy |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8787149B1 (en) * | 2012-02-01 | 2014-07-22 | Juniper Networks, Inc. | MAC address synchronization for multi-homing with multichassis link aggregation |
-
2020
- 2020-05-29 CN CN202010478532.1A patent/CN113746733A/zh active Pending
-
2021
- 2021-05-13 EP EP21812777.7A patent/EP4161005A4/en active Pending
- 2021-05-13 WO PCT/CN2021/093684 patent/WO2021238672A1/zh active Application Filing
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108259635A (zh) * | 2017-09-29 | 2018-07-06 | 新华三技术有限公司 | 一种arp表项学习方法和dr设备 |
CN108173691A (zh) * | 2017-12-27 | 2018-06-15 | 杭州迪普科技股份有限公司 | 一种跨设备聚合的方法及装置 |
US20200036577A1 (en) * | 2018-07-25 | 2020-01-30 | Hewlett Packard Enterprise Development Lp | Solution to provide tunneling redundancy |
CN109462515A (zh) * | 2018-09-11 | 2019-03-12 | 锐捷网络股份有限公司 | 环路处理方法、网络设备、mlag组网及存储介质 |
CN110351127A (zh) * | 2019-06-28 | 2019-10-18 | 迈普通信技术股份有限公司 | 一种优雅重启的方法、设备及系统 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115225468A (zh) * | 2022-07-26 | 2022-10-21 | 苏州盛科通信股份有限公司 | 流量快速切换方法、系统及计算机可读存储介质 |
CN115883489A (zh) * | 2022-11-17 | 2023-03-31 | 浪潮思科网络科技有限公司 | 一种mlag协议表项同步方法、设备及介质 |
Also Published As
Publication number | Publication date |
---|---|
EP4161005A4 (en) | 2023-11-08 |
CN113746733A (zh) | 2021-12-03 |
EP4161005A1 (en) | 2023-04-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2021238672A1 (zh) | 表项同步方法、网关设备、组网系统及存储介质 | |
EP3367619B1 (en) | Synchronizing multicast state between multi-homed routers in an ethernet virtual private network | |
US9686098B2 (en) | Efficient management of ring networks | |
CN102377666B (zh) | 具有平均速率和突发速率控制的基于泛洪的路由协议 | |
US9077617B1 (en) | Kernel-based TCP-layer assist for fast recovery by backup control unit of a device | |
WO2021043086A1 (zh) | 一种sbfd会话的建立方法、设备及系统 | |
US9385944B2 (en) | Communication system, path switching method and communication device | |
US8184650B2 (en) | Filtering of redundant frames in a network node | |
TWI740210B (zh) | 終端設備管理方法及伺服器 | |
CN110650078B (zh) | 协调伪线连接特征和多宿主提供者边缘设备能力 | |
WO2020001389A1 (zh) | 一种避免环路的通信方法、设备和系统 | |
WO2021082803A1 (zh) | 路由信息传输方法及装置、数据中心互联网络 | |
CN110838935A (zh) | 高可用sdn控制器集群方法、系统、存储介质及设备 | |
US11962507B1 (en) | Estimating standby socket window size during asynchronous socket replication | |
US20230111966A1 (en) | Ethernet storage system, and information notification method and related apparatus thereof | |
US11683379B2 (en) | Efficient message transmission and loop avoidance in an RPL network | |
WO2019113786A1 (zh) | Tfo传输方法、代理服务器和系统 | |
WO2015184759A1 (zh) | 一种服务网口状态检测和容错的装置及其方法 | |
WO2023184926A1 (zh) | 多路径端到端时延的监测方法、装置、电子设备及介质 | |
CN112398731B (zh) | 一种处理报文的方法和第一网络设备 | |
WO2021057672A1 (zh) | 一种序列号同步的方法及装置 | |
JP4430031B2 (ja) | ネットワーク中継方法、ネットワーク要素およびネットワーク中継システム | |
CN106656835A (zh) | 多ospf协议执行单元的并行单一呈现系统及方法 | |
US11212217B2 (en) | Spanning tree enabled link aggregation system | |
WO2022194193A1 (zh) | 用于获取路径的方法和装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 21812777 Country of ref document: EP Kind code of ref document: A1 |
|
WWE | Wipo information: entry into national phase |
Ref document number: 202217068375 Country of ref document: IN |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
ENP | Entry into the national phase |
Ref document number: 2021812777 Country of ref document: EP Effective date: 20230102 |