1. Field of the Invention
The present invention relates to the field of virtual local area network (VLAN) topologies and internetwork communications technologies. In particular, the present invention relates to an aggregated VLAN network architecture used in forwarding data packets by a LAN switch connecting multiple VLANs.
2. Background Information and Description of Related Art
A VLAN is a logical grouping of networked host computers on some other basis than the physical network location (e.g. department, primary application). VLANs allow network managers to more easily manage dynamic networks where the identity and location of the network's users are constantly changing.
VLANs can be implemented in a number of different ways, depending on the network strategy. A prior art traditional layer-2 VLAN is based on a logical grouping of the layer-2 switch ports to which the hosts connect. Alternative prior art layer-2 VLANs define VLAN membership by the host's Media Access Control (MAC) layer address. An example of a port-based prior art VLAN is shown in
Subsequent generations of prior art VLANs are embodied in layer-3 switches. Prior art layer-3 VLANs include VLANs based on the protocol type in a multi-protocol environment, or on a network-layer address such as an Internet Protocol (IP) multicast group, or a subnet address in a Transmission Control Protocol (TCP)/IP network environment. An example of a prior art layer-3 VLAN based on subnet address is shown in
An advantage of prior art VLANs based on layer-3 information such as the subnet address, is that it allows hosts to move to a different physical port on the switch in the same VLAN without having to reconfigure the host IP addresses. In an Internet Service Provider (ISP) environment, VLAN membership is often based on the subnet address for this reason, among others.
An advantage of all prior art VLANs is that the layer-2 or layer-3 switch is able to use VLAN membership to contain network traffic. For example, traffic originating on one port is only switched to other ports belonging to the same VLAN, or traffic originating on one subnet is only switched to other hosts belonging to the same subnet. For this reason, VLANs are often referred to as broadcast domains. VLANs avoid wasting bandwidth caused by unnecessarily forwarding traffic to switches for which there are no potential recipients (i.e. switches that do not have ports belonging to that particular VLAN, or that do not connect to hosts belonging to the same subnet). For example, with reference to
The subnet address that is commonly used as the basis for defining the layer-3 VLANs is a type of Internet Protocol address (IP address) used to route data packets across heterogeneous networks. IP addresses are 32-bit numbers that have a two-level structure: a network number and a host number. The network number uniquely identifies the network through which the host connects to the Internet, and the host number uniquely identifies the address, or location, of the host on that uniquely identified network. As the number of networks requiring access to the Internet has grown, a third level was introduced into Internet routing protocols to augment the original two-level addressing structure. This third level defines a sub-network, or “subnet.”
A subnet address may represent all the hosts at one geographic location, in one building, or on the same LAN or VLAN. An advantage to dividing a network into subnets is that it allows an organization (such as an ISP) to be connected to the Internet with a single shared network address. As a consequence, only one IP network address need be exported by routing protocols for all subnets belonging to a particular network, thereby reducing the routing overhead of the Internet. Without subnets, an ISP could get multiple connections to the Internet, one for each of its logically separate networks, but this would result in an inefficient and unnecessary use of the limited number of unique network numbers, as well as an unnecessary increase in the size of the global routing tables needed to properly route data packets from one network to another. The standard procedure for creating and identifying subnets is provided in Internet Request For Comments (RFC) 950.
Like VLANs, subnets can be used to contain network broadcast traffic, i.e. data packets from one subnet can be broadcast only to other hosts in the same subnet by using the appropriate broadcast IP addresses and routing protocols. In addition, a data packet can be broadcast to a specific subnet. In this way, a subnet is also considered a broadcast domain.
A typical use of the prior art layer-3 VLAN switches is in an ISP environment, where VLAN membership may be based on network layer information such as the layer-3 protocol type or layer-3 subnet address as previously described. Traditionally, the ISP assigns each of their subscribers to a separate VLAN based on a unique subnet address within the ISP's own IP address network space. However, there are a number of drawbacks to assigning each subscriber their own VLAN based on a unique subnet address.
One drawback is that implementations of a subnet addressing scheme must set aside certain special purpose IP addresses that cannot be used for host IP addresses. The special purpose IP addresses include at least two different broadcast IP addresses, a default router address (i.e. the address of the default gateway for the subnet), and, in an ISP environment, at least one IP address for a subscriber node.
The two broadcast IP addresses that must be set aside are fixed addresses with functional significance, i.e. they are used to broadcast data packets to the subnet. One is the “all hosts” address, consisting of the network number, subnet number, and all ones in the host number field. This address has the effect of transmitting the data packet to all of the hosts affiliated with that subnet. The other is the “this network” address, consisting of the network number, subnet number, and all zeroes in the host number field. This address has the effect of transmitting the data packet to the subnet only. The broadcasting IP addresses are useful when a host needs to request information but does not know exactly where to get it, or when a host needs to announce information to all other hosts on a subnet.
As a result of having to set aside these four types of special purpose and broadcast IP addresses, the IP address space overhead of subnets can become quite large, particularly when dividing a given IP network address space up into several smaller subnets, as is often the case in an ISP environment. For example, Table 1 illustrates the addressing overhead for an ISP that allocates 8 subnets to its subscribers, with each subnet being a /27 network (where the forward-slash notation refers to the length of the combined network number/subnet number prefix of the IP address).
As can be seen, each /27 network is capable of supporting only 28 hosts, because 4 of the potentially available host addresses must be set aside for the broadcast addresses, default router, and subscriber node. For the 8 subnets, this results in a greater than 12.5% loss in potential address space (32/256×100=12.5%). When multiplied by hundreds and thousands of subscriber subnets, this represents a significant waste of the available IP address space.
Another drawback to assigning each subscriber their own unique subnet, is the requirement of storing another 32-bit number, called a subnet mask, to support the interpretation of the IP addresses for each different subnet. The subnet mask is a bit-mask with bits set in the positions corresponding to the IP network number, and additional bits set in the positions corresponding to the subnet number. The bit positions corresponding to the host number default to zero.
An example of a subnet address mask used to define up to eight different subnets in a /24 network address space (also referred to as a Class C network) is shown in Table 2 below.
As can be seen, the subnet mask consists of 27 set bits, followed by 5 zero bits. The first 24 bits correspond to the binary network number prefix of the IP address, and the 25th-27th bits correspond to the subnet number prefix of the IP address, in this case a 3-bit binary number having a decimal value from 0 through 7. Together, they are referred to as the extended network prefix. The 5 zero bits represent the bits that define the host addresses on each subnet, for a total of 32 hosts. (As noted earlier, up to 4 of those 32 host addresses cannot be assigned to a host, but rather must be set aside for broadcast or other special purposes.)
Standard subnetting protocols require that the subnet mask be stored and compared by the router interface against the data packets to determine whether they can be sent directly to the destination on the local network or if they must be sent to a gateway. Therefore, the use of subnets results in an unavoidable amount of subnet mask storage and processing overhead that must be incurred when forwarding and routing data packets.
Yet another drawback to assigning each subscriber their own individual subnet is the constraints on the number and size of subnets imposed by the subnet addressing scheme itself. Since subnets must be defined along binary boundaries that yield host address blocks in powers of two, an ISP can only define as many subnets as will accommodate the host address space needed by the largest subnet. For example, a /24 network address space (Class C network) could be subnetted into 23 or 8 /27 subnets, each supporting 25, or 32 hosts, minus at least the two broadcast addresses, for a total of 30 hosts. If the largest subnet requires 50 host addresses, then the /24 network address space (Class C network) instead can only be divided into 22 or 4 /26 subnets, each supporting (26−2), or 62 hosts. Even larger host address spaces, say 500-1000 hosts, would need their own /22 or /23 subnet carved out of a /16 network address space (Class B network). Since ISPs often service subscribers of varying and unpredictable size, assigning each subscriber an individual subnet can result in extremely inefficient allocation of the available host address space.
As the demand for Internet access has grown, the necessity of conserving IP address space and reducing routing overhead has become more critical. Moreover, ISPs are increasingly rolling out significantly scaled server co-location and hosting facilities for a variety of subscribers of unpredictable size, servicing smaller organizations consisting of fewer than 100 hosts, as well as larger organizations consisting of thousands of hosts each. Accordingly, a new approach for providing dynamic and efficient management of VLANs, the available IP address space, and routing protocols for network traffic is desirable.
According to one aspect of the invention, a method and system is provided in which an aggregated VLAN network architecture is used in forwarding data packets by a LAN switch connecting multiple VLANs. Instead of assigning each subscriber's VLAN to one subnet, the method and system of the present invention assigns each subscriber to a “sub-VLAN” that shares a subnet with other subscribers' sub-VLANs. All of the sub-VLANs sharing the same subnet are hierarchically organized into a single “super-VLAN.” The super-VLAN is uniquely associated with that same subnet, and each sub-VLAN of the super-VLAN shares in the host address space supported by that subnet. As a result, the sub-VLANs can also 1) share the same virtual router interface (i.e. the routing configuration from the super-VLAN subnet), 2) configure the same default router, and 3) share the same subnet mask. By using VLAN aggregation architecture, the switches embodied by the present invention not only enable IP address conservation and routing efficiency, but are capable of separating subnet-like traffic between individual subscribers of unpredictable size.
The present invention will be described by way of exemplary embodiments, but not limitations, illustrated in the accompanying drawings in which like references denote similar elements, and in which:
In the following description various aspects of the present invention, a VLAN aggregation method and system, will be described. Specific details will be set forth in order to provide a thorough understanding of the present invention. However, it will be apparent to those skilled in the art that the present invention may be practiced with only some or all of the described aspects of the present invention, and with or without some or all of the specific details. In some instances, well known architectures, steps, and techniques have not been shown to avoid unnecessarily obscuring the present invention. For example, specific details are not provided as to whether the method and system is implemented in a router, server or gateway, as a software routine, hardware circuit, firmware, or a combination thereof.
Various operations will be described as multiple discrete steps performed in turn in a manner that is most helpful in understanding the present invention. However, the order of description should not be construed as to imply that these operations are necessarily performed in the order they are presented, or even order dependent. Lastly, repeated usage of the phrase “in one embodiment” does not necessarily refer to the same embodiment, although it may.
Overview of VLAN Aggregation Architecture
Referring now to
As further illustrated, super-VLAN Z 350 is associated with a /24 subnet having an IP address of 192.1.1. sub-VLAN P 310 uses host IP addresses 192.1.1.1-3, sub-VLAN Q 320 uses host IP addresses 192.1.1.4-5, and sub-VLAN R 330 uses host IP addresses 192.1.1.6-8. Of course, different allocations of the subnet address space can be made, depending on the number of hosts to be supported on the VLAN. For example, VLAN P 310 may need to support only 50 hosts, while VLAN Q 320 may need to support 1000 hosts. All of the sub-VLANs P, Q, and R, 310, 320, and 330 share a common gateway address of 192.1, and the common broadcast addresses 360 192.1.1.0 (i.e. the “all zeros” or “this network” address 361) and 192.1.1.255 (i.e. the “all ones” “all hosts” address 362). Furthermore, in an ISP environment, sub-VLANs P, Q, and R, 310, 320, and 330 can share at least one common subscriber node address (not shown).
In the illustrated embodiment, sub-VLAN P 310, sub-VLAN Q 320 and sub-VLAN R 330 are defined as sub-VLANs belonging to super-VLAN Z 350 and sharing a /24 subnet SN4305 address space 192.1.1. However, it should be understood that other variations for determining sub-VLAN (and super-VLAN) membership using subnets may be employed without departing from the principles of or exceeding the scope of the present invention. Moreover, while the description that follows addresses the method and system as it applies to an internetwork (Internet) application, it is appreciated by those of ordinary skill in the art that method is generally applicable to any network application including, but not limited to, Local Area Networks (LANs), Metropolitan Area Networks (MANs), and Wide Area Networks (WANs).
Additionally, while an embodiment is described in the context of sharing subnet address space, it is appreciated that the invention is equally applicable in a Classless Inter-Domain Routing (CIDR) environment. CIDR is documented in RFC 1518 and RFC 1519. The primary requirement for CIDR is the use of well known routing protocols that support it, such as RIP Version 2, OSPF Version 2, and BGP Version 4. In CIDR, the subnet mask is an integral part of routing tables and protocols. Moreover, a route is not an IP address, broken down into network and host bits according to its class, rather, a route is a combination of address and mask. Thus, not only can network be divided into “subnets”, but the networks can be combined into “supemets”, so long as they have a common network prefix. CIDR defines address assignment and aggregation strategies designed to minimize the size of top-level Internet routing tables, just as traditional subnets do.
In operation, each sub-VLAN P, Q, and R 310, 320, and 330 in the illustrated embodiment functions as a layer-2 broadcast domain. Thus, local broadcast packets originating from subscribers in sub-VLAN P 310 are confined to destination hosts belonging to sub-VLAN P 310, local broadcast packets originating from subscribers in sub-VLAN Q 320 are confined to destination hosts belonging to sub-VLAN Q 320, and so forth. For example, a Windows 95/NT network neighborhood search will not discover other subscribers' host machines.
Intra-Sub-VLAN Communication
Data packets originating within the sub-VLANs P, Q, and R 310, 320, and 330 in the illustrated embodiment carries a VLAN identification that can be used to provide intra-sub-VLAN communication using existing layer-2 VLAN forwarding mechanisms. While no other information is needed, additional constraints and layer-2 filtering can be defined as needed to improve performance. As there is no single official standard protocol for communication of VLAN information, existing VLAN forwarding mechanisms may be employed, including proprietary VLAN communication protocols. The method commonly used is known as “frame-tagging.” In frame-tagging, packets originating from a host belonging to a VLAN acquire a VLAN identifier (VLAN ID) as they are switched onto a shared backbone network. The VLAN ID is what enables the receiving switches to forward the packets intelligently by switching the packets to only those switches that are members of the same VLAN. A non-proprietary VLAN communication protocol has been incorporated into the IEEE 802.1Q standard, whereby the VLAN ID is part of the IEEE 802.1Q header inserted between the MAC header and the frame's data. In one embodiment of the present invention, the VLAN ID is modified to include the super-VLAN membership identification as well as the sub-VLAN membership, regardless of the VLAN communication protocol used to forward the VLAN packets.
Inter-Sub-VLAN Communication
Communication between the logically defined sub-VLANs P, Q, and R 310, 320, and 330 (inter-sub-VLAN communication) requires layer-3 routing. In one embodiment of the present invention, communication between the sub-VLANs P, Q, and R 310, 320, and 330 is routed through the super-VLAN Z 350, using the virtual router interface 370. As part of the VLAN ID stored in the packet, the super-VLAN membership identification provides the necessary information to the virtual router interface 370 to apply the proper routing configurations associated with the subnet to which the super-VLAN Z is assigned, in this case the /24 subnet 192.1.1. The routing configurations include routing protocols, static routes, redundant router protocols, subnet masks and access-lists. Since all sub-VLANs P, Q, and R 310, 320, and 330 share the same virtual router interface 370, each sub-VLAN P, Q, and R 310, 320, and 330 can configure the same default router (gateway) and share the same (or longer) subnet mask. As a result, the traditional address overhead of the prior art one subnet per VLAN architecture is minimized. Furthermore, IP addresses are used with maximum efficiency, making the task of managing moves, additions, and changes to the network trivial.
It should be noted that Address Resolution Protocol (ARP) proxy may be performed between hosts across different sub-VLANs. When a host transmits an ARP request for a host on another sub-VLAN, the switch generates an ARP response to the requesting host. This forces the VLAN data packets to be sent to the switch (by specifying the MAC address of the switch) so that the packets can be routed from one sub-VLAN to another.
If necessary, steps may be taken to prevent the communication between the sub-VLANs by disabling sub-VLAN proxy Address Resolution Protocol (ARP) while still allowing communication with other VLANs. The present invention also envisions a mechanism to prevent IP address theft between sub-VLANs (i.e. using the same IP address in multiple sub-VLANs that belong to same super-VLAN).
Conclusion
Accordingly, a novel method and system is described for an aggregated VLAN network architecture used in forwarding data packets by a LAN switch connecting multiple VLANs. From the foregoing description, those skilled in the art will recognize that many other variations of the present invention are possible. In particular, while the present invention has been described as being implemented in a network comprising one or more LAN switches, such as S4340, a virtual router interface 370, sub-VLANs 310, 320, and 330 and super-VLAN 350, some of the logic may be distributed in other components of a network or internetwork application.
For example, embodiments of the invention may be represented as a software product stored on a machine-readable medium (also referred to as a computer-readable medium or a processor-readable medium). The machine-readable medium may be any type of magnetic, optical, or electrical storage medium including a diskette, CD-ROM, memory device (volatile or non-volatile), or similar storage mechanism. The machine-readable medium may contain various sets of instructions, code sequences, configuration information, or other data. As an example, the procedures described herein for a virtual router interface 370 can be stored on the machine-readable medium. Those of ordinary skill in the art will appreciate that other instructions and operations necessary to implement the described invention may also be stored on the machine-readable medium.
Thus, the present invention is not limited by the details described. Instead, the present invention can be practiced with modifications and alterations within the spirit and scope of the appended claims.
This application is a Continuation of, and claims the benefit of, application Ser. No. 09/595,608 filed Jun. 16, 2000, now U.S. Pat. No. 6,914,905.
Number | Name | Date | Kind |
---|---|---|---|
5732078 | Arrango | Mar 1998 | A |
5737333 | Civanlar et al. | Apr 1998 | A |
5742604 | Edsall et al. | Apr 1998 | A |
5793763 | Mayes et al. | Aug 1998 | A |
5802106 | Packer | Sep 1998 | A |
5862452 | Cudak et al. | Jan 1999 | A |
5909686 | Muller et al. | Jun 1999 | A |
5910955 | Nishimura et al. | Jun 1999 | A |
5926463 | Ahearn et al. | Jul 1999 | A |
5938736 | Muller et al. | Aug 1999 | A |
5946308 | Dobbins et al. | Aug 1999 | A |
5949783 | Husak et al. | Sep 1999 | A |
5959989 | Gleeson et al. | Sep 1999 | A |
5968126 | Ekstrom et al. | Oct 1999 | A |
5978378 | Van Seters et al. | Nov 1999 | A |
6006258 | Kalajan | Dec 1999 | A |
6006264 | Colby et al. | Dec 1999 | A |
6006272 | Aravamudan et al. | Dec 1999 | A |
6012090 | Chung et al. | Jan 2000 | A |
6018619 | Allard et al. | Jan 2000 | A |
6023724 | Bhatia et al. | Feb 2000 | A |
6028848 | Bhatia et al. | Feb 2000 | A |
6029203 | Bhatia et al. | Feb 2000 | A |
6032194 | Gai et al. | Feb 2000 | A |
6035105 | McCloghrie et al. | Mar 2000 | A |
6047325 | Jain et al. | Apr 2000 | A |
6049834 | Khabardar et al. | Apr 2000 | A |
6052803 | Bhatia et al. | Apr 2000 | A |
6058106 | Cudak et al. | May 2000 | A |
6058431 | Srisuresh et al. | May 2000 | A |
6085238 | Yuasa et al. | Jul 2000 | A |
6088356 | Hendel et al. | Jul 2000 | A |
6094435 | Hoffman et al. | Jul 2000 | A |
6094659 | Bhatia | Jul 2000 | A |
6098172 | Coss et al. | Aug 2000 | A |
6104696 | Kadambi et al. | Aug 2000 | A |
6104700 | Haddock et al. | Aug 2000 | A |
6105027 | Schneider et al. | Aug 2000 | A |
6108330 | Bhatia et al. | Aug 2000 | A |
6115378 | Hendel et al. | Sep 2000 | A |
6118768 | Bhatia et al. | Sep 2000 | A |
6118784 | Tsuchiya et al. | Sep 2000 | A |
6119162 | Li et al. | Sep 2000 | A |
6119171 | Alkhatib | Sep 2000 | A |
6128657 | Okanoya et al. | Oct 2000 | A |
6131163 | Wiegel | Oct 2000 | A |
6141749 | Coss et al. | Oct 2000 | A |
6147995 | Dobbins et al. | Nov 2000 | A |
6151316 | Crayford et al. | Nov 2000 | A |
6151324 | Belser et al. | Nov 2000 | A |
6154446 | Kadambi et al. | Nov 2000 | A |
6154775 | Coss et al. | Nov 2000 | A |
6154839 | Arrow et al. | Nov 2000 | A |
6157647 | Husak | Dec 2000 | A |
6157955 | Narad et al. | Dec 2000 | A |
6167052 | McNeill et al. | Dec 2000 | A |
6167445 | Gai et al. | Dec 2000 | A |
6170012 | Coss et al. | Jan 2001 | B1 |
6178455 | Schutte et al. | Jan 2001 | B1 |
6178505 | Schneider et al. | Jan 2001 | B1 |
6181681 | Hiscock et al. | Jan 2001 | B1 |
6181699 | Crinion et al. | Jan 2001 | B1 |
6182226 | Reid et al. | Jan 2001 | B1 |
6182228 | Boden et al. | Jan 2001 | B1 |
6188694 | Fine et al. | Feb 2001 | B1 |
6195705 | Leung | Feb 2001 | B1 |
6202114 | Dutt et al. | Mar 2001 | B1 |
6208649 | Kloth | Mar 2001 | B1 |
6208656 | Hrastar et al. | Mar 2001 | B1 |
6212558 | Antur et al. | Apr 2001 | B1 |
6216167 | Momirov | Apr 2001 | B1 |
6219706 | Fan et al. | Apr 2001 | B1 |
6219739 | Dutt et al. | Apr 2001 | B1 |
6226267 | Spinney et al. | May 2001 | B1 |
6226771 | Hilla et al. | May 2001 | B1 |
6230203 | Koperda et al. | May 2001 | B1 |
6243749 | Sitaraman et al. | Jun 2001 | B1 |
6243754 | Guerin et al. | Jun 2001 | B1 |
6243815 | Antur et al. | Jun 2001 | B1 |
6246669 | Chevalier et al. | Jun 2001 | B1 |
6249523 | Hrastar et al. | Jun 2001 | B1 |
6252888 | Fite, Jr. et al. | Jun 2001 | B1 |
6253122 | Razavi et al. | Jun 2001 | B1 |
6256314 | Rodrig et al. | Jul 2001 | B1 |
6262976 | McNamara | Jul 2001 | B1 |
6266707 | Boden et al. | Jul 2001 | B1 |
6269099 | Borella et al. | Jul 2001 | B1 |
6430621 | Srikanth et al. | Aug 2002 | B1 |
6526052 | Rijhsinghani et al. | Feb 2003 | B1 |
6553028 | Tang et al. | Apr 2003 | B1 |
6614787 | Jain et al. | Sep 2003 | B1 |
6614792 | Pazy et al. | Sep 2003 | B1 |
6674760 | Walrand et al. | Jan 2004 | B1 |
7222188 | Ames et al. | May 2007 | B1 |
Number | Date | Country | |
---|---|---|---|
Parent | 09595608 | Jun 2000 | US |
Child | 11050165 | US |