Various exemplary embodiments disclosed herein relate to reporting interruption of traffic in Ethernet rings.
A brief summary of various embodiments is presented below. Some simplifications and omissions may be made in the following summary, which is intended to highlight and introduce some aspects of the various embodiments, but not to limit the scope of the invention. Detailed descriptions of embodiments adequate to allow those of ordinary skill in the art to make and use the inventive concepts will follow in later sections.
Various embodiments include a method of determining, by a network manager, a failure in a ring communications network, including determining a plurality of ring segments within different services of a plurality of services using the ring communications network, determining that there are two or more link failures in the ring communications network, determining the ring segments where the two or more link failures are located, and indicating an interruption of one of the services when the two or more failed links are on different ring segments.
The method may include indicating no interruption of one of the services when the two failed links are on the same ring segment.
The method may include monitoring channeling traffic by a ring owner around the ring communications network in a first direction, and monitoring channeling of the traffic by the ring owner around the ring communications network in a second direction opposite to the first direction when the two failed links are on the same ring segment.
The network manager may be notified by a network element in the ring of the failed links.
The services may be ethernet services. The traffic may be ethernet traffic.
Various embodiments also include a network manager configured to manage a failure in a ring communications network, including a network interface, a memory device, and a processor in communication with the interface memory device, the processor being configured to determine a plurality of ring segments within different services of a plurality of services using the ring communications network, determine that there are two link failures in the ring communications network, determine the segments where the two link failures are located, and indicate an interruption of one of the services when the two failed links are on different ring segments.
The network manager processor may indicate no interruption of one of the services when the two failed links are on the same ring segment.
The network manager processor may monitor channeling of traffic by a ring owner around the ring communications network in a first direction and monitors channeling of the traffic by a ring owner around the ring communications network in a second direction opposite to the first direction when the two failed links are on the same ring segment.
Additional objects and features of the invention will be more readily apparent from the following detailed description and appended claims when taken in conjunction with the drawings. Although several embodiments are illustrated and described, like reference numerals identify like parts in each of the figures, in which:
It should be understood that the figures are merely schematic and are not drawn to scale. It should also be understood that the same reference numerals are used throughout the figures to indicate the same or similar parts.
The descriptions and drawings illustrate the principles of various example embodiments. It will thus be appreciated that those skilled in the art will be able to devise various arrangements that, although not explicitly described or shown herein, embody the principles of the invention and are included within its scope. Furthermore, all examples recited herein are principally intended expressly to be for pedagogical purposes to aid the reader in understanding the principles of the invention and the concepts contributed by the inventor(s) to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions. Additionally, the term, “or,” as used herein, refers to a non-exclusive or (i.e., and/or), unless otherwise indicated (e.g., “or else” or “or in the alternative”). Also, the various embodiments described herein are not necessarily mutually exclusive, as some embodiments can be combined with one or more other embodiments to form new embodiments. Descriptors such as “first,” “second,” “third,” etc., are not meant to limit the order of elements discussed, are used to distinguish one element from the next, and are generally interchangeable. Values such as maximum or minimum may be predetermined and set to different values based on the application.
One issue that arises in ethernet rings is how to determine a status of the ethernet ring. A ring may be deemed operational when traffic can flow in both directions between network devices and ethernet services, inoperational where no traffic flows, or partially operational where data may flow in one direction or may flow between specific network devices or ethernet services. In ethernet rings, different identification numbers and labels are assigned to different components of a ring such that various portions of a ring may be monitored.
The ring 100 may have a plurality of demarcation points. Ingress and egress access to the ring 100 may be controlled by a plurality of network devices 130A, 130B, 130C, 130D, 130E, 130F, 130G, and 130H. The number of networks devices are not limited to this amount and may span into the hundreds and thousands. A network device may also be referred to as an owner, for example 130A. The owner network device 130A may control the amount of traffic passing there through and the direction the device 130A wants data traffic to flow around the ring 100. Connections between the network devices 130A-130H may be made through ethernet links. An interface between network device 130A and network device 130B, for example, may be a ethernet link 140A. Additional ethernet links between the network devices 130B-130H are shown as ethernet links 140B-140H. Because traffic may flow in two directions, the failure of a ethernet link 140A within the ring 100 does not cause any traffic flow disruption, for example, because the traffic can be reversed and continue to flow in another direction 120 between any two network devices on the ethernet ring 100. Failure of an ethernet link may also be referred to as a change in operational state.
The network devices 130A-130H that make up a ring may have a purpose of connecting ethernet services that use the network devices 130A-130H. As illustrated in
For a network manager one challenge is to calculate an impact on each ethernet service 150A-150D that uses an ethernet ring 100 when more than one ethernet link within the ethernet ring 100 has failed. Network management systems can provide information to neighboring devices and systems to inform devices and systems of what resources are available, which are offline, inoperational, or partially operational. Network management systems may also provide this information to human network operators. Network management systems do not want to over-report or under-report failures within a network.
In some embodiments, a network owner such as owner network device 130A will desire to pass traffic coming in from ethernet service 150A to network device 130B, for example. To route the traffic, instead of leaving open both directions of the ring 100, the owner network device 130A may prevent access to the ethernet link 140H, and direct ethernet traffic in a clockwise direction 110 along ethernet link 140A. In this manner, traffic can be managed in one direction by the owner network device 130A. If a failure occurs, the owner network device 130A may block off access to ethernet link 140A, unblock path 140H, and route traffic to ethernet link 140H to restore the data transmission path through the ethernet ring 100.
For example, traffic from ethernet service 150A may need to be routed to ethernet service 150C along path including ethernet links 140A, 140B, and 140C. If one of the ethernet links 140A, 140B, or 140C should fail or change operational state, the network device 130A may re-route data traffic along ethernet links 140H, 140G, 140F, 140E, and 140D in the opposite direction 120 to reach ethernet service 150C.
A problem may arise in determining the functionality of a ring in which multiple ethernet links fail or change operational state in different parts of an ethernet ring 100, and determining which, if any, parts of the ethernet ring 100 are still operational.
A solution may require that at least two ethernet links must be inoperational in order for one or more ethernet services using the ring 100 to be inoperational. However, this strategy may significantly over-report ethernet service disruption because some ethernet services may still be accessible.
Numerous algorithms could be postulated that require extensive calculations to determine the per service impact of multiple inoperable interfaces within an ethernet ring. Those calculations would increase either the time required to complete the calculation for each ethernet service and/or the amount of computer resources required to perform that calculation. In large rings and networks this may increase the loading of the network manager to undesirable levels.
For each ethernet service 150A-150D, the ethernet ring 100 may be partitioned into ring segments 160A, 160B, 160C, and 160D, where each ring segment is a combination of ethernet links 140A-140H within services of two ethernet service terminations. Ring segments 160A-160D are used as an example, as one skilled in the art would be able to determine that numerous ring segments may be used based on the size of a ring and a number of ethernet services and ethernet links included therein. Referring to
Embodiments described herein may include a network manager 190. The network manager 190 may monitor an operational status of an ethernet ring 100. The network manager 190 may communicate with network devices 130A-130H within the ethernet ring 100, and ethernet services 150A-150D. The network manager 190 may also communicate with network devices in external ethernet rings and ethernet services. This communication with the network manager 190 may use any of the various devices in the network.
Referring to ring segment 160B, in one embodiment, if both ethernet links 140B and 140C fail, the network manager 190 could determine that two ethernet links are down, therefore the whole ethernet ring 100 is down, and network devices would be notified that none of the ethernet services of the ring 100 are available. The network manager 190 may be notified of failed link(s) by a ring owner or network element(s) within the ring 100 that is connected to the failed link(s). This is an overly conservative approach, as ethernet ring 100 is still able to connect each of the different ethernet services 150A-150D through an alternative direction of traffic flow.
In one embodiment, the network manager 190 would recognize that the failure of two ethernet links 140B and 140C are within the same ring segment 160B, and the network manager 190 would inform devices within the ethernet ring 100 and other devices in other rings that ethernet services are still available, based on the determination that both ethernet links 140B and 140C are in the same ring segment 160B. However if a determination is made that an ethernet link in both ring segments 160A and 160B are down, then the network manager 190 would inform other entities within and outside the ring 100 that traffic to and from ethernet service 150B is interrupted, until one of the ring segments 160A or 160B is repaired.
Ring segment 160C encompasses ethernet links 140D, 140E, and 140F, as well as network devices 130E and 130F. If a plurality of the devices or ethernet links that make up the ring segment 160C should fail, the network manger 190 would determine that only service between ethernet service 150C and ethernet service 150D is interrupted in one direction from network device 130D to network device 130G for example in direction 110, but traffic could still flow in the other direction 120 around the ring 100 from network device 130D to network device 130G.
For a given ethernet ring, the ethernet ring is inoperational if two or more ring segments are inoperational, the determination being made by the network manager. At step 240, the network manager may determine that the number of faults is two or more. In previous embodiments, if a system determines that a number of faults is two or more, a network manager may over-report that any service that includes the ring is inoperational or down, thus wasting valuable resources and time. Here, in step 250, a determination is made whether the two or more ethernet links that are down are within the same ring segment. If the two or more ethernet links are in the same ring segment (Yes), then the network manager monitors an ethernet ring owner that re-routes traffic in the other direction to the particular destination. If in step 250 it is determined by the network manager that the ethernet links are not in the same ring segment (NO), then the network manager will determine which network service is not available, will determine based on the placement of the faults which ethernet services still are available, and will continue to monitor traffic through the ring to the available devices and ethernet services. Thus, using the ring structure and methods described herein, faults of two or more ethernet links will not automatically shut the ethernet ring down, which may provide an efficient calculation of per service impact of ethernet ring status changes.
This concept may be extended to an arbitrary number of ethernet rings, an arbitrary number of ethernet services, and a “many to many” relationship among them in which each ethernet service can use multiple ethernet rings, and each ethernet ring can be used by multiple ethernet services. For ethernet services that use multiple ethernet rings, the preceding calculation is performed independently on each ethernet ring.
The processor 320 may be any hardware device capable of executing instructions stored in memory 330 or storage 360 or otherwise processing data. As such, the processor may include a microprocessor, field programmable gate array (FPGA), application-specific integrated circuit (ASIC), or other similar devices.
The memory 330 may include various memories such as, for example L1, L2, or L3 cache or system memory. As such, the memory 330 may include static random access memory (SRAM), dynamic RAM (DRAM), flash memory, read only memory (ROM), or other similar memory devices.
The user interface 340 may include one or more devices for enabling communication with a user such as an administrator. For example, the user interface 340 may include a display, a mouse, and a keyboard for receiving user commands. In some embodiments, the user interface 340 may include a command line interface or graphical user interface that may be presented to a remote terminal via the network interface 350.
The network interface 350 may include one or more devices for enabling communication with other hardware devices. For example, the network interface 350 may include a network interface card (NIC) configured to communicate according to the Ethernet protocol. Additionally, the network interface 350 may implement a TCP/IP stack for communication according to the TCP/IP protocols. Various alternative or additional hardware or configurations for the network interface 350 will be apparent.
The storage 360 may include one or more machine-readable storage media such as read-only memory (ROM), random-access memory (RAM), magnetic disk storage media, optical storage media, flash-memory devices, or similar storage media. In various embodiments, the storage 360 may store instructions for execution by the processor 320 or data upon with the processor 320 may operate. For example, the storage 360 may store a base operating system 361 for controlling various basic operations of the hardware 300.
It will be apparent that various information described as stored in the storage 360 may be additionally or alternatively stored in the memory 330. In this respect, the memory 330 may also be considered to constitute a “storage device” and the storage 360 may be considered a “memory.” Various other arrangements will be apparent. Further, the memory 330 and storage 360 may both be considered to be “non-transitory machine-readable media.” As used herein, the term “non-transitory” will be understood to exclude transitory signals but to include all forms of storage, including both volatile and non-volatile memories.
While the host device 300 is shown as including one of each described component, the various components may be duplicated in various embodiments. For example, the processor 320 may include multiple microprocessors that are configured to independently execute the methods described herein or are configured to perform steps or subroutines of the methods described herein such that the multiple processors cooperate to achieve the functionality described herein. Further, where the device 300 is implemented in a cloud computing system, the various hardware components may belong to separate physical systems. For example, the processor 320 may include a first processor in a first server and a second processor in a second server.
It should be apparent from the foregoing description that various exemplary embodiments of the invention may be implemented in hardware or firmware. Furthermore, various exemplary embodiments may be implemented as instructions stored on a machine-readable storage medium, which may be read and executed by at least one processor to perform the operations described in detail herein. A machine-readable storage medium may include any mechanism for storing information in a form readable by a machine, such as a personal or laptop computer, a server, or other computing device. Thus, a tangible and non-transitory machine-readable storage medium may include read-only memory (ROM), random-access memory (RAM), magnetic disk storage media, optical storage media, flash-memory devices, and similar storage media. Further, as used herein, the term “processor” will be understood to encompass a microprocessor, field programmable gate array (FPGA), application-specific integrated circuit (ASIC), or any other device capable of performing the functions described herein.
It should be appreciated by those skilled in the art that any block diagrams herein represent conceptual views of illustrative circuitry embodying the principles of the invention. Similarly, it will be appreciated that any flow charts, flow diagrams, state transition diagrams, pseudo code, and the like represent various processes which may be substantially represented in machine readable media and so executed by a computer or processor, whether or not such computer or processor is explicitly shown.
Although the various embodiments have been described in detail with particular reference to certain aspects thereof, it should be understood that the embodiments described herein are capable of other embodiments and its details are capable of modifications in various obvious respects. As is readily apparent to those skilled in the art, variations and modifications can be effected while remaining within the spirit and scope of the embodiments described herein. Accordingly, the foregoing disclosure, description, and figures are for illustrative purposes only and do not in any way limit the embodiments described herein, which is defined only by the claims.