The present disclosure relates generally to communicating information over a network between two networked devices.
The communications industry is rapidly changing to adjust to emerging technologies and ever increasing customer demand. This customer demand for new applications and increased performance of existing applications is driving communications network and system providers to employ networks and systems having greater speed and capacity (e.g., greater bandwidth). In trying to achieve these goals, a common approach taken by many communications providers is to use packet switching technology.
Reliably communicating information in a network is important. Different techniques are employed, including those included in a protocol used to communicate packets, as well as path protection for being able to quickly reroute traffic when a particular path no longer becomes available.
The appended claims set forth the features of one or more embodiments with particularity. The embodiment(s), together with its advantages, may be best understood from the following detailed description taken in conjunction with the accompanying drawings of which:
1. Overview
Disclosed are, inter alia, methods, apparatus, computer-storage media, mechanisms, and means associated with reliably transporting packet streams using packet replication. One embodiment receives one or more packet streams at a duplication point in a network, and transmits two or more copies of each of these packet stream(s), typically over divergent paths in the network, to a merge point from which a single copy of each packet stream is forwarded or consumed.
In one embodiment, this merge point is a packet switching device that includes ingress card(s) and egress line card(s), wherein multiple copies of the packet stream are received by ingress line card(s), with only a single copy provided to an egress line card of the packet switching device. In this manner, a switching fabric or other communication mechanism communicatively coupling the ingress line card(s) to the egress line card, nor the egress line card, is taxed with the burden imposed by additional copies of packet stream(s).
In one embodiment, a distributed mechanism is used to coordinate the switching between which streams of packets are forwarded to the egress line card by including in each packet stream a protection marker identifying a same position in the stream of packets, and identifying to switch a packet stream from being in an active state to a protect state (to now drop packets), or from being in a protect state to an active state (to now forward packets to the egress line card).
In one embodiment, in response to a failure, such as a loss in receiving an active packet stream or loss of an ingress line card on which the active packet stream is received while a corresponding protect stream is still being received, the packet switching device changes the protect stream to an active stream so that the packet switching device is able to quickly resume sending packets of the packet stream.
2. Description
Disclosed are, inter alia, methods, apparatus, computer-storage media, mechanisms, and means associated with reliably transporting packet streams using packet replication. Embodiments described herein include various elements and limitations, with no one element or limitation contemplated as being a critical element or limitation. Each of the claims individually recites an aspect of the embodiment in its entirety. Moreover, some embodiments described may include, but are not limited to, inter alia, systems, networks, integrated circuit chips, embedded processors, ASICs, methods, and computer-readable media containing instructions. One or multiple systems, devices, components, etc. may comprise one or more embodiments, which may include some elements or limitations of a claim being performed by the same or different systems, devices, components, etc. A processing element may be a general processor, task-specific processor, a core of one or more processors, or other co-located, resource-sharing implementation for performing the corresponding processing. The embodiments described hereinafter embody various aspects and configurations, with the figures illustrating exemplary and non-limiting configurations. Note, computer-readable media and means for performing methods and processing block operations (e.g., a processor and memory or other apparatus configured to perform such operations) are disclosed and are in keeping with the extensible scope and spirit of the embodiments. Note, the term “apparatus” is used consistently herein with its common definition of an appliance or device.
Note, the steps, connections, and processing of signals and information illustrated in the figures, including, but not limited to, any block and flow diagrams and message sequence charts, may typically be performed in the same or in a different serial or parallel ordering and/or by different components and/or processes, threads, etc., and/or over different connections and be combined with other functions in other embodiments, unless this disables the embodiment or a sequence is explicitly or implicitly required (e.g., for a sequence of read the value, process said read value—the value must be obtained prior to processing it, although some of the associated processing may be performed prior to, concurrently with, and/or after the read operation). Also note, nothing described or referenced in this document is admitted as prior art to this application unless explicitly so stated.
The term “one embodiment” is used herein to reference a particular embodiment, wherein each reference to “one embodiment” may refer to a different embodiment, and the use of the term repeatedly herein in describing associated features, elements and/or limitations does not establish a cumulative set of associated features, elements and/or limitations that each and every embodiment must include, although an embodiment typically may include all these features, elements and/or limitations. In addition, the terms “first,” “second,” etc. are typically used herein to denote different units (e.g., a first element, a second element). The use of these terms herein does not necessarily connote an ordering such as one unit or event occurring or coming before another, but rather provides a mechanism to distinguish between particular units. Moreover, the phrases “based on x” and “in response to x” are used to indicate a minimum set of items “x” from which something is derived or caused, wherein “x” is extensible and does not necessarily describe a complete list of items on which the operation is performed, etc. Additionally, the phrase “coupled to” is used to indicate some level of direct or indirect connection between two elements or devices, with the coupling device or devices modifying or not modifying the coupled signal or communicated information. Moreover, the term “or” is used herein to identify a selection of one or more, including all, of the conjunctive items. Additionally, the transitional term “comprising,” which is synonymous with “including,” “containing,” or “characterized by,” is inclusive or open-ended and does not exclude additional, unrecited elements or method steps. Finally, the term “particular machine,” when recited in a method claim for performing steps, refers to a particular machine within the 35 USC §101 machine statutory class.
Expressly turning to the figures, an unlimited number of network configurations could operate according to one embodiment.
In one embodiment, packet switching device 101 receives one or more original packet streams, and transmits a copy of each of these original packet stream(s) over each of paths 111 and 112 to packet switching device 103. Packet switching device 103 sends from itself a single copy of each original packet stream packet, in-order, and without missing any packets, while dropping one received copy of the original packet stream. In one embodiment, one of these two packet streams received by packet switching device 103 is designated as being in the active state, while the other is in a protect state. In case of a switchover, the two packet streams switch roles of being in the active/protect states, typically while sending a single copy of each original packet stream packet, in-order, and without missing or duplicated any packets. In one embodiment, packet switching device 103 receives multiple copies of one or more original streams of packets, and sends from itself a single copy of each original packet stream packet, in-order, and without missing any packets, while dropping one received copy of the original packet stream.
One embodiment of a packet switching device 200 is illustrated in
In one embodiment, each of two line cards 201 (or a same line card) receives copies of packets of an original packet stream (which causes each of these line cards to be considered an “ingress” line card as they are receiving packets), and a line card 205 sends from packet switching device 200 a single copy of the original packet stream (which deems that line card an “egress” line card). As can be observed in
In one embodiment, apparatus 220 includes one or more processing element(s) 221, memory 222, storage device(s) 223, specialized component(s) 225 (e.g. optimized hardware such as for performing lookup and/or packet processing operations, etc.), and interface(s) 227 for communicating information (e.g., sending and receiving packets, user-interfaces, displaying information, etc.), which are typically communicatively coupled via one or more communications mechanisms 229, with the communications paths typically tailored to meet the needs of a particular application.
Various embodiments of apparatus 220 may include more or fewer elements. The operation of apparatus 220 is typically controlled by processing element(s) 221 using memory 222 and storage device(s) 223 to perform one or more tasks or processes. Memory 222 is one type of computer-readable/computer-storage medium, and typically comprises random access memory (RAM), read only memory (ROM), flash memory, integrated circuits, and/or other memory components. Memory 222 typically stores computer-executable instructions to be executed by processing element(s) 221 and/or data which is manipulated by processing element(s) 221 for implementing functionality in accordance with an embodiment. Storage device(s) 223 are another type of computer-readable medium, and typically comprise solid state storage media, disk drives, diskettes, networked services, tape drives, and other storage devices. Storage device(s) 223 typically store computer-executable instructions to be executed by processing element(s) 221 and/or data which is manipulated by processing element(s) 221 for implementing functionality in accordance with an embodiment.
In one embodiment, in response to a detected failure (e.g., based on a timeout or other mechanism) in egress line card 313 receiving packets in the active stream, ingress line card 311 will commence forwarding packets of the protect stream (that it was previously dropping) to egress line card 313, so egress line card 313 can resume sending out or otherwise processing packets of the original packet stream, while reducing the delay in its resumption and the number of missing packets in the sent out version of the original packet stream.
Illustrated in
In one embodiment, a same duplicate-stream value is included in each packet of a same replicated stream (whether in the active or protect state), which simplifies correlation at a merge point in the network as no signaling is required to associate a stream in an active state with its corresponding stream in a protect state (when it is known that particular active and protect tunnels are associated with each other). In one embodiment, each duplicate-stream value uniquely identifies a duplication point in a network for a stream of packets. Therefore, the range of values required for a duplicate-stream value can be readily known by the configuration of packet switching device 500. In one embodiment, each ingress line card deterministically determines the duplicate-stream value based on hashing, or otherwise computing, the duplicate-stream value based on an identification of the duplication point (e.g., by processor one on line card two), thus, requiring no centralized distribution of duplicate-stream values.
In one embodiment, an active and/or protect packet stream may be transported across a LAG, with different packets of the active and/or protect stream transported across a different portion of a path. One embodiment assigns duplicate-stream values, which may be modified (e.g., concatenated with a LAG or other sub-path value), such that a merge point in the network receives packets whose path taken is uniquely identified by the duplicate-stream value received by the merge point (e.g., packet switching device). In one embodiment, each duplicated packet in an active state and its counterpart(s) in a protect state have the same duplicate-stream value.
As part of reliably transporting packet streams using packet replication, it may be necessary, or otherwise desirous, to switch an active stream to being a protect steam, and a protect stream to an active steam. As previously discussed, in case of a detected failure, packets of one or more protected streams are no longer dropped by an ingress line card of a merge point (e.g., packet switching device), and therefore, the egress line card may be able to quickly resume forwarding (or otherwise processing) packets of the original stream of packets (depending on the amount of failure in the network and/or packet switching device).
A more graceful transition of streams of packets from an active mode to a protect mode while simultaneously transitioning a corresponding stream of packets from a protect mode to the active mode is illustrated by the processes of
Otherwise, in process block 703, the received packet was from a packet stream in the protect state. If the received packet does not include a protect marker as determined in process block 711, then in process block 712, the packet is dropped at the ingress line card. Otherwise, in process block 714, the protect stream of the duplicate-stream value of the tunnel on which it was received is placed in an active mode, and processing returns to process block 701.
As determined in process block 803, if the packet is from a protect packet stream as determined based on the tunnel in which it was received and its duplicate-stream value (tunnel-duplicate-stream value abbreviated as T-DSV), then, in process block 804, the packet is buffered for the tunnel/duplicate-stream value as a marker packet has not been received in the active stream yet; thus, the sending or otherwise processing of this packet must be delayed to maintain the order of the original packet stream.
Otherwise, as determined in process block 803, the packet is part of the active stream and then as determined in process block 805, if the received packet of the active stream is not a marker packet, then in process block 806, the packet is either immediately sent out or placed at the end of a buffer of packets for the duplicate-stream value/tunnel on which the packet was received at least if there are any corresponding residual packets from a switchover.
Otherwise, the received packet in the active stream is a marker packet, and processing proceeds to process block 808, wherein the state of the duplicate-stream value/tunnel on which the packet was received is changed from active state to a protect state. In process block 810, a corresponding protect state packet stream is switched from a protect state to an active state. In process block 812, all buffered packets (i.e., buffered in process block 804) from the old protect state packet stream just switched to the active state in process block 810, are sent out. Processing returns to process block 801.
In view of the many possible embodiments to which the principles of the disclosure may be applied, it will be appreciated that the embodiments and aspects thereof described herein with respect to the drawings/figures are only illustrative and should not be taken as limiting the scope of the disclosure. For example, and as would be apparent to one skilled in the art, many of the process block operations can be re-ordered to be performed before, after, or substantially concurrent with other operations. Also, many different forms of data structures could be used in various embodiments. The disclosure as described herein contemplates all such embodiments as may come within the scope of the following claims and equivalents thereof.
Number | Name | Date | Kind |
---|---|---|---|
5404352 | Pauwels et al. | Apr 1995 | A |
6144640 | Simpson et al. | Nov 2000 | A |
6493315 | Simpson et al. | Dec 2002 | B1 |
7031304 | Arberg et al. | Apr 2006 | B1 |
7133415 | Zelig et al. | Nov 2006 | B2 |
7197008 | Shabtay et al. | Mar 2007 | B1 |
7310306 | Cheriton | Dec 2007 | B1 |
7715309 | Scholl et al. | May 2010 | B2 |
7720055 | Kadambi et al. | May 2010 | B2 |
7773578 | Liu | Aug 2010 | B2 |
7890991 | Kay | Feb 2011 | B2 |
7940777 | Asati et al. | May 2011 | B2 |
7961755 | Harel et al. | Jun 2011 | B2 |
7969970 | Burchard et al. | Jun 2011 | B2 |
8064336 | Scholl et al. | Nov 2011 | B2 |
8873567 | Mandal et al. | Oct 2014 | B1 |
20020021661 | DeGrandepre et al. | Feb 2002 | A1 |
20020080786 | Roberts | Jun 2002 | A1 |
20030041208 | Volkmar | Feb 2003 | A1 |
20050201273 | Shimizu | Sep 2005 | A1 |
20060013210 | Bordogna et al. | Jan 2006 | A1 |
20060140226 | Ho et al. | Jun 2006 | A1 |
20060268686 | Shei et al. | Nov 2006 | A1 |
20070002770 | Haalen et al. | Jan 2007 | A1 |
20090129262 | Honma | May 2009 | A1 |
20090135890 | Chan et al. | May 2009 | A1 |
20090154342 | Oltman et al. | Jun 2009 | A1 |
20090154461 | Kitani et al. | Jun 2009 | A1 |
20090238184 | Darnell et al. | Sep 2009 | A1 |
20100008359 | Kay | Jan 2010 | A1 |
20100014428 | Naven et al. | Jan 2010 | A1 |
20100085873 | Moons | Apr 2010 | A1 |
20100172361 | Scholl et al. | Jul 2010 | A1 |
20100189116 | Brolin | Jul 2010 | A1 |
20100232428 | Shinohara | Sep 2010 | A1 |
20100235593 | Yadav et al. | Sep 2010 | A1 |
20100284401 | Beshai | Nov 2010 | A1 |
20100303083 | Belanger et al. | Dec 2010 | A1 |
20100312943 | Uehara et al. | Dec 2010 | A1 |
20100316053 | Miyoshi et al. | Dec 2010 | A1 |
20110085545 | Tadimeti et al. | Apr 2011 | A1 |
20110197011 | Suzuki et al. | Aug 2011 | A1 |
20110211443 | Leong et al. | Sep 2011 | A1 |
20110222534 | Kurita | Sep 2011 | A1 |
20110228778 | Dyke et al. | Sep 2011 | A1 |
20130114593 | Jabr et al. | May 2013 | A1 |
20130201826 | Testa et al. | Aug 2013 | A1 |
20140064292 | Binetti et al. | Mar 2014 | A1 |
Number | Date | Country | |
---|---|---|---|
20140029622 A1 | Jan 2014 | US |