This invention relates to communication networks, and in particular to a system and method for providing transparent LAN (Local Area Network) services.
Many network users, such as companies, have multiple sites within a metro area or region and desire to provide “internal” or LAN-like network connectivity between those locations, each of which may comprise an intranet. In addition, some of these network users desire network connections that are still somewhat private with suppliers and customers, or an extranet network connection.
Conventionally, network users have relied on point-to-point private line circuits and shared WAN (wide area network) technologies, such as frame relay and ATM (Asynchronous Transfer Mode) technologies.
In some applications, use of the foregoing approaches is limited in providing network users an efficient, scalable solution. For example, network users using point-to-point private line circuits typically require a separate point-to-point private line circuit for each pair of locations, or sites. Consequently, a network user having four locations requires six point-to-point private line circuits and a network user having six locations requires fifteen point-to-point private line circuits. Thus, the point-to-point private line circuit solution is not easily scalable and for large numbers of locations even larger numbers of point-to-point private line circuits are necessary. Indeed, for large numbers of locations, a point-to-point private line circuit solution can be expensive due to the cost of establishing and maintaining the various point-to-point private line circuits.
In addition, the point-to-point private line circuit solution is not bandwidth efficient. That is, unused bandwidth on some of the point-to-point private line circuits is not typically available for routing network traffic traversing other of the point-to-point private line circuits. The point-to-point private line circuit solution is further inefficient since data packets sent to all locations must be set over each of the multiple point-to-point private line circuits.
Accordingly, a need exists for a system and method for providing LAN-type network connectivity between multiple locations of a network user that is bandwidth efficient and highly scalable. An additional need exists to provide such a system and method that is easily provisioned and managed.
This invention relates to communication networks, and in particular to a system and method for providing transparent LAN (Local Area Network) services.
In one embodiment, data packets are broadcast over a ring only to members of a particular domain using multicast MPLS protocol so that the data packets are forwarded to members of the particular domain only and not to other domains that are also connected to the same ring.
Pursuant to another aspect of the present invention, bandwidth efficiency is achieved by using native layer two broadcast of multicast MPLS data packet over a fiber optic ring having a Resilient Packet Ring (RPR) topology. Hence, a separate packet need not be sent to each of the nodes. Rather, a single multicast MPLS data packet is sent over the ring. By sending one, rather than several, MPLS data packet over the ring, bandwidth efficiency is achieved.
Another aspect of the present invention provides the ability to specify SLA (Service Level Agreement) guarantees, or QoS (Quality of Service) for each domain. For example, the nodes may limit the maximum amount of bandwidth each member of a domain may send or receive, the maximum amount of bandwidth the domain may use, and the type and quality of service provided to the members of the domain.
Further, a management console may be used to remotely provision, manage, and monitor network usage. In one embodiment, a user at the management console may configure a node via a graphical user interface to perform network provisioning.
Yet another aspect of the present invention provides a service header in the multicast MPLS data packet for communication of service level parameters. The service header may include the unicast label, a version field, and the IP address of the source. Thus, upon receipt of a data packet having a service header, the nodes receiving this unicast label store the unicast label and the IP address of the source. Hence, when the node needs to send a data packet to that source as a destination, the node may unicast the data packet to the appropriate node using the unicast label rather than sending the data packet to all nodes.
In operation, in accordance with one embodiment, a transmitting device belonging to a domain and connected to one of the nodes sends a data packet destined for another member of the domain over the ring. The data packet sent by the transmitting device includes a destination MAC address, a source MAC address, and a payload. The node to which the transmitting device is connected receives the data packet sent by the transmitting device and appends a unicast MPLS label, a multicast MPLS label, and a ring header to form a ring packet. The node then transmits the ring packet over the ring.
Each of the nodes on the ring receives the ring packet and inspects the multicast MPLS label to determine whether any members of the domain associated with the multicast MPLS label are connected to physical ports of the receiving node. If no members of the domain associated with the multicast MPLS label are connected to physical ports of a given node, that node passes the packet to other nodes on the ring without sending a copy of the packet on any of the customer ports of the node. Otherwise, the node strips off the ring header, the multicast MPLS label, and the unicast label and forwards the packet, as transmitted by the transmitting device, to the destination device.
The node also maintains an association table that associates the unicast label, or source label, and the source IP address with the source MAC address of the transmitting device. Thus, for future data transmissions to a device having that source MAC address, the node may unicast the data packet by appending the known unicast MPLS label associated with the device having that source address and a ring header, rather than multicasting the data packet, thereby furthering bandwidth efficiency.
Additional details regarding the present system and method may be understood by reference to the following detailed description when read in conjunction with the accompanying drawings.
Common reference numerals are used throughout the drawings and detailed description to indicate like elements.
Multiple transparent LAN services (TLS) domains, such as domains A and B may co-exist on the ring 102. A TLS domain may be identified by a port of a slot of a node. As discussed below, each TLS domain has an associated multicast MPLS label; each site within a TLS domain has a unique site ID. Thus, the multicast label may be used to send data to the various ports of the various nodes belonging to the domain associated with the multicast label.
In one embodiment, domain A may represent one network customer and domain B may represent another network customer where each of the customers has multiple locations, or sites. As illustrated, the network customer of domain A has multiple locations 120, 122, 124, and 126. Each of these locations may comprise a LAN. The location 120 is connected to node 110, the location 122 is connected to node 108, and locations 124, 126 are connected to node 106. In this configuration, the locations 120 and 122 may thus exchange data with each other over the ring 102 rather than over a point-to-point private line circuit. Further, the locations 124, 126 may also exchange data with locations 120 and 122 over the ring 102.
Each of the nodes 104-110 may include physical ports, such as Ethernet and Gigabit Ethernet ports. These physical ports may be configured to be a part of any of the domains A, B of the ring 102. In some embodiments, a physical port may be configured to be a part of multiple domains by virtue of subports (e.g., logical ports). Pursuant to the configuration of FIG. I, the membership in the domains A and B does not extend beyond the ring 102.
Further, as shown, multiple locations, or sites, 124, 126 of a single domain, such as domain A, may be supported by a single node, such as the node 106. In addition, QoS (Quality of Service) may be supported for each of the domains A, B.
In the configuration of FIG. I, transparent LAN services may be provided for each of the domains A and B. Pursuant to one embodiment, an endpoint device, such as a personal computer, of domain A may send a data packet to another endpoint device of domain A using multicast MPLS (Multi Protocol Label Switching) protocol. Because each multicast MPLS label is associated with one and only one of the domains, the data packet is multicast to members of domain A only and not to any members of the domain B. Likewise, a device of domain B may send a data packet to other devices of domain B using multicast MPLS protocol to broadcast the data packet to members of domain B only and not to any members of domain A. Nodes receiving the multicast MPLS data packet pass the packet on the ring without sending a copy of the packet to any of its customer ports if no member of the source domain is connected to the receiving node. If a node receiving the multicast MPLS data packet has a member of the source domain connected thereto, then the receiving node strips off a multicast MPLS label from the data packet and forwards the packet to the member of the domain connected thereto.
A transmitted data packet from one of the nodes 104110, may also include a service header. The service header is generally used to communicate service level parameters or path negotiation. Details regarding the service header are described below with reference to
A management console 130 may also be connected to the ring 102 by a node 132. The management console 130 is used to permit network management and provisioning of the devices connected to the ring 102 as described in more detail below.
Members of domains A and B are connected to the rings 212 and 214. As shown, a member of domain A and a member of domain B are connected to ring 212 via node 226. Similarly, a member of domain B is connected to the ring 212 via node 228. Further, a member of domain A and a member of domain B are connected to the ring 214 via node 232. A member of domain A is connected to the ring 214 via node 234. Accordingly, as shown in
The system controller applications 402 include a management interface 410, a multicast MPLS client 412, a TLS manager 414 and a shelf manager 416. The system controller applications 402 may be performed by the system controller 362 (
The management interface 410 performs interface functions between the node 108 (
The TLS manager 414 fronts other interfaces and provides logical control for TLS functionality, remembers the TLS configuration of the node 108, and restores TLS configuration information after reboots.
Thus, the TLS manager 414 controls node-level information regarding TLS-related configurations on the node information regarding TLS-related configurations on the node 108, and interface to the multicast MPLS client 412, other of the system controller applications 402, and the line card applications 406. In particular, the TLS manager 414 deals with domains and interfaces that are members of those domains.
The TLS manager 414 also enforces logical rules to validate TLS-related requests. In one embodiment, the rules include the following. An interface may only join a TLS domain if the TLS domain is created first. A TLS domain may not be deleted if the TLS domain has members. TLS domain creation and member joining both query the multicast MPLS client 412 to verify, or determine, the multicast label for the domain. The TLS manager 414 also communicates with the multicast MPLS client 412 to get the TLS identifier label binding.
The shelf manager 416 implements TLS mode and provides triggers to the TLS manager 414 for card-level and port-level events.
The line card applications 406 include a card manager 420, TLS microcode 422, and other applications 424. The card manager 420 manages the operation of the line card 352 (
The TLS microcode 422 performs TLS-related line card functions. At the ingress of the line card 352 (
If the source MAC address 704 of the incoming packet 700 is not found in the association table, the TLS microcode 422 adds the source MAC address 704 of the incoming packet to the association table.
The TLS microcode 422 also looks up the destination MAC address 702 of the incoming packet 700 in the association table. If the destination MAC address 702 of the incoming packet 700 is not found in the association table, the TLS microcode 422 appends to the incoming packet the broadcast MAC address and the multicast MPLS label of the associated TLS domain. In one embodiment/the TLS microcode 422 appends the service header 506, a multicast MPLS label 710, and a ring header 712 to the incoming packet 700 (See/
In one embodiment, an MPLS unicast label 702 is allocated for a logical port at the time the logical port joins a domain. The unicast label 702 is appended to every incoming data packet on the logical port, going out on the ring. The other nodes on the ring, and on connected rings, learn from the transmitted data packets including the unicast label 702 and use this label to send packet to MAC addresses at the associated logical port. The ring card is provisioned with the forwarding entry to direct all incoming packets with this label to the corresponding logical port.
If the destination MAC address 702 of the incoming packet 700 is found in the association table, the TLS microcode 422 retrieves the corresponding destination unicast label 702 from the association table. The TLS microcode 422˜hen appends the service header 506, the destination unicast label 702, and the ring header 712 to the incoming packet 700 to form the ring packet 730 of
Hence, a user at the management console 130 may remotely request a TLS domain for a particular line card of a specific node over the ring. The TLS domain request may be to add a new domain or to add a member to an existing domain. The request may also specify SLA guarantees, rate limits, quality of service, and the like associated with the domain. In response, the associated MPLS client sets up, or establishes a MPLS multicast tunnel and an associated MPLS multicast label for that tunnel.
Referring again to
If the ring packet 720, 730 includes a multicast MPLS label, the TLS microcode 432 determines whether a member of the domain associated with the multicast MPLS label is connected to the node 108. If a member of the domain associated with the multicast MPLS label is connected to the node 108 then the TLS microcode 432 strips the ring header and any multicast and unicast labels and passes the data packet to the line card 352 associated with the member of the domain. If a member of the domain associated with the multicast MPLS label is not connected to the node 108, the TLS microcode 432 causes the packet to be forwarded on the ring without sending a copy of the packet to any of its customer ports.
The unicast label field 608 is used by the TLS service layer to indicate the source MPLS label to use for return path for the source MAC address in the payload. This field may be set to be 20 bits long and may contain a static MPLS label.
The CoS field 610 contains the CoS to be used in the return path. This is ignored by the TLS service endpoint and instead the provisioned CoS for the TLS port is used while sending packets. The CoS field 610 may be 3 bits long. The stack bit 612 may be 1 bit long. The TTL field may be 8 bits long and may be replaced with a hash ID of a ring card of the source node.
Accordingly, the present system and method provide an efficient mechanism for providing transparent LAN services by performing multicast MPLS over a ring network and the provision of a service header to communicate service level parameters.
The above-described embodiments of the present invention are meant to be merely illustrative and not limiting. Thus, those skilled in the art will appreciate that various changes and modifications may be made without departing from this invention in its broader aspects. Therefore, the appended claims encompass all such changes and modifications as fall within the scope of this invention.
This patent application claims priority, under 35 U.S.C. 120, as continuation patent application, to commonly assigned U.S. patent application Ser. No. 10/140,308, filed on May 6, 2002, entitled “LOGICAL PORT SYSTEM AND METHOD”, which, in turn, is related to U.S. patent application Ser. No. 10/140,234, filed on May 6, 2002, entitled “SYSTEM AND METHOD FOR PROVIDING TRANSPARENT LAN SERVICES”, the contents of each being hereby incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
4663748 | Karbowiak et al. | May 1987 | A |
4698804 | Flores et al. | Oct 1987 | A |
5311585 | Armstrong et al. | May 1994 | A |
5333130 | Weissmann et al. | Jul 1994 | A |
5398236 | Hemmady et al. | Mar 1995 | A |
5636205 | Suzuki et al. | Jun 1997 | A |
5721819 | Galles et al. | Feb 1998 | A |
5790523 | Ritchie et al. | Aug 1998 | A |
5793745 | Manchester | Aug 1998 | A |
5978378 | Van Seters et al. | Nov 1999 | A |
6011780 | Vaman et al. | Jan 2000 | A |
6047331 | Medard et al. | Apr 2000 | A |
6094582 | Zimmermann | Jul 2000 | A |
6122759 | Ayanoglu et al. | Sep 2000 | A |
6226296 | Lindsey et al. | May 2001 | B1 |
6229788 | Graves et al. | May 2001 | B1 |
6236640 | Klink | May 2001 | B1 |
6269452 | Daruwalla et al. | Jul 2001 | B1 |
6292464 | Elahmadi et al. | Sep 2001 | B1 |
6304347 | Beine et al. | Oct 2001 | B1 |
6305019 | Dyer et al. | Oct 2001 | B1 |
6343081 | Blanc et al. | Jan 2002 | B1 |
6400681 | Bertin et al. | Jun 2002 | B1 |
6426947 | Banker et al. | Jul 2002 | B1 |
6557112 | Shimada | Apr 2003 | B1 |
6639896 | Goode et al. | Oct 2003 | B1 |
6647428 | Bannai et al. | Nov 2003 | B1 |
6788681 | Hurren et al. | Sep 2004 | B1 |
6931002 | Simpkins et al. | Aug 2005 | B1 |
6965592 | Tinsley et al. | Nov 2005 | B2 |
6973026 | Dyrga et al. | Dec 2005 | B1 |
7065089 | Kuhl et al. | Jun 2006 | B2 |
7068654 | Joseph et al. | Jun 2006 | B1 |
7079544 | Wakayama et al. | Jul 2006 | B2 |
7154861 | Merchant et al. | Dec 2006 | B1 |
7254138 | Sandstrom | Aug 2007 | B2 |
7269185 | Kirkby et al. | Sep 2007 | B2 |
7327757 | Ghahremani et al. | Feb 2008 | B2 |
7668166 | Rekhter et al. | Feb 2010 | B1 |
20020027906 | Athreya et al. | Mar 2002 | A1 |
20020085553 | Ku et al. | Jul 2002 | A1 |
20020114031 | Yamada | Aug 2002 | A1 |
20020176371 | Behzadi | Nov 2002 | A1 |
20020176373 | Sato | Nov 2002 | A1 |
20020176450 | Kong et al. | Nov 2002 | A1 |
20030009599 | Lee et al. | Jan 2003 | A1 |
20030026209 | Katz | Feb 2003 | A1 |
20030110268 | Kermarec et al. | Jun 2003 | A1 |
20030118019 | Mark et al. | Jun 2003 | A1 |
20030120763 | Volpano | Jun 2003 | A1 |
20030123449 | Kuhl et al. | Jul 2003 | A1 |
20030147393 | Stewart | Aug 2003 | A1 |
20030152075 | Hawthorne et al. | Aug 2003 | A1 |
20030152182 | Pai et al. | Aug 2003 | A1 |
20030154315 | Sultan et al. | Aug 2003 | A1 |
20030165146 | Sultan et al. | Sep 2003 | A1 |
20040032856 | Sandstrom | Feb 2004 | A1 |
20050259571 | Battou | Nov 2005 | A1 |
20060034292 | Wakayama et al. | Feb 2006 | A1 |
20110206057 | Rekhter | Aug 2011 | A1 |
Number | Date | Country |
---|---|---|
0843360 | May 1998 | EP |
0901169 | Mar 1999 | EP |
0908954 | Apr 1999 | EP |
1024642 | Aug 2000 | EP |
WO9508190 | Mar 1995 | WO |
WO0070622 | Nov 2000 | WO |
WO02093830 | Nov 2002 | WO |
Entry |
---|
ISSCC 200/Feb. 8, 2000/Salon 1-6—Digest of Technical Papers. |
Kazuo Nakazato, et al., “PLED—Planar Localised Electron Devices,” 1997, IEEE. |
MMC Networks, “EPIF 4-L3 Reference Manual,” MMC 97-0030, Issue 1.0, pp. i-viii, 1-1 to 1-6, 2-1 to 2-16, and 3-1 to 3-16, Oct. 1998. |
MMC Networks, “AnyFlow 5400 Product Overview”, 3 pages, 1998. |
MMC Networks, EPIF4-L3C1 Ethernet Port L3 Processor, MMC Networks, Inc., MMC 98-0066, Issue 1.0, pp. 1-37, 1998. |
MMC Networks, XPIF-300A3/XPIF-300A3-50 Gigabit BitStream Processor, MMC 99-0046, Issue 0.91, pp. 1-64, 1999. |
Number | Date | Country | |
---|---|---|---|
20090074413 A1 | Mar 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10140308 | May 2002 | US |
Child | 12275080 | US |