The present disclosure relates generally to computing systems, and more specifically, to stress-testing a computer system network.
Due to cost and space limitations, many test environments have smaller scale Storage Area Network (SAN) environments with smaller workloads. Testing includes adding latency and simulating a larger SAN hop count, which is the number of hops needed to get from the sender to the receiver to more accurately test products. Current methods that exist to introduce latency and simulate hop count include the addition of physical test tools placed in the environment. For example, U.S. Pat. No. 6,922,663, incorporated herein by reference, teaches a network client simulation tool that virtualizes multiple clients from a single network entity. The simulation tool builds LAN frames of protocol stack level 2, which represent data originating from multiple clients to simulate traffic from multiple clients. It also provides a method for inserting the level 2 LAN frames built onto a physical LAN for actual delivery to a system being tested for simulating real client LAN traffic environment. U.S. Pat. No. 8,102,776, incorporated herein by reference, teaches that simulated network traffic may be generated using a specification of a sequence of frames to be transmitted from the network testing device These tools can only impact the links they are placed on (limited ports) and the tool costs prevent the wide spread use across test teams and configurations.
According to one embodiment, a method, system, and program product is provided. A first device receives a latency request. The first device sends a latency support confirmation. The first device receives an I/O frame. The I/O frame comprises a latency simulating bit and a latency duration. Based on the latency simulating bit and the latency duration, the first device holds the I/O frame. The first device sends the I/O frame.
According to one embodiment, the holding further comprises calculating, by the first device, a latency period based on the latency duration. The latency period is a period of time that said I/O frame is held for.
According to one embodiment, the latency period is calculated by the first device using a statistical distribution.
According to one embodiment, the statistical distribution comprises a function selected from a group consisting of: a constant value; an exponential probability density function, said latency delay representing said exponential probability density function by an expected value of said latency delay representing the 63.2nd percentile; an uniform probability density function, the latency delay representing the uniform probability density function by a lower limit and an upper limit of the latency delay; a Gaussian probability density function, the latency delay representing the Gaussian probability density function by an arithmetic mean representing the 50th percentile, a standard deviation of the latency delay, and the number of standard deviations to be included; a binary probability density function, the latency delay representing the binary probability density function by a first latency duration and a second latency duration; a Rayleigh probability density function, the latency delay representing the Rayleigh probability density function by an expected value of said latency delay representing the 63.2nd percentile and a shape factor of two; and a Weibull probability density function, the latency delay representing the Weibull probability density function by an expected value of the latency duration representing the 63.2nd percentile, a shape factor, and a latency offset.
According to one embodiment, the holding further comprises calculating, by a second device, a latency period based on the latency duration. The latency period is a period of time that the I/O frame is held for. The latency period overwrites data stored in the latency duration field.
According to one embodiment, the latency period is calculated by the second device using a statistical distribution.
According to one embodiment, the statistical distribution comprises a function selected from a group consisting of: a constant value; an exponential probability density function, said latency delay representing said exponential probability density function by an expected value of said latency delay representing the 63.2nd percentile; an uniform probability density function, the latency delay representing the uniform probability density function by a lower limit and an upper limit of the latency delay; a Gaussian probability density function, the latency delay representing the Gaussian probability density function by an arithmetic mean representing the 50th percentile, a standard deviation of the latency delay, and the number of standard deviations to be included; a binary probability density function, the latency delay representing the binary probability density function by a first latency duration and a second latency duration; a Rayleigh probability density function, the latency delay representing the Rayleigh probability density function by an expected value of said latency delay representing the 63.2nd percentile and a shape factor of two; and a Weibull probability density function, the latency delay representing the Weibull probability density function by an expected value of the latency duration representing the 63.2nd percentile, a shape factor, and a latency offset.
According to one embodiment, the first device is a server or a switch.
According to one embodiment, the second device is a server or a switch.
According to one embodiment, the first device is a server comprising a network adapter. The network adapter is configured for the holding of the I/O frame.
According to one embodiment, the first device comprises a receiver. The receiver comprises a buffer. The buffer is configured for the holding of the I/O frame.
According to one embodiment, the I/O frame comprises an I/O command.
The subject matter which is regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other features, and advantages of the disclosure are apparent from the following detailed description taken in conjunction with the accompanying drawings in which:
In accordance with an embodiment, a method, system, and computer program product is provided for stress-testing a computer system network, in particular, adding latency and simulating SAN hops to the computer system network. Embodiments described herein are directed to testing network communications. Specific details regarding networking, particularly for Fibre Channel, can be found in “Fibre Channel Link Services (FC-LS-3) REV 3.0”, published Feb. 21, 2012, incorporated herein by reference; “Fibre Channel Framing and Signaling -2 (FC-FS-2) Rev 0.00”, published May 7, 2003, incorporated herein by reference; “Fibre Channel Arbitrated Loop (FC-AL-2) Rev 7.0, published Apr. 1, 1999, incorporated herein by reference; and “Fibre Channel Framing and Signaling—4 (FC-FS-4) Rev 0.10”, published April 17, 2012, incorporated herein by reference.
For example, FC-LS-3 teaches the following:
Class 2 service: A service that multiplexes frames at frame boundaries to or from one or more Nx_Ports with acknowledgement provided.
Class 3 service: A service that multiplexes frames at frame boundaries to or from one or more Nx_Ports without acknowledgement.
Data Frame: An FC-4 Device_Data frame, an FC-4 Video_Data frame, or a Link_Data frame
Destination_Identifier (D_ID): The address identifier used to indicate the targeted destination Nx Port of the transmitted frame.
Fabric: The entity that interconnects Nx_Ports attached to it and is capable of routing frames by using the D_ID information in a Frame_Header.
F_Port: An FC_Port within the Fabric that attaches to a PN_Port through a link, and is addressable by the Nx_Ports communicating through the PN_Port attached to the F_Port by the F_Port_Controller well-known address (i.e., FFFFFEh)
FC_Port: A port that is capable of transmitting and receiving Fibre Channel framesaccording to the FC-0, FC-1, and FC-2 levels of the Fibre Channel architecture.
Information Category: The category to which the frame Payload belongs (e.g., Solicited Data, Unsolicited Data, Solicited Control and Unsolicited Control)
Link Control Facility (LCF): A hardware facility that attaches to an end of a link and manages transmission and reception of data.
Name_Identifier: A 64-bit identifier, with a 60-bit value preceded by a 4-bit Network_Address_Authority Identifier, used to identify entities in Fibre Channel (e.g., Nx_Port, node, F_Port, or Fabric)
Network_Address_Authority (NAA): An organization such as Institute of Electrical and Electronics Engineers (IEEE) that administers network addresses.
Network_Address_Authority (NAA) identifier: A four-bit identifier defined to indicate a Network_Address_Authority (NAA).
N_Port: An Nx_Port communicating through a PN_Port that is not operating a Loop Port State Machine, including services operating at well-known addresses.
N_Port_ID: An address identifier of an Nx_Port used in the identify source (S_ID) and destination (D_ID) fields of a frame that is unique within a topology.
NL_Port: An Nx_Port communicating through a PN_Port that is operating a Loop Port State Machine and without the qualifier Public or Private is assumed to be a Public NL_Port.
Nx_Port: An end point for Fibre Channel frame communication (see FC-FS-3) that is used in this standard to specify behavior of either N_Ports or Public NL_Ports that does not specify or constrain the behavior of Private NL_Ports.
Payload: Contents of the Data_Field of a frame, excluding Optional Headers and fill bytes, if present.
PN_Port: An LCF that supports only Nx_Ports.
Public NL_Port: An NL_Port that attempts a Fabric Login.
Private NL_Port: An NL_Port that does not attempt a Fabric Login and does not transmit open primitive (OPN).
Sequence: A set of one or more Data frames with a common Sequence_ID (SEQ_ID), transmitted unidirectionally from one Nx_Port to another Nx_Port with a corresponding response, if applicable, transmitted in response to each Data frame.
Sequence_ID (SEQ_ID): An identifier used to identify a Sequence.
One embodiment of a network is described in reference to
One embodiment of a Fabric Log In (FLOGI) frame is described in reference to
The SOF delimiter 201 is an ordered set that immediately precedes the frame content. It marks the beginning of the frame. The Frame Header 202 is 24 bytes of information used in Fibre Channel frames and contains information such as routing control, destination identifier, originating exchange, source identifier, etc. Network Header 203, which may also be known as the Ethernet Header, is an optional header whose presence may be indicated by a field in the Frame_Header 202.
The Network Header 203 may be used for routing between Fibre Channel networks of different Fabric address spaces, or Fibre Channel and non-Fibre Channel networks. The Association Header 204 may be used to identify a specific process or group of processes within a node associated with an exchange. When an Nx_Port has indicated during Login that an Initial Process Associator is required to communicate with it, the Association Header 204 shall be used by that Nx_Port to identify a specific Process or group of Processes within a node associated with an Exchange. The Device Header 205 may contain FC-4/Upper layer protocol specific data based on a Type field in the Frame Header 202. If present, the Device Header 205 may be present in either the first Data frame or in all Data frames of a Sequence. Upper level protocol (ULP) types may also make use of the Device Header 205. The Device Header 205 may be ignored and skipped if not needed. If a Device Header 205 is present for a ULP that does not require it, the related FC-4 level of the Fibre Channel protocol may reject the frame. The Payload 300, further described in
One embodiment of a payload is described in reference to
ELS_Command code 301 may be a 4-byte field (word 0) that identifies, for example a PLOGI, FLOGI, or LS_ACC. Every extended link service is assigned a code. It defines the bits and bits that follow this field.
The Port_Name 302 may be an eight-byte field (words 5-6) that identifies an Nx_Port. Each Nx_Port, including Nx_Ports that have Well-known addresses, shall provide a Name_Identifier. Nx_Ports that are not assigned to Well-known addresses shall provide a Name_Identifier that is unique within the Fibre Channel interaction space of the Nx_Port. Bits 63-60 specify the format of the Name Identifier.
The Node_Name or Fabric_Name 303 may be an eight-byte field (words 7-8) that labels a Node or Fabric for identification purposes, such as diagnostics., The Node_Name and Fabric_Name 303 are independent of and unrelated to network addressing. Each Node_Name or Fabric_Name 303 shall be unique within the Fibre Channel interaction space. Bits 63-60 specify the format of the name. Node_Name may be applicable to PLOGI, PLOGI LS_ACC and FLOGI. Fabric_Name may be applicable to FLOGI LS_ACC.
The Obsolete 304 may be a 16-byte field (words 9-12). This field is not used.
The Class 2 Service Parameters 305 may be a 16-byte field (words 13-16). The Class 3 Service Parameters 306 may be a 16-byte field (words 17-20). These parameters are further described in
The Auxiliary Parameter Data 307, which may also be known as the Data Field Control (DF_CTL), may be a 16-byte field (words 21-24). This field specifies whether the data portion of Payload 300 is used for a non data purpose. It may also specify the first n number of bytes designated for the non data purpose.
Vendor Version Level 308 field may be a 16-byte field (words 25-28) and may specify vendor-specific information. If the Valid Version Level bit in the Common Service Parameters field 400 (word 1, bit 29) is set to one, the Vendor Version Level field 308 contains valid information. If the Valid Version Level bit is set to zero, the Vendor Version Level field 308 is not meaningful.
The Services Availability field 309 may be a 8-byte field (word 29-30) that returns information regarding the Fabric's ability to route to the defined well-known addresses. It is meaningful only for FLOGI LS_ACC. Only bits 10-3 of word 30 are meaningful. Word 29 and bits 31-11 and 2-0 of word 30 are reserved.
The Login Extension Data Length 310 may be an 8-byte field (word 31). If the Login Extension Data Length field 310 is non-zero, a Login Extension follows the normal payload. The Login Extension Data Length field 310 indicates the length of the Login Extension field in words. The Payload Bit located in the Common Service Parameters 400 shall be set to one if this field is non-zero.
The Reserved Bytes 311 may be 32 bits, or 4 bytes, per word. In one embodiment, the Reserved Bytes may include 30 words, for example Bits Word 32-61, thus resulting in 120 bytes total in reserve, for future use. The Reserved Bytes may include a Latency Delay Bit (also known as Latency Delay Enabled bit or Latency Simulating Bit) and Maximum Number of Latency Delayed Frames, 314.
In one embodiment of the invention, the Latency Delay Enabled Bit and the Maximum Number of Latency Delayed frames, 314, may be located in the first byte. The first bit of this byte denotes whether the latency delay is disabled or enabled. For example, disabled may be represented by the bit=0 and enabled may be represented by the bit=1. If the latency delay is enabled (bit=1), then the controllers 108,118,124 know to search the I/O command 500 for delay header information which is then utilized. If the remaining bits of this byte are zero, then the number of frames with a latency delay 314 are unlimited, until the latency delay process is terminated by the user. However, if the remaining bits of this byte are non-zero, then the number of frames which are latency delayed 314 are limited to the number denoted by those remaining seven bits, after which time the latency-delay process auto-terminates. Additional reserved bytes may be appended to the first byte to add to the number of frames which are latency delayed before the latency delay process auto-terminates. Thus, the latency delay process may be enabled via a FLOGI, PLOGI, FDISC, or a LS_ACC.
The Clock Synchronization Quality of Service (QoS) field may be 8-bytes (word 62-63) for syncing the clock for the purposes of the simulated delay. This insures consistent simulated delays. This field revolves around a service, for example a service that resides in a switch, called the Clock Synchronization Server. During the login process, this field is used to check if the Clock Synchronization Server exists.
The Login Extension Data 313 may be specified by the any number of bytes located from word 64 and on. This field specifies additional data that may be necessary for a login, which extends the size of the login frame.
One embodiment of Common Service Parameters for PLOGI, FLOGI, and FLOGI LS_ACC, is described in reference to
The buffer-to-buffer Credit field 402 (word 0, bits 15-0) defines the number of buffers available for holding Class 2, or Class 3 frames received. An FC_Port tracks Buffer-to-buffer Credit as a single entity for all frames subject to buffer-to-buffer flow control. Values in the Buffer-to-buffer Credit field 402 are 1 to 32 767. The value 0 is reserved.
Continuously increasing relative offset 404 may comprise a bit, for example word 1, bit 31. If the continuously increasing relative offset bit (word 1, bit 31) is set to one, the Nx_Port supplying this parameter shall be capable of supporting continuously increasing relative offset, if present, within a Sequence on a frame by frame SEQ_CNT (sequence count) basis. This bit shall only be applicable to those Information Categories in which an Nx_Port supports relative offset (i.e., word 2, bits 15-0).
The Clean Address bit 405 (word 1, bit 31) provides an indication to an Nx_Port as to whether the address it was assigned by the Fabric had been previously used by another device within a Resource_Allocation_Timeout value (R_A_TOV). If this bit is set to zero, the assigned address may or may not have been used by a previous device within R_A_TOV. If this bit is set to one, the assigned address has not been used by any other device within R_A_TOV, or has been assigned to the current device for a previous FLOGI and not been changed within R_A_TOV. This bit is only meaningful in the FLOGI LS_ACC, it is not meaningful in the FLOGI request.
The Multiple N_Port_ID Support bit 406 (word 1, bit 31) shall be set to one to indicate that the PN_Port supplying this parameter is capable of requesting multiple N_Port_IDs using the FDISC ELS. The N_Port_ID Support bit shall be set to zero to indicate that the PN_Port supplying this parameter is not capable of requesting additional N_Port_IDs. This bit is only meaningful in the FLOGI request, it is not meaningful in the FLOGI LS_ACC.
The Random relative offset 407 (word 1, bit 30) indicates that the Nx_Port supplying this parameter shall be capable of supporting random relative offset values, if present. Random values may increase, decrease, or otherwise fluctuate within a Sequence. This bit shall only be applicable to those Information Categories in which an Nx_Port supports relative offset (i.e., word 3, bits 15-0).
The Virtual Fabrics bit 408 (word 1, bit 30) indicates support for Virtual fabrics. Virtual fabrics, for example, may include Virtual Cluster Switching (VCS) Fabric technology which is a Layer 2 Ethernet technology designed to improve network utilization, maximize application availability, increase scalability, and dramatically simplify the network architecture in virtualized data centers. It comprises three pillars of innovation technology: Ethernet fabrics, Distributed Intelligence, and Logical Chassis. VCS Fabric technology is designed to incorporate a set of Dynamic Services for the highest level of functionality and investment protection for data centers, making it a core building block for virtualizing data center networks.
The Valid Vendor Version level 409 (world 1, bit 29), in PLOGI, PLOGI LS_ACC, and FLOGI, may be set to one or zero. If the Valid Vendor Version Level bit 409 is set to one, the Vendor Version Level 308 (words 25 through 28 in
The Multiple N_Port_ID Assignent 410 (word 1, 29) may be a one or a zero. When the Multiple N_Port_ID Support bit 406 in the FLOGI request is one, the Multiple N_Port_ID Assignment bit 410 shall be set to one if the F_Port_supplying this parameter is capable of assigning multiple N_Port_IDs to the attached PN_Port using the FDISC ELS. The Multiple N_Port_ID Assignment bit 410 shall be set to zero when the Multiple N_Port_ID Support bit 407 in the FLOGI request is zero or to indicate that the F_Port_is not capable of assigning multiple N_Port_IDs to the attached PN_Port when the Multiple N_Port_ID Support bit 407 in the FLOGI request is one. This bit is only meaningful in the FLOGI LS_ACC, it is not meaningful in the FLOGI request.
One embodiment of an Input/Output (I/O) Command is described in reference to
The Delay Header 506 may comprise a Time Qualifier Bit 511, an ID of Choice of Probability Density Function 512, a First Parameter 513, Second Parameter 514, and a Third Parameter 515. The Leading Time Qualifier Bit 511 may be located in the first byte of the Delay Header 506 and may be a 0 value if the units of time (the time used for the delay) is in microseconds or a 1 value if the units of time is in milliseconds. The ID of the Choice of Probability Density Function 512 may be located in the last 7 bits of the first byte of the Delay Header 506, and is described further in
The Choice of Probability Density Function of Latency Duration describes multiple durations. The constant latency duration consists of a single specified latency duration. The exponentially distributed latency duration consists of the expected value of latency duration (63.2nd percentile). The uniformly distributed latency duration includes both a minimum and a maximum latency duration. The Gaussian distributed latency duration includes the arithmetic mean (average) value of latency duration (50 percentile), standard deviation of latency duration, and number of standard deviations. The binary distributed latency duration includes a first and a second value of latency duration. The Rayleigh distributed latency duration includes the expected value of latency duration (63.2nd percentile) and a shape parameter of two. The Weibull distributed latency duration includes the expected value of latency duration (63.2nd percentile), a shape parameter, and a latency duration offset, which may be zero.
The exponential probability density function is shown in equation [1] (shown below), where C is the characteristic latency duration and C=x at 63.2%, exp is the exponential function. Controllers 108, 118, and 124 may implement equations [1-4] (shown below), as well as the uniform and binary distributed latency durations, in software, for example open source software.
f(x)=(1/C)*exp(−x/C) equation [1]
The Gaussian probability density function is shown in equation [2] (shown below), where U is average value of the latency duration and U=x at 50%, and S is the standard deviation. Since the Gaussian probability density function extends from minus infinity to plus infinity, the domain or input to the Gaussian probability function is limited to n standard deviations, where n is user defined.
f(x)={1/[S*√(2π)]}*exp[−(x−U)2/(2S2)] equation [2]
The Weibull probability density function is shown in equation [3] (shown below), where B is the shape parameter, also know as the Weibull slope, and Xo is the latency duration offset, also known as the location parameter or minimum value of x. Xo may be set to zero.
f(x)=[B/(C−Xo)]*[(x−Xo)/(C−Xo)](B−1)* exp{−[(x−Xo)/(C−Xo)]B} equation [3]
The Rayleigh probability density function is shown in equation [4] (shown below), which is equation [3] with the special case of B=2 and Xo=0.
f(x)=[B/C]*[x/C]*exp{−[x/C]2} equation [4]
An exponential probability density function is a special case of the Weibull probability density function, where the shape parameter is unity (B=1) and the latency duration offset Xo is zero. The Rayleigh probability density function is a special case of the Weibull probability density function, where the shape parameter is two (B=2) and the latency duration offset Xo is zero. The Weibull probability density function with a shape parameter of B=3.5 mimics the Gaussian probability function. The binary probability density function is a discrete probability density function, one equivalent to flipping a coin, where heads gives the first value of latency duration, and tails gives the second value of latency duration. The constant latency duration is equivalent to these special cases: (a) the Gaussian probability density function with a zero standard deviation, (b) a binary probability density function where the first and second values of latency duration are equal, or (c) a uniform probability density function where the minimum and maximum latency durations are equal.
One embodiment of an implementation is that of the intelligent controller in a server, such as servers 102, 112. The location of the latency buffer is in the controller, such as buffer 109, 119 in controller 108, 118. The intelligent controller (a) calculates the latency duration, for example per the Probability Density Function described in
An alternative embodiment is an intelligent controller located in a switch, such as switch 120. The intelligent controller, such as controller 124, (a) calculates the latency duration, for example per the Probability Density Function described in
Yet another alternative embodiment is that of an intelligent transmitter in network adapter, such as transmitter 104A in network adapter 104 or a transmitter in a transmitting switch. The intelligent Transmitter in the sending network adapter (a) calculates the latency duration, for example per the Probability Density Function described in
Yet another alternative embodiment is that of an Intelligent Receiver in Network Adapter, such as receiver 114B in network adapter 114 with buffer 114C or a receiver in a receiving switch. Transmitter, such as transmitter 104A or a transmitter in a transmitting switch, sends information regarding latency duration, for example the delay header 506 in I/O frame 500, to a receiver, such as receiver 114B or a receiver in a receiving switch. The delay header 506 in I/O frame 500 may contain the ID of Choice of Probability Density Function 512, the First Parameter 513, the Second Parameter 514, and the Third Parameter 515 as described in
One embodiment of a process for latency simulation is described in reference to
In one embodiment, the first device performs steps 704, 705, and 706. In this embodiment, a delay header as previously described above in
In one embodiment, the second device performs steps 704, 705, and 706. In this embodiment, a delay header as previously described above in
In one embodiment, the first device performs step 704 and the second device performs steps 705, and 706. In this embodiment, a delay header as previously described above in
In one embodiment, the calculating step 704, whether by the first device or the second device, includes checking to see if there is a constant latency duration in the delay header in the I/O frame. If there is, no additional calculation is performed, and the process moves on to the next step.
In one embodiment, based on the maximum number of latency delayed frames field in the payload of the I/O frame, a subsequent number of frames will also be held based on the same parameters of the I/O frame.
The above creates a stress-test condition which simulates customer installations and workloads without the need of full-scale glass-house installations.
As will be appreciated by one skilled in the art, the embodiments may be embodied as a system, method or computer program product. Accordingly, the embodiments may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the embodiment may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
One example of a computer program product incorporating one or more aspects of an embodiment is described with reference to
Computer program code for carrying out operations of the embodiment may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The computer system 901 may communicate with other computers or networks of computers by way of a network adapter 913, for example a network interface controller (NIC), capable of communicating 908 with a network 909. For example, network adapters may include communications channels, token ring, Ethernet or modems. The computer system 901 may also include a controller, not shown, connected to the network adapter. Alternatively, the computer system 901 may communicate using a wireless interface, such as a CDPD (cellular digital packet data) card. The computer system 901 may be associated with such other computers in a Local Area Network (LAN), VLAN, or a Wide Area Network (WAN), or the computer system 901 may be a client in a client/server arrangement with another computer, etc. All of these configurations, as well as the appropriate communications hardware and software, are known in the art.
Software programming code which embodies an embodiment may be typically accessed by the processor 906 from long-term storage media 907. The software programming code may be embodied on any of a variety of known media for use with a data processing system, as previously described above with reference to
Alternatively, the programming code 911 may be embodied in the memory 905, and accessed by the processor 906 using the processor bus. Such programming code may include an operating system which controls the function and interaction of the various computer components and one or more application programs 912. Program code may be normally paged from storage media 907 to memory 905 where it may be available for processing by the processor 906. The techniques and methods for embodying software programming code in memory, on physical media, and/or distributing software code via networks are well known and will not be further discussed herein. The computer program product medium may be typically readable by a processing circuit preferably in a computer system for execution by the processing circuit.
The flow diagrams depicted herein are just examples. There may be many variations to these diagrams or the steps (or operations) described therein without departing from the spirit of the embodiment. For instance, the steps may be performed in a differing order, or steps may be added, deleted or modified. All of these variations are considered a part of the claimed embodiment.
While the preferred embodiment has been described, it will be understood that those skilled in the art, both now and in the future, may make various improvements and enhancements which fall within the scope of the claims which follow.
The present application is a continuation of U.S. patent application Ser. No. 14/246744, “Introducing Latency And Delay In A SAN Environment” filed Apr. 7, 2014, the contents of which are incorporated by reference herein in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 14246744 | Apr 2014 | US |
Child | 15406088 | US |