This invention relates generally to the field of computer networks. More particularly, this invention relates to maintaining high availability in a computer network utilizing link redundancy and failover control.
Computer networks play an ever expanding role in today's economy. As the available number and types of networked resources increase, combined with increases in speed and affordability of communications bandwidth, networks are becoming in some sense indistinguishable from computing systems. One example of such a reliance on computer networking occurs at the enterprise level as demonstrated by networked storage solutions. Rather than providing physical storage at a client system, the enterprise relies on shared storage whereby high-density, network-accessible storage servers are separately managed from client systems. Such a growing reliance on networks to perform even basic computing services, such as storage, imposes increasing demands for high availability. Any network interruptions can range from a mere inconvenience to an intolerable situation for mission critical applications.
In some cases, mechanisms may be put into place to detect an error in a network connection and to notify a network administrator. The administrator may then take action to identify the source or at least the general location of the error and to take corrective action, such as reconfiguring network resources. Unfortunately, such actions take time and result in interruptions to workflow. Such a manual intensive approach would be hard pressed to meet the high availability requirement of today's mission critical systems.
In other cases, resources are provided to facilitate a failover to a redundant resource. One such example is illustrated in
Some systems provide a mechanism to monitor external link state through the physical layer of the external ports (EXTA-EXTD). In response to detecting an external link failure, the mechanism also triggers an internal link drop on all of the corresponding internal ports (INTA-INTD) of the associated switch 106. This link drop initiates the failover mechanism provided on each of the servers 102 with an active link to the effected switch 106 so that it could properly failover, switching its active link to another one of the network interfaces.
Unfortunately, monitoring external link states at the physical layer of an external switch port is susceptible to frequent “link flapping” issues experienced when enabling that port. Only having physical-layer status, the system is unable to distinguish between “real” link failures and the intermittent link flapping events. Consequently, this leads to unnecessary internal link drops and failover events at the respective server 102 causing it to ping-pong between selecting the appropriate active link.
What are needed are methods and systems to provide high availability network connectivity in a computer system. The present invention satisfies these needs and provides additional advantages. In particular, the present invention provides processes and systems for monitoring external link state using state information obtained from an OSI model layer 2 or higher protocol running on the external link. Relying on information from such a protocol as the spanning tree protocol (STP), it is possible to avoid falsely identifying external link failures due to link flapping. In addition, the present invention provides processes and systems providing flexibility in the definition of an external failure event by providing configurable triggers. Only when the trigger event occurs, is an internal link drop initiated causing failover to a redundant link. Thus, a STP state can be monitored on at least one identified Virtual Local Area Network (VLAN). Further, the STP state can be monitored for static trunk groups or LACP (Link Aggregation Control Protocol (LACP) trunk groups.
In one aspect, the invention features a process for maintaining network connectivity in a computing device coupled to a network through at least one spanning-tree-protocol enabled switch. The computing device includes multiple network interfaces adapted in a failover configuration. One of the network interfaces is active and in communication with an internal switch port, such that the active network interface is in switchable communication with a remote network through the switch. External links from the switch to the remote network can use one or more external switch ports, depending upon a trunking configuration. The STP state of the one or more external switch ports is monitored. An external failure event is determined based on the monitored STP states of the one or more external switch ports. Upon determining an external failure event, one or more internal links coupled between the active network interface and the internal switch port are deactivated, or “dropped” in response to the identified external failure event. A failover from the active network interface to another one of the multiple network interfaces is initiated in response to the deactivated internal link.
In another aspect, the invention features a network-enabled computer system for maintaining high availability network connectivity between the computer system and a network. The computer system includes a computing device having multiple network interfaces adapted in a failover configuration. Each network interface is coupled to one side of a respective internal communication link with one of the network interfaces being active. A spanning-tree-protocol enabled switch has an internal port coupled to another side of the respective internal communication link. The active network interface is in switchable communication with at least one external port of the switch coupled to the network through an external communication link. An intelligent failover controller includes a fault monitor in communication with the STP enabled switch for monitoring a STP state at the at least one external port. The intelligent failover controller also includes a link-drop controller in communication with the fault monitor. The link-drop controller selectively initiates a link drop on one or more of the internal communication links in response to the monitored STP state. The active network interface fails over to another one of the multiple network interfaces in response to the link drop.
The above and further advantages of this invention may be better understood by referring to the following description in conjunction with the accompanying drawings, in which like numerals indicate like structural elements and features in the various figures. For clarity, not every element may be labeled in every figure. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention.
A description of preferred embodiments of the invention follows.
In computer network architectures, a network-enabled computing device is often coupled to a network through one or more network switches. As described above in relation to
Even with the above configuration, there can be inefficiencies such as those due to unnecessary failover from link flapping. By providing an intelligent failover controller, a more reliable network interface failover can be achieved thereby avoiding unnecessary failover actions. In more detail, the intelligent failover controller includes a monitor adapted to monitor status of the external communication links using information obtained from a networking layer above the physical layer. The monitored information can be obtained from an OSI model layer-2 or higher protocol. For example, the monitored information can be obtained from at least one of the spanning tree protocol (STP) described in IEEE Standard 802.1D and the rapid spanning tree protocol described in IEEE 802.1D-2004. In particular, the intelligent failover controller monitors the external links to identify which links, if any, are not in an operational state as determined by the layer-2 or higher protocol state.
For the STP example, the external port is always in one of the following states: Forwarding; Listening; Learning; Blocking; and No Link. For STP, any monitored state other than the Forwarding state can be considered to be non-operational. The STP state information can be obtained from STP state machine that are typically provided for each of the external ports of an STP-enabled switch. Thus, the intelligent failover monitor examines the current STP state of each of the state machines to determine whether the associated external link is in a forwarding state.
Upon one or more of the monitored external links being in a non-operational STP state, the intelligent failover controller can selectively initiate a link drop causing a corresponding link drop on one or more of the internal communication links. Teaming/failover controllers on the computing devices connected to the dropped internal link will operate as described herein, failing over to another one of the network interfaces, thereby accessing another network switch through a different internal communication link to maintain network communications. Beneficially, the intelligent failover controller provides additional features to allow definition of one or more failure events, each described at least in party by the particular failed external switch ports, and to allow the definition of appropriate control ports through which an internal link drop is initiated upon detection of the related external failure event.
Additional advantages are gained in providing high-availability to bandwidth sensitive applications, such as multimedia servers and voice over IP (VoIP) solutions. Such applications are sensitive to bandwidth fluctuations due to failed links within a trunk. By providing an ability to detect the number of operational links within a trunk and to define external failure events based on a threshold number of active links for the trunk, it becomes possible to preserve traffic quality.
The computing device 112 also includes a network-interface teaming/failover controller 126 in communicates with each of the two network interfaces 124. The teaming/failover controller 126 manages the two network interfaces 124 in a redundant, failover configuration. Thus, at any given time one of the two network interfaces 124 is active, forwarding and receiving network traffic between the computing device 112 and its interconnected network switch 116. The other network interface 124 remains in standby, ready to assume the active role should that become necessary. Each of the redundant network interfaces shares the same network address to avoid interruption of network traffic in the event of a failover.
The network interface 124 allows the computing device 112 communicate over a computer network by including electronic circuitry required to communicate according to a specific physical layer and data link layer standard such as Ethernet or token ring. This provides a base for a full network protocol stack, allowing communication among small groups of computers on the same LAN and large-scale network communications through routable protocols, such as IP. The network interface is an OSI model layer-2 item because it has a media access control (MAC) address. In some embodiments, the network interfaces 124 can be individual removable network interface cards (NIC). In other embodiments, the network interfaces 124 can be integral to the computing device 112.
The teaming/failover controller 126 monitors status of the internal communication link 123a. This can be accomplished at the active network interface 124a by monitoring link status of the physical link layer. Upon detecting an interruption, or link drop, the teaming/failover controller 126 places the active network interface 124a a non-active state, and transitions one of the other network interfaces 124b from standby into an active state.
An internal link drop may result from a failure of any of the active network interface 124a, the internal communication link 123a, the network switch 116a, and any upstream links 119a and devices 118a. Upon the teaming/failover controller 126 detecting a link drop of the first internal link 123a, the teaming/failover controller 126 initiates a failover to the second network interface 124b. Having an independent physical path to the network 114, the second network interface 124b takes over network communications continue between the computing device 112 and the network 114 using the same network address.
Without receiving any more than an internal link drop, the teaming/failover controller 126 is generally unaware of the location and nature of the failure. Thus, a robust design provides for complete redundancy in all components from the network interface 124b to the network 114, as shown. The source of the link drop can be determined by alternate means such as automatic or manual failure diagnostics and later corrected.
Each switch 116 includes multiple server-side, or internal switch ports 128a, 128b (generally 128) for connecting to the computing device 112 and referred to herein as internal ports 128. Each switch 116 also includes multiple network-side, or external switch ports 130a, 130b (generally 130) for connecting to the network, referred to herein as external ports 130. The switch 116 also includes a switching module 132 in communication with all of the internal and external ports 128, 130 for controlling and establishing interconnections between one or more of the ports 128, 130. An intelligent failover controller 134 is provided in communication with the switching module 132.
The switching module 132 implements an OSI layer 2 or higher protocol for each of the ports. The intelligent failover controller 134 monitors protocol-related information, such as an associated state of related external port 130 to determine whether the interconnected link is operational. Upon determining that one or more of the monitored ports 130 are not operational, the intelligent failover controller 134 initiates a link drop at one or more definable control ports, such as one or more of the internal ports 128.
In brief overview,
Alternatively or in addition, configuration includes the establishment of one or more trunks. A trunk refers to using multiple physical network cables or ports 130 arranged in parallel as a single logical port to increase the link bandwidth beyond the limits of any one single cable or port. The trunks can be created using static trunk groups in which two or more external ports are identified as belonging to the same static trunk. Alternatively, trunks can be established using the link aggregation control protocol (LACP) as described in IEEE specification 802.3ad. This allows for bundling several physical ports 130 together to form a single logical channel, whereby the network switch 116 negotiates an automatic bundle by sending LACP packets to a peer (e.g., the downstream switch 118 (
As a second phase of the configuration process at Step 142, an administrator configures one or more triggers on the network switch 116, whereby each trigger defines an external failure event. The ability to define external failure events provides additional intelligence and flexibility in determining when the intelligent failover controller 134 on the network switch 116 will initiate a link drop action on the control ports 128 to trigger the teaming/failover controller 126 on the computing device 112 to fail over an active network interface 124 (
Once the configuration has been completed (Steps 141, 142), the intelligent failover controller 134 on the network switch 116 monitors the operational status of each of the external links. In particular, at step 143, the intelligent failover controller 134 (
Upon identifying that an external failure event has occurred at Step 144, the intelligent failover controller 134 identifies the related control ports 128 at Step 145. At Step 146, the intelligent failover controller 134 initiates a link drop for each of the control ports 128 identified at Step 145 as being related to the external failure event determined at Step 144. After a link drop has been initiated on the control ports 128, process flow returns to Step 143 continuing to monitor external link states and repeating Step 144 through Step 146, as necessary.
The STP state monitors 160 receive information from the switching module 132 (
In some embodiments, each of the triggers 162 captures defined external failure events and provide respective trigger output 176a, 176b . . . 176k (generally 176) in response to detecting such an event. Each trigger 162 accesses certain configuration information provided in the registers 166, such as a monitor limit value, on/off status of VLAN monitoring, on/off status of the trigger, and a list of the monitor ports associated with the trigger 162.
The link-drop controller 180 includes a register 172 for storing configuration information. In particular, this register includes a list of the control ports associated with each of the one or more triggers 162. The link-drop controller 180 also includes logic 182 receiving the trigger outputs 176 and comparing them to the configuration information of the register 172. Upon detecting that one or more trigger events have occurred, the logic 182 identifies the related control ports and forwards one or more link drop commands 184a, 184b . . . 184m to the internal switch ports of the switch module 132. In some embodiments, the logic 182 is in communication with the switch module 132, forwarding the one or more link drop commands 184 to the switch module 132. The switch module 132, in turn, drops the internal communication links 123 associated with the identified control ports 128.
At least one application of the intelligent failover process is in a blade server system. In general, a blade server system is a self-contained computer system in which more than one blade server modules are provided within a single chassis to achieve a high-density form factor. Each blade server module is itself a computing device, similar to a typical server but with many of the components removed for space savings, power savings and other considerations. The blade server modules are mounted within an enclosure or chassis that provides services common to the blade server, such as power, cooling, networking, various interconnects and management.
One example of such a blade server system is the IBM® ESERVER® BLADECENTER®, commercially available through International Business Machines Corporation of Armonk, N.Y., which provides enhanced monitoring capabilities for blade servers, which utilize teaming software to provide high availability and fault tolerance. Each blade server in an IBM® ESERVER® BLADECENTER® chassis can be configured with multiple network interfaces, each of which is connected to a different network switch, such as NORTEL® layer 2/3 copper Gigabit Ethernet switch module, model no. 32R1860 commercially available through Nortel Networks Limited, of Quebec, Canada. The detection of an internal link drop is required to trigger the teaming software on the blade server to switch its active link from one network interface to another.
In some embodiments, the blade server housing or chassis 300 also includes a management module 314a coupled to one or more of the different blade server chassis components 302, 306, 308, 310 through the midplane 304. The management module 314a can be coupled to one or more of the blade server modules 302 and the switches 306 through a system bus. Alternatively or in addition, the management module 314a can be coupled to the switches 306 through a secondary bus, such as a serial inter-integrated circuit (I2C) bus 316. In some embodiments, the blade server chassis 300 includes a second management module 314b connected similar to the first management module 314a, but in a redundant manner.
The blade server module 302 also includes multiple network interfaces 332a, 332b, 332c, 332d (generally 332) each coupled to a respective network switch 306 through an internal communication link (not shown) provided by the midplane 304. A teaming/failover controller 334 is in communication with the processor 322 and each of the network interfaces 332. As shown, one of the network interfaces 332a is active, the remaining network interfaces 332b, 332c, 332d inactive, but ready to become active upon initiation by the teaming/failover controller 334.
A schematic illustration of the interconnections between the multiple network interfaces 332 of the fourteen blade server module 3021, 3022 . . . 30214 to the four network switches 306 of the exemplary blade server system of
The network switch 306 also includes another internal management switch port 346 that can be connected to a management module 314 (
One or more of the different protocols and features of the network switch 306 can also be accessed by one or more of the blade server modules 302 (
In some embodiments, each of the network switches 306 also includes a respective terminal port 348, such as an RS-232 serial communications port. The terminal port 348 is connected to the switching module 340, such that a remote terminal device (i.e., a “dumb” terminal) connected to the terminal port 348 can be used to monitor and control the network switch 306. This method of access is referred to as a command line interface (CLI). Thus, the network switch 306 can provide CLI menu structure to guide an administrator through the process of monitoring and controlling the network switch 306.
The network switch 306 also includes an intelligent failover controller 134 connected to the switching module. The same manner of monitoring and controlling the switching module 340 can be used to monitor and control the intelligent failover controller 134. Access to the intelligent failover controller 134 can be obtained as shown through the switching module 340.
The network 360 is further configured having a first VLAN 370a″ and a second VLAN 370b′. The first VLAN 370a″ is configured to include the first and second internal ports INT1, INT2 and the first and second external ports EXT1, EXT2 of the second switch 366b. The second VLAN 370b′ is configured to include the third internal port INT3 and the third external port EXT3 of the first switch 366a. Thus, the first and second VLANS 370a″, 370b′ reside on different switches. With the redundant configuration shown, a redundant first VLAN 370a′ is configured to include the first and second internal ports INT1, INT2 and the first and second external ports EXT1, EXT2 of the first switch 366a; and a second, redundant VLAN 370b″ is configured to include the third internal port INT3 and the third external port EXT3 of the second switch 366b.
The external ports of the first VLAN 370a″ (EXT1 and EXT2) are grouped together as a first trunk 368a″. The external port of the second VLAN 370b′ (EXT3) is grouped together as a second trunk 368b′. The external ports of the first and second redundant VLANs 370a′, 370b″ are similarly grouped together in first and second trunks 368a′, 368b″. The “Xs” positioned near the ports of the switches 366 indicate that the adjacent port is not active. Switch ports without “Xs” positioned near them are active.
The intelligent failover controller includes an internal teaming engine designed to operate independently on a defined set of monitor and control ports. By removing dependency from the external configuration, the internal teaming engine design allows for greater flexibility to adapt to future modifications and enhancements. All teaming configuration is remapped internally and can be represented as a bitmap of monitor and control ports. The following example illustrates how the teaming configuration can be remapped internally and utilized by the teaming engine.
In the exemplary of
By way of illustrative example, operation of another exemplary system for each of a number of different configuration scenarios is provided below. In particular, the following exemplary scenarios illustrate how the external teaming configuration is remapped internally. In some embodiments, the external teaming configuration is remapped and represented as a bitmap of monitor and control ports for use by the triggers. In general, all of the examples refer to a system similar to that illustrated in
As a first Example, a network system of
A first exemplary scenario with the above configuration summarized in Table I provides a single trigger (Trigger 1) and a single trunk (Trunk 1) with VLAN monitor off. Trunk 1 includes external ports Ext1 and Ext2. With the VLAN monitor off any configured VLANs will be ignored by the trigger. Thus, upon detecting an external failure event at one of the switches 306 (
A summary of the first exemplary scenario is provided in Table III. The table is split into two segments with a left-hand segment providing a so-called front-end failover configuration. This front-end failover configuration information reflects information entered by a network administrator during configuration of the system. In this scenario, the administrator has identified a single trigger (Trigger 1) for monitoring Trunk 1. The administrator has also identified a limit of 0 for the identified trunk. Thus, an external failure event exists when zero links of Trunk 1 are in an STP forwarding state.
The ports (Ext1 and Ext2) listed in the table result directly from the inclusion of Trunk 1, as this trunk has been pre-configured to include these ports. Although not necessary with VLAN monitor off, the VLAN associated with the ports of Trunk 1 are also identified. This association is summarized in Table II, with ports Ext1 and Ext2 belonging to VLAN2 and VLAN2 belonging to STG2.
The right-hand segment of Table III is referred to as the back-end failover monitor. This segment of the table reflects the monitor ports as those ports necessarily monitored in determining whether an external failure event of Trigger 1 exists. Since Trigger 1 includes only Trunk 1, which includes external ports Ext1 and Ext2, only these external ports need to be monitored. This segment of the table also reflects the associated control port links to be dropped in the event of detecting the related external failure event (i.e., Trigger 1 is “triggered”). Since the VLAN monitor is off, all of the internal ports of the switch detecting the trigger events are failed over.
With the information provided in Table III, the intelligent failover controller 134 (
A summary of a second exemplary scenario is provided in Table IV. This scenario is essentially the same front-end failover configuration of the preceding scenario, the only difference being that the limit is now set to 1. Additionally, for this scenario the VLAN monitor feature is ON. With a limit set to 1, a failover on Trigger 1 will occur when there is 1 monitor link remaining. Thus, if either of the external ports (Ext1, Ext2) is not in the STP forwarding state, an external failure event is declared. With VLAN monitor on, the control ports now depend upon those internal switch ports associated with the identified VLANs. Referring to Table II to identify those internal ports associated with VLAN2 yields internal ports int(2, 8, 9, 10). Thus, failover on trigger 1 will bring down control links coupled to internal switch ports int(2, 8, 9, 10).
A summary of a third exemplary scenario is provided in Table V. In this scenario, the limit is once again set to 1 for trunk 1, but a second trunk, Trunk 2, is also added to the same trigger. Referring to the trunk configuration, Trunk 2 includes external port Ext3. Referring to Table II, external ports Ext1, Ext2, and Ext3 all belong to VLAN 2. From the front-end failover configuration, the monitor ports of Trigger 1 include ext(1, 2, 3). Referring again to Table II with VLAN monitor ON, the control ports associated with VLAN2 are internal ports int(2, 8, 9, 10). Thus, failover on Trigger 1 will bring down control links coupled to internal switch ports int(2,8,9,10).
A failover on trigger 1 will only occur when there is 1 monitor link remaining. Thus, an external failure event will only occur when only one of the monitor ports remains in the STP forwarding state. Additional restrictions can also be defined and applied during the configuration stage, such that multiple trunks within the same trigger must belong to the same VLAN membership and share the same PVID.
A summary of a fourth exemplary scenario is provided in Table VI. This scenario includes the same configuration for Trigger 1 as identified in Table V, but adds a second trigger, Trigger 2. The second trigger is associated with an LACP trunk identified by an LACP key. For the instant example, the LACP trunk includes external ports Ext4 and Ext5. Inspection of table II identifies that these ports are associated with VLAN 4, which also includes internal ports Int4 and Int12.
Failover on trigger 1 will occur as described in the preceding scenario having the same trigger. Failover on trigger 2, however, will occur when there are no monitor links remaining, since the Trigger 2 limit set to 0 (i.e., none of the monitor ports are in the STP Forwarding state). A Failover on trigger 2 will bring down control links int(4, 12). An additional rule requires that multiple triggers not operate on the same VLAN.
In the following exemplary scenarios, the VLAN TAGGING feature has been enabled, with an associated configuration summarized below in Table VII. External ports Ext1, Ext2 and Ext3 belong to the same static trunks as described in the above scenarios. In addition, external ports Ext4 and Ext5 are configured to belong to an LACP trunk being identified by LACP key 1.
A summary of a fifth exemplary scenario is provided in Table VIII. Triggers, limits, and trunks being monitored are identical to the scenario summarized in Table VI; however, the VLANs and STGs differ resulting from VLAN tagging being ON. An inspection of each of the external ports associated with the identified trunks and comparison to Table VII identifies all of the VLANS associated with each external port. The monitor ports remain the same as in the preceding scenario; however, the control ports differ according to the identified VLANs.
Thus, a failover on Trigger 1 will occur when there is 1 monitor link remaining associated with static Trunks 1 and 2. A failover on Trigger 1 will bring down control links int(1-3, and 6-11). A failover on Trigger 2 will occur when there are 0 monitor links remaining associated with LACP key 1. Failover on trigger 2 will bring down control links int(4,5,12,13,14). Note that multiple trunks within the same trigger must belong to the same VLAN memberships and share the same PVID. Also note that multiple triggers are not allowed to operate on the same VLANs. Also note that each Monitor port link STP state will be checked only on the default PVID (even if the trigger may belong to multiple VLANs on different STP groups).
The last exemplary scenario demonstrates an invalid configuration having overlapping control links between triggers. It will assume that VLAN tagging is enabled with a VLAN/STG configuration identified in Table IX.
A summary of a fifth exemplary scenario is provided in Table X. The front-end failover configuration is similar to that of the preceding scenario, but for the identified VLANs. The VLAN identification differs based on the new VLAN/STG configuration of Table IX. In particular, each of the triggers (Trigger 1 and 2) includes an overlapping VLAN, namely VLAN1. Examination of the resulting control ports reveals that there is overlap. Internal ports Int1, Int6, and Int7 appear as control ports for each of the triggers. This is unacceptable, as a failure event of either of the triggers would result in a partial failover of some of the control ports of the other trigger.
In some embodiments, the configuration controller 164 (
A first-tier menu 402 facilitates access to the managed resources. The first-tier menu 402 provides access to one or more second-tier menus 404a-404f (generally 404). The first-tier menu 402 optionally provides a feature to allow a network administrator to quickly view the configuration of the controlled resources. The number and type of second-tier menus 404 depend upon the available features, but at a minimum includes a failover menu 404a for configuring the failover features, such as definition of the triggers identifying external failure events. Other second-tier menus include an IEEE 802.1x menu 404b for managing LACP features; a STP menu 404c for managing STP features; a trunk group menu 404d for managing static trunks; an IP trunk has menu 404e for further managing the use of trunks; and a VLAN menu 404f for managing VLANs.
Each of the second-tier menus 404 can include one or more additional sub menus, depending upon the particular application. The failover menu 404a includes multiple third-tier menus 406, one for each trigger. In some embodiments, up to eight triggers are provided requiring eight separate trigger menus. Even lower-tier menus, such as an auto monitor menu 408 can be provided, and are accessible from the trigger menus 406.
In operation, a network administrator navigates the menu structure during a configuration process to properly configure the networked resources. The configuration process can be repeated as necessary. Configuration information provided during this process is preserved and can be stored in one or more locations. The information provided by the exemplary menu structure applies to operation of each of the network switches 116 (
While the invention has been shown and described with reference to specific embodiments, it should be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the invention.
This application claims the benefit of U.S. Provisional Application No. 60/708,863, filed Aug. 17, 2005. The entire teachings of the above application are incorporated herein by reference.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US06/31937 | 8/16/2006 | WO | 00 | 1/17/2008 |
Number | Date | Country | |
---|---|---|---|
60708863 | Aug 2005 | US |