US 20050117562 A1
A computer network has two or more switches and a plurality of links. A first machine and a second machine are interconnected by the network in such a way that there exist multiple paths through the network from an N_Port of the first machine to an N_Port of the second machine. Network traffic from the N_Port of the first machine to the N_Port of the second machine is distributed between the multiple paths such that frames related to any single exchange traverse the same path yet frames of a first exchange need not traverse the same path as frames of a second exchange. Frames of each exchange therefore tend to be received by their destination in order with respect to other frames of that exchange, while they are not necessarily received in-order with respect to frames of other exchanges.
18. A method of routing between or among a plurality of paths in a network fabric between a first N_Port and a second N_Port, comprising:
receiving a packet containing a destination identifier and an originator exchange identifier;
accessing an entry of a routing table using an address generated based on at least portions of each of the destination identifier and originator exchange identifier; and
selecting one of the plurality of paths between the first N_Port and second N_Port based on the accessed entry of the routing table.
19. The method of
20. The method of
21. The method of
22. The method of
23. The method of
selecting a first one of the paths between the first N_Port and second N_Port in response to a first value of the destination identifier and a first value of at least a portion of the originator exchange identifier; and
selecting a second one of the paths between the first N_Port and second N_Port in response to the first value of the destination identifier and a second value of the at least the portion of the originator exchange identifier.
24. The method of
the method further comprising applying the at least portions of the destination identifier and originator exchange identifier to a hash function, the hash function to generate the address,
the hash function to further receive as an input a field selected from the group consisting of the source identifier and a port number of the incoming port of the switch.
25. The method of
26. A program product comprising computer-readable code to distribute data between or among paths between a first N_Port and a second N_Port, the computer-readable code executable to cause a switch to:
maintain a routing table having plural entries selectable by an address;
receive a packet containing a destination identifier and an exchange identifier;
generate the address based on at least portions of each of the destination identifier and the exchange identifier; and
route the packet on one of the paths based on the entry of the routing table selected by the generated address.
27. The program product of
wherein routing the packet on one of the paths comprises routing the packet through one of plural outgoing ports of the switch based on the outgoing port selector contained in the entry selected by the address.
28. The program product of
29. The program product of
30. The program product of
31. The program product of
32. A switch operable in a network having a plurality of paths, comprising:
a plurality of ports including a first port to receive a frame over the network, and additional ports;
a storage to store a routing table having entries for identifying corresponding additional ports for routing a frame received at the first port, wherein the received frame has a destination identifier and an exchange identifier; and
a generator to generate an address based on at least portions of each of the destination identifier and exchange identifier, the address to select one of the entries of the routing table; and
routing logic to route the received frame through one of the additional ports based on the entry selected by the address.
33. The switch of
34. The switch of
The invention relates to the field of computer networks. In particular, the invention relates to distributing network traffic between a pair of networked machines over multiple available routes through a network interconnecting the machines.
Most modern computer networks, including switched Fibre Channel networks, are packet oriented. In these networks, data transmitted between machines is divided into chunks of size no greater than a predetermined maximum. Each chunk is typically packaged with a header and a trailer into a packet for transmission. In Fibre Channel networks, packets are known as Frames.
Packets encounter delay while being routed through a network. Many networks have switches or routers that receive packets, store them, and forward the packets on towards their destinations when communications resources become available; storing and forwarding of packets introduces delay. Additional delay may be caused by propagation delay in the network interconnect between machines or switches of the network.
The multiple packets, or frames, associated with a single Fibre Channel operation are known as a exchange. A Sequence is a group of one or more frames, forming part of an exchange, transmitted in a single direction over the network. A sequence may contain data, status, or control information. Each exchange may contain one or more sequences, and may contain data sequences of multiple frames with control and acknowledgment sequences that are often single frames. A Fibre Channel network having at least one switch is a switched Fibre Channel fabric. A Fibre Channel switch is a routing device generally capable of receiving frames, storing them, decoding destination information from headers, and forwarding them to their destination or to another switch further along a path toward their destination.
A network interface of a switch for connection of the switch to a machine is known as an F_Port. An F_Port having the ability to connect to a Fibre Channel Arbitrated Loop is known as an FL_Port. An E_Port is a network interface of a switch for connection of that switch to another switch of a fabric. A G_Port is a port having the ability to operate as either an F_Port or an E_Port; and a GL_Port further has the ability to connect to a Fibre Channel Arbitrated Loop. For purposes of this patent F_Port includes any port of a switch that connects through a link to a machine, whether it be an F_Port, G_Port, GL_Port, or an FL_Port. Further, for purposes of this patent, an E_Port includes any port of a switch that connects through a link to another switch, regardless of whether it be an E_Port, GL_Port, or G_Port. Further, for purposes of this patent, the term switch port includes any port of a switch, whether it be an E_port or F_port as defined herein.
A network interface for connection of a machine to a Fibre Channel fabric is known as an N_Port, and a machine attached to a Fibre Channel network is known as a node. An L_Port is a network interface for connection of a machine to a Fibre Channel Arbitrated Loop, and an NL_Port is an N_Port also having the ability to connect to a Fibre Channel Arbitrated Loop. For purposes of this patent, the term N_Port includes both N_Ports and NL_Ports.
Machines, or “Nodes”, attached to a Fibre Channel network may be computers, or may be storage devices such as RAID systems, disk drives, or other storage servers.
A Fibre Channel exchange operates between an originator N_Port and a responder N_Port. For example, an originator N_Port may request an I/O operation such as a disk write; the machine attached to the responder N_Port performs the operation. N Ports may be originators for some exchanges, and responders for others. Each Fibre Channel N_Port is assigned identification for use as a destination address for frames intended for it, this identification is unique to the specific Fibre Channel network at a given time. Each Fibre Channel N_Port participating in an exchange assigns exchange identification to that exchange, that exchange identification being unique among the exchanges in progress on that N_Port but not necessarily unique across the network.
For purposes of this application, a link is the data transmission and reception hardware and any associated firmware that form a connection between an N_Port and an F_Port of a switch, or between E_Ports of two switches, of a Fibre Channel fabric. A link may incorporate a Fibre Channel Arbitrated Loop.
In a computer network, there may be more than one possible path, or sequence of links, switches, hubs, routers, etc. that may be traversed by a frame, between two machines attached to the network. Multiple paths may be intentional, providing extra capacity or redundant paths to protect against switch, node, or line failures, or may be unintentional consequences of network topology. Multiple paths between a pair of N_Ports may exist if there are two or more switches in the network.
It is known that frames routed on different paths through a network may suffer different delays. Further, delay on each path varies with traffic on each link of the path, the arbitration sequence of each arbitrated loop forming part of a link, flow control delays like those often injected to avoid buffer overflow, and switch loading.
Machines transmitting data on modern high-speed networks usually do not wait for each frame to be acknowledged before transmitting following frames—multiple frames of a single Fibre Channel sequence may exist in a Fibre Channel fabric at the same time. Further, frames of multiple sequences of a single exchange may also exist simultaneously in a Fibre Channel fabric, as may frames of multiple exchanges originated by any given N_Port.
If frames of a sequence are transmitted on different paths through a fabric, an early-transmitted frame suffering long delay on one path may arrive at its destination after a late-transmitted frame that suffers little delay on another path. Frames transmitted on different paths thus may arrive at the destination N_Port out-of-order, meaning that they are received in a different order than they were transmitted by their originating machine.
Frames received out-of-order may, and often do, require collection and sorting into correct order before they can be fully processed by the receiving machine. Some network protocols, including the TCP Internet protocol, presume out-of-order delivery and require that receiving machines collect and re-order frames before executing any command associated with them. Other order-dependent protocols, including the FCP protocol for encapsulating the SCSI storage interface protocol over Fibre Channel, assume that frames arrive in correct order—requiring that the Fibre Channel fabric deliver frames in-order. Some order-dependent protocols detect, and permit retry of, out-of-order frames even if they do not require that destinations perform resequencing. Fibre Channel frame headers include a sequence count field with which out-of-order frames may be detected within a sequence.
Fibre Channel fabrics support a variety of order-dependent and order-independent protocols running on top of their low-level Fibre Channel mechanism.
Since frames transmitted over the same path through a network tend to arrive in order, many Fibre Channel systems permitting order-dependent protocols restrict communication between any two N_Ports to transmission over one active path in each direction. Any other path between the N_Ports may be usable as an alternate path should an active path fail, but may remain little used until that failure occurs. Networks that failover from an active path to an alternate path are known in the art of Fibre Channel networks. Frame routing of this type is known herein as static routing with alternate paths.
Links of an active path, especially links between switches, may be shared with traffic between other N_Ports, including N_Ports of other machines. As loads and network configurations change, it is possible for a statically routed active path to become a bottleneck while alternate paths may have unused capacity. It is desirable to make use of any available, otherwise unused, capacity of these alternate paths to provide improved network throughput.
It is known that many machines, including RAID storage subsystems, have the ability to queue multiple commands for execution. For example, a RAID system may queue several read or write commands, received from one or more machines. Once queued, these commands are executed from the queue to or from cache, or to or from disk, in an order depending on availability of data in cache, disk availability and disk rotation. With proper interlocks, execution may often be in an order different from that in which the commands were received.
Commands that may be queued in these devices may include commands from multiple processes, or threads, running on a single machine having one or more processors. For example, a transaction-processing system may have several processes running, each process requiring access to a different record of a database on a RAID system, all requesting access to the database at about the same time. Each process may then create read, write, lock, or unlock commands for the database. Queuing and execution of each of these commands requires that a exchange of frames be transmitted between the machine and the device.
Fibre channel frame headers have a D_ID field that encodes identification of the destination N_Port of the frame. They also have an S_ID field that encodes identification of the originating port of the frame. There is also an OX_ID field that encodes the exchange identifier assigned by the originating N_Port, and an RX_ID field that encodes the exchange identifier assigned by the receiving N_Port of the exchange. Since the receiving N_Port does not assign RX_ID until the exchange has begun and a frame is sent in response to other frames of the exchange, the RX_ID field of early frames of an exchange, including the first frame sent by the originating N_Port, may not match the RX_ID of late frames of the exchange.
A network, such as a Fibre Channel fabric, having two or more machines attached, each attached to the fabric through at least one N_Port, has a first and a second path between an N_Port of a first machine and an N_Port of a second machine. The first machine originates several commands for execution on the second machine and embeds those commands and associated data in frames. Frames belonging to a first command are recognized and transmitted between the first and second machines over the first path, while frames belonging to a second command are transmitted between the first and second machines over the second path.
Frames belonging to an individual exchange are recognized through the OX_ID field of the frame headers. In an alternative embodiment, frames belonging to an individual exchange are recognized through a combination of the OX_ID and the S_ID fields of the frame headers. These fields, together with the destination address (D_ID) of the frame, are input to a function whose output is used by routing and distributing tasks of one or more switches to index routing tables at a switch of the network fabric. These routing tables contain information determining the link over which each frame will be sent through the fabric from that switch towards the destination. In this way, the routing tables determine paths, from what may be a multiplicity of possible paths, that each frame will follow through the network.
Except when routing tables are being updated, frames relating to the same exchange therefore follow the same path through the network, and therefore arrive in-order. Frames of simultaneous, but different, exchanges may be routed over different paths thus distributing traffic between the available paths.
As nodes, switches, and links are added to or removed from the network, and as a load-balancer adjusts demand on elements of the network, the routing tables are updated to reflect valid paths through the network and desired frame distribution among them. If more than one valid path appears in the table for any given destination, commands to that destination will tend to be distributed between the paths according to the frequency with which each path appears in the table.
A switched Fibre Channel network (
Machines of the network may include computers 102 104, and 120, and RAID or other storage systems 106 each having at least one N_Port 108, 112, 114, 118, and 122, for interconnection to the fabric. Each N_Port 108, 112, 114, 118, and 122 connects through a link 130, 134, 136, 140, and 142 to a switch of the switches 150, 152, and 154 of the fabric 100. Switches 150, 152, and 154 of the fabric may further be interconnected by additional links 160, 162, and 164. Switches of the fabric may be joined by multiple links, switch 152 connects to switch 154 by a redundant link 165.
There may be, and preferably are, more than one path between a first and a second machine of the network. There are frequently also more than one possible path from a first N_Port to a second N_Port. For example, computer 120 may communicate to RAID system 106 through a first path comprising N_Port 122, link 142, switch 150, link 162, switch 154, link 140, and N_Port 118; or through a second path comprising N_Port 122, link 142, switch 150, link 160, switch 152, link 164, switch 154, link 140, and N_Port 118. A third path may also exist similar to the second path but using the redundant link 165 from switch 152 to switch 154, comprising N_Port 122, link 142, switch 150, link 160, switch 152, link 165, switch 154, link 140, and N_Port 118. Similarly, computer 102 may communicate with computer 104 through a path comprising N_Port 108, link 130, switch 150, link 162, switch 154, link 136 and N_Port 114, or through an alternative path comprising N_Port 108, link 130, snitch 150, link 160, switch 152, link 164, switch 154, link 136, and N_Port 114.
Consider the first and second path described above between computer 120 and RAID system 106. In a network utilizing static routing, only one of these paths is active at a given time. The active path may include one or more elements that become overloaded, or become a bottleneck for these communications. For example, if the active path from N_Port 108 of computer 102 to N_Port 114 of computer 104 is through link 162 and the active path from N_Port 122 of computer 120 to N_Port 118 of RAID system 106 is also through link 162, it is possible for link 162 to have a heavy load while link 160 is idle.
There may be multiple processes simultaneously executing on computer 120. Each of these processes 200 and 202 (
A disk-write command may be packetized as a write exchange
Each frame, or packet, transmitted over a Fibre Channel network has structure as illustrated in
A switch of a Switched Fibre Channel Fabric receives frames having the format of
It is known that a routing table 330,
In an effort to improve the ability of network management software to optimize traffic flow on a network, some switches input the S_ID field 302 (
In a switch of the present invention, a routing table 350,
In an alternative embodiment of a switch of the present invention, the S_ID field 302, as well as the D_ID field 300 and the OX_ID field 304, of each frame header is used by a hash function 360 (
Consider frames received by a switch 150 of the present invention from computer 120 and intended for RAID system 106 N_Port 118. The headers of each of these frames are decoded by switch 150. In the network as illustrated, frames having D_ID field 300 corresponding to a destination of N_Port 118 may reach that destination through a path through switches 152 and 154, and through a second path through switch 154 directly. A hash function of the D_ID field 300 and at least one bit of the OX_ID field 304 of the header are therefore used to index routing table 180 to select the outgoing switch port. The routing table 180 has the structure illustrated in
Frames belonging to the same exchange have the same OX_ID field; therefore these frames follow the same route through the network and tend to arrive in-order within that exchange. Frames may, however, arrive out-of-order with respect to frames of other exchanges.
In a Fibre Channel network, there may be paths between two ports that are “better” in some way than others. Multiple bits of the OX_ID field 304 may be considered by a routing table to distribute frames between a preferred and a less preferred path. For example, if three bits of OX_ID are considered by a routing table of switch 150, eight table entries may be addressed for the same D_ID. If three of these have an outgoing port selector specifying E_Port 170, while five specify E_Port 178, about three-eighths of frames will tend to follow the path through switches 150 and 154 while five-eighths of frames will tend to follow the path through switches 150, 152, and 154. If more than one valid path appears in the table for any given destination, exchanges directed to that destination are thus distributed between the paths according to the frequency with which each path appears in the table.
As machines, switches, and links are added to or removed from the network the routing tables are updated to reflect valid paths through the network and the desired frame distribution among them. The is routing tables are also adjusted as a load-balancer task, which may run on any compute-capable machine or switch of the network, adjusts demand on elements of the network. For example, should the link 162 attached to E_Port 170 of switch 150 fail, those routing table entries specifying this port may be replaced by entries specifying E_Port 178 so that frames may reach their intended destination.
It is not necessary that the hash function 340 consider all bits of the OX_ID field, it is expected that significant distribution of traffic among multiple routes can be achieved by considering as few as one or several low bits of the OX_ID field.
In an alternative embodiment of the present invention, a hash function 400 (
The embodiment of
While the routing table of the present invention has been described as producing an outgoing port selector from a hash function of the D_ID and OX_ID fields 300 and 304, that operation may be either direct or indirect. In an alternative embodiment, a level of indirection is used such that paths may be taken in or out of service quickly, without need to rewrite many of the outgoing port selectors in the routing table. For example, consider the routing table structure of
In this embodiment, should a link fail it may be possible to rewrite the portmap table 432 to reroute all frames onto a functioning link (if one exists) in less time than it would take to restructure the routing table 428. Once the frames are rerouted onto a functioning link by rewriting the portmap table 432, the routing table 428 may be adjusted to balance the load. Alternatively, if path code 430 has more bits than the outgoing port selector 434, it may not be necessary to rewrite the routing table 428.
Routing tables of the present invention may be implemented in firmware or hardware of the switch. It is known that implementation of routing tables in hardware provides advantage for switches having heavy load and large numbers of switch ports. In a hardware implementation, routing table 350 of
The hash function used for addressing the routing table may be any of many hash functions known in the art of computer science. This function may also comprise concatenation of a preselected group of bits of each input to the hash function; such as concatenation of one or more low-order OX_ID bits with several bits of the D_ID field to produce an index to the routing table. This function may also comprise concatenation of functions of bits from each field, or concatenation of bits of results of a function applied to each field.
A computer program product is a machine-readable memory having recorded on it a program for performing a particular function; this may be a read-only memory or may be an erasable and rewritable memory such as RAM, CD-RW, tape, flash memory, or magnetic disk. It is anticipated that routing control software for controlling routing tables as herein described may be distributed or operated as a computer program product. Similarly, a switch containing firmware for constructing and utilizing the routing table of the present invention in routing frames is expected to contain memory having that firmware, and therefore contains a computer program product.
While much reference has been made to a first and second path through the network, the invention is not limited to a pair of paths. The invention is applicable to any reasonable number of concurrently available paths between nodes of a network.
While the invention has been particularly shown and described with reference to a preferred embodiment thereof, it will be understood by those skilled in the art that various other changes in the form and details may be made without departing from the spirit and scope of the invention.