This disclosure relates in general to the field of communications and, more particularly, to policy-driven storage in a microserver computing environment.
Microservers are an emerging trend of servers for processing lightweight, scale out workloads for hyper-scale data centers with large numbers of relatively lightweight server nodes. The microserver represents a new server architecture characterized by many (e.g., tens or even hundreds) lightweight server nodes bundled together in a shared chassis infrastructure, for example, sharing power, cooling fans, and input/output components, eliminating space and power consumption demands of duplicate infrastructure components. The microserver topology facilitates density, lower power per node, reduced costs, and increased operational efficiency. Microservers are generally based on small form-factor, system-on-a-chip (SoC) boards, which pack processing capability, memory, and system input/output onto a single integrated circuit.
To provide a more complete understanding of the present disclosure and features and advantages thereof, reference is made to the following description, taken in conjunction with the accompanying figures, wherein like reference numerals represent like parts, in which:
Overview
An example method for facilitating policy-driven storage in a microserver computing environment is provided and includes receiving, at an input/output (I/O) adapter in a microserver chassis having a plurality of compute nodes and a shared storage resource, policy contexts prescribing (e.g., indicating, specifying, comprising, designating, etc.) storage access parameters of respective compute nodes and enforcing the respective policy contexts on I/O operations by the compute nodes, in which respect a particular I/O operation by any compute node is not executed if the respective policy context does not allow the particular I/O operation. The method further includes allocating (e.g., distributing, assigning, issuing, dispensing, etc.) tokens to command descriptors associated with I/O operations for accessing the shared storage resource, identifying a violation of any policy context of any compute node based on availability of the tokens, and throttling (e.g., regulating, decreasing, controlling, adjusting, choking, curbing, reducing, etc.) I/O operations by other compute nodes until the violation disappears.
As used herein, the term “policy context” of a compute node refers to a software object (e.g., structure) containing information (e.g., values of one or more relevant variables) related to one or more policies (e.g., conditions, rules, parameters, restrictions, constraints, etc.) to be applied on the compute node. As used herein, the term “compute node” refers to a hardware processing apparatus, in which user applications (e.g., software programs) are executed.
Example Embodiments
Turning to
I/O adapter 16 services (e.g., processes) both network and storage access requests from compute nodes 14 within microserver 12. In various embodiments, compute nodes 14 may access a shared storage resource 18 through I/O adapter 16 according to policy contexts 20 over a shared transmission medium, such as a Peripheral Component Interconnect Express (PCIe) bus. Each compute node 14 is associated with a corresponding policy context 20. Policy context 20 prescribe storage access parameters (e.g., input/output operations per second, minimum bandwidth, maximum bandwidth, etc.) of respective compute nodes 14.
Note that the label “20” may refer to a single policy context, or it may refer to a plurality of policy contexts without changing the scope of the embodiments. For example, policy context 20 may comprise a single software object comprising storage access parameters of substantially all compute nodes 14 in microserver chassis; in another example, policy context 20 may comprise a plurality of software objects, each such software object comprising storage access parameters of a corresponding one of compute nodes 14, and each such software object being referred to as a separate policy context. Irrespective of whether the label is used in the singular or plural, any policy context 20 comprises storage access parameters of one or more compute nodes 14 within the broad scope of the embodiments.
One or more switch(es) 22 outside microserver chassis 12 may provide network connectivity to a network external to microserver chassis 12. A management application, such as a Cisco® Unified Computing System™ (UCS) manager executing on (or through) switch 22 configures network endpoints (e.g., a network endpoint refers to a logical endpoint of network traffic corresponding to a specific network protocol layer) and storage endpoints (e.g., a storage endpoint refers to a logical endpoint for storage traffic) for each compute node 14 with user-defined attributes and capabilities. The UCS manager also provisions storage resource 18 (e.g., storage disks, memory space, boot space, logical unit numbers (LUNs), etc.) for each compute node 14 with suitable capacity and reliability characteristics (e.g., array of independent disks (RAID) level) according to user-provided instructions. An appropriate software executing on I/O adapter 16 creates suitable PCI endpoints on compute nodes 14, for example, associated with the respective network endpoints and storage endpoints. Respective host drivers managing the network endpoints and storage endpoints in corresponding compute nodes 14 plug into the appropriate network and storage stacks.
Some embodiments of communication system 10 facilitate network centric data center management with the network endpoints and storage endpoints being capable of being configured through centralized policy enforcement according to user-defined attributes and capabilities. Whereas the network endpoints have a peer representation on upstream switch 22 where policies can be enforced, storage resource 18 is local to microserver 12 and the storage endpoints exist solely in the domain within microserver chassis 12. In other words, the storage endpoints are inaccessible to switch 22 (e.g., storage traffic is local to microserver chassis 12 and does not traverse switch 22), and thus policy contexts 20 cannot be enforced at switch 22.
Compute nodes 14 may be of varying processing capacities and PCIe bandwidths. For example, in some embodiments, compute nodes 14 may comprise application specific servers, wherein the respective central processing units (CPUs) and storage resource 18 are custom-built for the applications executing thereon, with one of compute nodes 14 using a 2 GHz CPU and 512 MB of memory, another of compute nodes 14 using a 1 GHz CPU and 256 MB of memory, and so on. In another example, some workloads may require guaranteed bandwidth; some other workloads may require bandwidth to be restricted according to predefined parameters (e.g., network utilization, storage throughput, I/Os per second (IOPS), storage bandwidth utilization); etc. According to various embodiments, a datacenter administrator can configure compute nodes 14 for various different workloads having different network and storage bandwidths through the UCS manager executing on switch 22. At least a portion of the configuration pertaining to accessing storage resource 18 may be stored locally in microserver chassis 12 as policy contexts 20 and enforced by I/O adapter 16.
In various embodiments, I/O adapter 16 may also facilitate collection of statistics on host network adapters and export them to UCS manager. The administrator can view per network interface statistics on a suitable graphical user interface (GUI) of UCS manager. In various embodiments, configuration of the various network endpoints and storage endpoints may be enforced through appropriate policies, which can change dynamically as desired by the administrator. VIC protocol control messages may be exchanged between microserver chassis 12 and switch 22 to apply the policies immediately (e.g., contemporaneously, simultaneously, within a predetermined time period, etc.). Thus, UCS manager provides a unified view of the data center and makes it easy for the administrator to administer any configuration change from a single control point.
For purposes of illustrating the techniques of communication system 10, it is important to understand the communications that may be traversing the system shown in
Turning to memory retrieval operations, direct memory access (DMA) is an ability of a device (such as a compute node) to access local host memory directly, without the intervention of any central processing units (CPUs). Remote DMA (RDMA) is the ability of accessing (e.g., reading from or writing to) memory on a remote machine without interrupting the processing of the CPU(s) on the remote machine. Although compute nodes 14 are local within microserver chassis 12, they are remote relative to each other's compute and memory resources, and therefore RDMA can be used for data transfers between compute nodes 14 with minimal processor overhead and low latency.
RDMA communication is based on a set of three queues: (i) a send queue and (ii) a receive queue, comprising a Queue Pair (QP) and (iii) a Completion Queue (CQ). Posts in the QP are used to initiate the sending or receiving of data. An application (e.g., through a host driver) places instructions on its work queues that generate buffers in I/O adapter 16 to send or receive data. I/O adapter 16 consumes the instructions from the send queue at the egress side and streams the data to its memory region corresponding to the remote system. The memory region consumes the work queues at the receive queue at the ingress side and places the received data in appropriate memory regions of the host.
In a general sense, the RDMA traffic between compute nodes 14 in microserver chassis 12 does not leave the PCIe domain (e.g., shared transmission medium within microserver chassis 12 through which data is communicated according to PCIe protocols) and enter the Ethernet domain (e.g., Ethernet network outside microserver chassis 12 through which data is communicated according to Ethernet protocols). In other words, the RDMA traffic is local to microserver chassis 12 and does not traverse switch 22. On the other hand, network traffic from and to compute nodes 14 traverse switch 22. Therefore, unlike enforcement of network traffic related policies (of administrator provided instructions at UCS manager), enforcement of storage traffic related policies cannot be performed at switch 22.
Moreover, in such shared infrastructure deployments, in which shared storage resource 18 is fixed and limited in size, there is a potential for one compute node 14 to starve other compute nodes 14 by over utilizing shared storage resource 18. Thus, applications running on compute nodes 14 experience uneven storage performance despite corresponding compute nodes 14 having identical processing power and PCIe bandwidth.
In addition, because the storage interfaces of compute nodes 14 directly communicate with shared storage resource 18 through I/O adapter 16, bypassing switch 22, the I/O statistics are not accessible to the central UCS manager executing in switch 22. The administrator has to rely on statistics collected by storage stacks on each disparate compute node 14 for the I/O statistics. Any sort of storage traffic shaping has to be executed on respective compute nodes 14 and cannot be dynamically changed without manual intervention. In large data centers with hundreds and thousands of compute nodes 14 on separate microserver chassis, such manual adjustment of policies for each of compute nodes 14 may not be practical.
Further, because each compute node 14 has access only to its local storage traffic, any global analysis of the I/O statistics (e.g., such as shared load on the shared resources) cannot be facilitated by per-compute node policies enforced separately on each compute node 14. The operating system of each compute node 14 does not have a global view of storage traffic originating from all compute nodes to a shared storage infrastructure. Thus, while the operating system can offer ways to limit the bandwidth for the corresponding compute node 14, it cannot enforce policies guaranteeing a minimum bandwidth or throughput. Such a highly rigid manual approach can defeat centralized management of the data center.
As compute nodes 14 don different roles in the clustered multi-host environment, they run different applications and workloads, with corresponding differing requirements for network and storage bandwidth. Some applications also mandate certain minimum network and storage bandwidth at any given time for optimal performance Whereas network QoS management has been well established and implemented across various network elements (e.g., OS stack, network adapter, switches, routers, etc.) in the network, technologies and solutions to manage storage QoS have been lagging. Storage area network (SAN) storage vendors have attempted to implement storage QoS on SAN switches and targets. However, the SAN solutions are not applicable for the microserver computing environment, in which every compute node 14 perceives storage as local, but share a common storage controller to access boot and data LUNs.
To provide storage QoS in such multi-host system, there is a need for sampling storage I/O commands across compute nodes 14 and arbitrating access to shared storage resource 18 based on administrator provided configuration. Moreover, there is a further need for the solution to be policy based, dynamic and centralized, working uniformly across all host platforms and operating systems, without separate agents executing on compute nodes 14 to shape storage traffic.
Communication system 10 is configured to such issues (among others) by facilitating policy-driven storage in a microserver computing environment. According to various embodiments, a human administrator defines QoS policies at switch 22 for storage adapters associated with compute nodes 14. The QoS policies define various parameters, such as maximum bandwidth allocated to a particular compute node 14, maximum number of IOPs allowed from a particular storage adapter, and/or minimum bandwidth to be guaranteed for a particular storage adapter. The policies are dynamic, in the sense that they can be changed at any time, irrespective of the state of compute node 14. Any changes in storage QoS policies are communicated substantially immediately to I/O adapter 16 through suitable VIC protocol control messages. The QoS policies are stored locally at I/O adapter 16 as policy context 20.
Turning to
A System Link Technology™ executing in communication system 10 enables creation of PCIe physical functions represented by sNICs 24. Any one sNIC 24 presents a PCIe storage endpoint comprising a virtual storage controller to the operating system of the respective compute node 14 and maps storage resource 18 to a specific service profile within the UCS manager (e.g., executing in or through upstream switch 22). For example, sNIC0 presents a virtual storage controller to the operating system of compute node A and maps storage resource 18 to a specific service profile within the UCS manager associated with compute node A. Similarly, sNIC1 presents a virtual storage controller to the operating system of compute node B and maps storage resource 18 to a specific service profile within the UCS manager associated with compute node B; and so on.
I/O adapter 16 creates sNICs 24 based on administrator provided policies at switch 22. sNICs 24 allow respective ones of compute nodes 14 to have their own specific virtual drive carved out of the available physical drives within microserver chassis 12. The communication between the operating system to the drive is via standard SCSI commands sNICs 24 comprise PCIe endpoints claimed by SCSI host drivers of respective compute nodes 14. The UCS manager at switch 22 provisions storage on shared storage resource 18 and exports LUNs to compute nodes 14 via respective sNICs 24.
A root complex 26 of the PCIe bus of microserver chassis 12 enables connectivity to a PLX switch (optional) and a storage controller 30, which connects to various shared storage devices (SSD) comprising storage resource 18. In various embodiments, shared storage controller 30 comprises any off-the-shelf storage controller from any suitable vendor. The PLX switch is optional, and may be used to extend the number of shared storage controllers that can be attached to the PCIe bus. Storage firmware 28 executing in I/O adapter 16 maintains per sNIC policy contexts, indicative of active policies for corresponding compute nodes 14 as specified in policy context 20. In some embodiments, the centralized UCS manager provisions LUNs for compute nodes 14 using out of band management interface over an Inter-Integrated Circuit (I2C) bus. I/O adapter 16 samples the I/O traffic originating from sNICs 24 to various LUNs on storage resource 18 and generates (and maintains) counters per sNIC interface or optionally per sNIC and per LUN (e.g., <sNIC, LUN>).
According to various embodiments, shared storage controller 30 exposes a command ring comprised of an array of command descriptors (of SCSI commands) to storage firmware 28. Each command descriptor contains SCSI command related information, address pointers to data buffers in shared storage resource 18 and a variety of control information. The command ring comprises a circular buffer comprising the command descriptors. Embodiments of communication system 10 allocate tokens to command descriptors associated with I/O operations for accessing shared storage resource 18 (e.g., tokens represent command descriptors). In an example embodiment, storage firmware 20 allocates the token to the command descriptors.
For example, each command descriptor in the command ring is represented as a token associated with the corresponding I/O operation (e.g., SCSI command). As used herein, “token” is a special series of bits that travels around a token-ring buffer, such as the command ring. As the token circulates, packet processors in I/O adapter 16 can capture it. The token acts like a ticket, enabling its owner (e.g., marked SCSI command) to be executed. In some embodiments, only one token is associated with each I/O operation that accesses a specific portion of shared storage resource 18. The tokens are managed in a common resource pool and an arbiter routine (e.g., software code, microcode, computer program, process, thread, instructions, etc.) of storage firmware 28 assigns the tokens to corresponding I/O commands.
Any suitable token management protocol may be used within the broad scope of the embodiments. For example, the tokens are distributed by the token ring: each cycle a packet processor's thread interface unit (TIU) passes on a token to the right and receives one from the left. Two basic instructions are provided for ring management: the first instruction requests a token; the processor removes a token from the ring, if one is available, and places it in the requesting thread's context. The requesting thread is then allowed to fork and jump, much like a subroutine call. When the thread terminates, the second instruction releases the token back into the ring. In a general sense, only SCSI command holding the token (e.g., marked with the token) can access the shared storage resource 18. In some embodiments, the token specifies an index to be used in the command ring of shared storage controller 30.
For every I/O command, the arbiter routine decides to award or deny the token for that I/O command based on token availability in the command ring and policy context 20 for corresponding sNIC 24. If the arbiter routine awards the token, a data processor in I/O adapter 16 initiates a command request by posting the I/O command in the command queue of shared storage controller 30. In various embodiments, the data processor executes storage firmware 28. If arbiter routine denies the token due to unavailability or based on policy context 20, the data processor returns a “BUSY” status for that I/O command.
Shared storage controller 30 notifies the data processor of completion of the I/O command. The data processor forms a I/O completion notification and forwards it to relevant compute node 14 that initially issued the SCSI command. The arbiter routine monitors the I/O completion notifications and returns the token back to the common token pool. Each sNIC 24 provides a pair of (i) command queue and (ii) response queue for issuing I/O commands to shared storage controller 30 and also for receiving I/O completion notifications. Moreover, I/O adapter 16 gathers storage I/O statistics and token arbitration without impacting data path performance In some embodiments, the administrator can change the storage QoS policy even when compute nodes 14 are operational and I/Os are active. Policy changes are communicated to storage firmware 28 via VIC protocol control messages and are validated before being enforced.
Turning to the infrastructure of communication system, network topology of the network including microserver chassis 12 can include any number of compute nodes, servers, hardware accelerators, virtual machines, switches (including distributed virtual switches), routers, and other nodes inter-connected to form a large and complex network. A node may be any electronic device, client, server, peer, service, application, or other object capable of sending, receiving, or forwarding information over communications channels in a network. Elements of
Communication system 10 may include a configuration capable of TCP/IP communications for the electronic transmission or reception of data packets in a network. Communication system 10 may also operate in conjunction with a User Datagram Protocol/Internet Protocol (UDP/IP) or any other suitable protocol, where appropriate and based on particular needs. In addition, gateways, routers, switches, and any other suitable nodes (physical or virtual) may be used to facilitate electronic communication between various nodes in the network.
Note that the numerical and letter designations assigned to the elements of
The example network environment may be configured over a physical infrastructure that may include one or more networks and, further, may be configured in any form including, but not limited to, local area networks (LANs), wireless local area networks (WLANs), VLANs, metropolitan area networks (MANs), VPNs, Intranet, Extranet, any other appropriate architecture or system, or any combination thereof that facilitates communications in a network.
In some embodiments, a communication link may represent any electronic link supporting a LAN environment such as, for example, cable, Ethernet, wireless technologies (e.g., IEEE 802.11x), ATM, fiber optics, etc. or any suitable combination thereof. In other embodiments, communication links may represent a remote connection through any appropriate medium (e.g., digital subscriber lines (DSL), telephone lines, T1 lines, T3 lines, wireless, satellite, fiber optics, cable, Ethernet, etc. or any combination thereof) and/or through any additional networks such as a wide area networks (e.g., the Internet).
In various embodiments, microserver chassis 12 may comprise a rack-mounted enclosure, blade enclosure, or a rack computer that accepts plug-in compute nodes 14. Note that microserver chassis 12 can include, in a general sense, any suitable network element, which encompasses computers, network appliances, servers, routers, switches, gateways, bridges, load-balancers, firewalls, processors, modules, or any other suitable device, component, element, or object operable to exchange information in a network environment. Moreover, the network elements may include any suitably configured hardware provisioned with suitable software, components, modules, interfaces, or objects that facilitate the operations thereof. This may be inclusive of appropriate algorithms and communication protocols that allow for the effective exchange of data or information.
Compute nodes 14 may comprise printed circuit boards, for example, manufactured with empty sockets. Each printed circuit board may hold more than one processor (e.g., within the same processor family, differing core counts, with a wide range of frequencies and vastly differing memory cache structures may be included in a single processor/socket combination). In some embodiments, each compute node 14 may comprise one or mode central processing unit (CPU) and memory with standard PCIe connectivity to chassis resources, including storage resource 18. Components shared in microserver chassis 12 includes power, management, cooling, storage and networking.
I/O adapter 16 may include an electronic circuit, expansion card or plug-in module that accepts input and generates output in a particular format. I/O adapter 16 facilitates conversion of data format and electronic timing between input/output streams and internal computer circuits of microserver chassis 12. In an example embodiment, I/O adapter 16 comprises five Microprocessor without Interlocked Pipeline Stages (MIPS) processors, with one of them executing control firmware and the remaining handling the storage data path.
Embodiments of communication system 10 facilitate achieving both minimum bandwidth utilization and maximum bandwidth utilization of shared storage resource 18 by compute nodes 14 within microserver chassis 12. Further, various policy enforcement operations described herein are performed on sNICs 24 without manual intervention or any intervention by compute nodes 14. In other words, the policy enforcement is transparent to compute nodes 14.
Whereas communication system 10 has been described with reference to a microserver computing environment, it will be appreciated that the operations described herein can be executed at any network level wherein a plurality of computing devices access shared storage resources. For example, the operations performed by I/O adapter 16 may be extended to execute at switch 22. Thus, the operations described herein may be applied to a storage area network (SAN) environment with servers in physically distinct chassis sharing storage resources in the SAN. Policy enforcement using tokens, and per-sNIC policy contexts, etc. as described herein may be performed at switch 22 connecting the servers in such scenarios.
The number of applications running in a typical data center is growing exponentially. With this, the demand for servers and network infrastructure is also constantly growing. Massively Scalable Data Centers are being hosted by various cloud providers. The microserver architecture allows use of more compute nodes using less physical space. For efficient management of such microserver infrastructure, it is desirable to consolidate management planes at single point of control, as is possible with embodiments of communication system 10. Also, different treatment of storage traffic based on the workload and application performance is possible through enforcement of appropriate policy contexts 20. Embodiments of communication system 10 allow defining a storage QoS policy from centralized management software in switch 22 and dynamically updating the QoS based on demand and requirements.
Turning to
Host-1 is associated with a particular sNIC 24, namely, sNIC-1, provisioned with a command queue 32, to which a host driver of an application executing in Host-1 posts a I/O operation (e.g., SCSI command), such as a read command, or a write command as a SCSI packet through sNIC-1. Command queue 32 may be provisioned in sNIC-1 associated with Host-1 by a control firmware, which forms a portion of storage firmware 28. sNIC-1 may encapsulate the SCSI packet in an Ethernet packet with an appropriate Ethernet header. A packet classifier 34 in I/O adapter 16 filters the Ethernet packet using appropriate SCSI command filters 36. In some embodiments, packet classifier 34 filters the Ethernet packet based on its Layer 2 (L2) to Layer 5 (L5) header fields.
The filtered result comprises a key which can be used to index into a flow table 38, which includes a plurality of entries associated with SCSI commands corresponding to sNICs 24, among other parameters. In the example shown, flow table entry 40 is associated with a SCSI command corresponding to sNIC-1. Flow table 38 facilitates recording storage traffic in microserver chassis 12 based on suitable match criteria for further analysis. In a general sense, flow table 38 may be used to track packet flows based on suitable match criteria applied to header fields in the Ethernet packets' L2-L5 headers. In some embodiments, flow table 38 provides a secondary look up table after packets are filtered at packet classifier 34. In some embodiments, any match in flow table 38 updates associated statistics in hardware (e.g., ASIC) in I/O adapter 16. The statistics include packet count, byte count and latest timestamp. In some embodiments, each flow table entry is also associated with an action field, such as forwarding the packet to a suitable queue, or executing an appropriate microcode routine.
Note that packet classifier 34 and flow table 38 classify and track Ethernet packets. In a general sense, packet classifier 34 and flow table 38 are generally available in any I/O adapter and are configured typically for Ethernet packet processing. Such general purpose packet classifier 34 and flow table 38 can be modified according to embodiments of communication system 10 to include appropriate filters to filter (e.g., identify, screen, etc.) SCSI commands and responses (e.g., containing CDB and LUN information) formatted as Ethernet packets with a reserved internal Ether type.
In various embodiments, the flow table lookup of the filtered result from packet classifier 34 triggers execution of an arbiter routine (or other such action) in a packet processor 42. In an example embodiment, packet processor 42 processes packets on ingress or egress paths per Uplink InterFace (UIF) of I/O adapter 16. In some embodiments, the arbiter routine comprises various special microcode routines (also known as Rewrite Rules). which are executed in packet processor 42 to modify contents of the packets and to further perform other actions.
The arbiter routine, which can comprise a microcode routine in some embodiments, decides to award or deny a token to the SCSI command from sNIC-1 based on token availability in a common token pool 46 and according to a per sNIC policy context 48. Common token pool 46 contains tokens allowing I/O commands to be executed or returned back to the host with a BUSY/QUEUE FULL status. In various embodiments, common token pool 46 is derived from the command ring provided by shared storage controller 30. The command descriptors of the command ring are managed as resources and allocated from common token pool 46.
According to an example embodiment, common token pool 46 comprises a circular buffer marked by a producer and consumer index. The arbiter routine awards tokens to the SCSI commands from the circular buffer. The arbiter routine also returns tokens back to common token pool 46 after I/O command completion. In various embodiments, a single packet processor 42 manages the award and return of tokens from and to common token pool 46.
In various embodiments, per sNIC policy context 48 is derived by a control processor 50 from policy context 20 in some embodiments. Per sNIC policy context 48 holds per sNIC storage access parameters of sNICs 24 configured according to policy context 20 received from switch 22 at I/O adapter 16. In an example embodiment, the per sNIC storage access parameters comprise maximum bandwidth, minimum bandwidth or maximum IOPS associated with storage traffic. In various embodiments, control processor 50 comprises a MIPS based processor executing control path firmware. The control path firmware executing in control processor 50 configures sNICs 24 and shared storage resource 18 mapped to compute nodes 14, handles VIC protocol communication between I/O adapter 16 and the UCS manager executing on switch 22, and handles requests from host drivers to change states of sNICs 24.
In one example, the administrator specifies values of various storage access parameters for each compute node 14 in policy context 20; control processor 50 retrieves the association of each compute node 14 with its corresponding sNIC 24 (e.g., Host-1 is associated with sNIC-1); control processor 50 applies the various storage parameters specified in policy context 20 with corresponding sNIC 24 based on the retrieved association. In another example, the administrator specifies values of various storage access parameters for groups of compute nodes 14 (e.g., compute nodes 14 executing web applications can use a maximum of x amount of bandwidth; compute nodes 14 executing database applications must have a minimum of y amount of bandwidth; etc.) in policy context 20. Control processor 50 identifies compute nodes 14 in the respective groups, retrieves association of each identified compute node 14 with its corresponding sNIC 24, and applies the various storage parameters specified in policy context 20 with corresponding sNIC 24 based on the retrieved association. Note that the groups of compute nodes 14 can be based on any suitable criterion, such as applications, users, authentication parameters, user roles, compute node hardware, etc. within the broad scope of the embodiments.
Turning back to operations on the Ethernet packet from sNIC-1, the arbiter routine executing in packet processor 42 strips the Ethernet header off the Ethernet packet (using any suitable stripping procedure known in the art) and posts the SCSI command into a command response queue (RQ) 52 at a data path processor 54. In various embodiments, data path processor 54 comprises a MIPs based processor in I/O adapter 16. If the token has been awarded, the I/O command is forwarded to shared storage controller 30 through root complex 26. Root complex 26 provides connectivity to storage controller 30 over a PCIe interface. The DMA operation associated with the I/O command is carried out directly between storage controller 30 and Host-1 over a PCIe bus.
Resources (e.g., command ring) of storage controller 30 are directly mapped to a VIC address space (e.g., memory space) in I/O adapter 16; control path and data path firmware running on various MIPS processors (e.g., data path processor 54) in I/O adapter 16 can access the memory mapped space to issue the I/O commands Storage controller 30 can perform DMA to or from server address spaces (in memory) using suitably specialized hardware (e.g., ternary content addressable memory (TCAM) table).
Data path processor 54 is notified when the I/O operation is complete. For example, I/O completion interrupts are mapped to data path processor 54, which thereafter generates a completion event to be sent to Host-1. Data path processor 54 creates a I/O completion notification indicating completion of the SCSI command from sNIC-1 and posts the I/O completion notification in a response work queue (WQ) 56. The I/O completion notification is encapsulated in an appropriate Ethernet packet having a suitable Ethernet header according to embodiments described herein.
Packet classifier 34 filters the Ethernet header according to SCSI response filters 58. The result of the filtering comprises a key that is used as an index into flow table 38. The Ethernet response packets are matched with appropriate response entries 60 corresponding to sNIC-1 associated with the I/O completion notification. Had the I/O completion notification been an indication of “BUSY” or “QUEUE FULL” status, another appropriate busy response entry 61 corresponding to sNIC-1 provides the requisite match. Any match in flow table 38 triggers execution of an appropriate arbiter routine in packet processor 42. The arbiter routine returns the token associated with the I/O command to common token pool 46 and posts the I/O completion notification in a response queue 62 of Host-1.
In various embodiments, the arbiter routine indicated in flow table 38 varies according a type of the SCSI packet. If the SCSI packet encapsulated in the Ethernet packet comprises a SCSI command, the arbiter routine determines if policy context 20 permits a token fetch; if the policy context permits the token fetch, the arbiter routine attempts to fetch one of the tokens from common token pool 46. On the other hand, if the SCSI packet encapsulated in the Ethernet packet comprises a SCSI response, the arbiter routine increments a hit counter in flow table 38 indicative of a number of I/O operations completed for sNIC-1 of Host-1, decapsulates the Ethernet packet and forwards the SCSI response to sNIC-1. Further, if the SCSI packet encapsulated in the Ethernet packet comprises a SCSI busy response indicating token unavailability, the arbiter routine decapsulates the Ethernet packet and forwards the SCSI busy response to sNIC-1.
Turning to
The control path firmware initializes a QoS monitor 64, which runs periodically on control processor 50. QoS Monitor 64 administers system-wide QoS policies across sNICs 24 and/or compute nodes 14. QoS Monitor 64 has a global view of the total load on shared storage resource 18, including visibility to current bandwidth utilization of various sNICs 24 and policy context 20. As an example, a monitor thread (e.g., sequence of instructions) of QoS monitor 64 can make decisions to provide guaranteed bandwidth for sNICs 24, which request such guaranteed bandwidth. QoS monitor 64 includes two monitor threads: a low frequency (e.g., once a second) periodic sampler 66 and a higher frequency throttler 68. QoS monitor 64 also maintains a sNIC list 70, comprising a list of sNICs 24 in microserver chassis 12.
Periodic sampler 66 samples the I/O operations being executed and updates the per sNIC IOPS parameter in flow table 38. Throttler 68 is scheduled to run at a higher frequency if low frequency periodic sampler 66 detects violations of policy context 20. High frequency throttler 68 attempts to correct the violations by dynamically throttling and un-throttling sNICs 24.
During operation, periodic sampler 66 samples flow table entries (e.g., 40, 60, 61) for sNICs 24 in flow table 38. Periodic sampler 66 measures IOPS based on the number of I/O completions sampled in successive runs. For sNICs 24 that have requested bandwidth reservation according to associated policy context 20, a “starve counter” is examined in the corresponding flow table entry. If the starve counter is 0, nothing is done. On the other hand, a non-zero starve counter, and/or a number of outstanding token count lower than a minimum threshold token indicates starvation (e.g., unavailability of requested bandwidth reservation). The sNIC is considered as a “starving sNIC” and added to a starving sNIC list 72. In an example embodiment, periodic sampler 66 identifies substantially all starving sNICs in a single sweep (e.g., execution) and schedules throttler 68 to handle the situation.
In various embodiments, high frequency throttler 68 is invoked on demand, and it executes at a higher frequency (than periodic sampler 66) until the starving situation is remedied and the violation of policy context 20 disappears. In an example embodiment when it is invoked, throttler 68 is scheduled to execute every 100 ms until starving sNICs 24 are no longer starved. In various embodiments, throttler 68 make a list of sNICs 24 that can be throttled and lists such sNICs in a throttled sNIC list 74. sNICs 24 may be listed in throttled sNIC list 74 based on several criteria: for example, sNICs 24 without any associated policy context may be added to throttled sNIC list 74; sNICs 24 that have relatively lower priority according to policy context 20 may be added to throttled sNIC list 74 (e.g., low priority sNICs are added before normal priority sNICs); sNICs having a “Max IOPS” (0x01) policy type or “Max Bandwidth utilization” (0x02) policy type may be added to throttled sNIC list 74; sNICs having lower bandwidth requirement and not experiencing any violation of respective per sNIC policy context 48 may be added to throttled sNIC list 74; and so on. The operating state of such sNICs added to throttled sNIC list 74 may be set to “PAUSED”.
In an example embodiment, the state of starved sNICs may be checked after a predetermined wait period (e.g., 100 ms). If the situation has not improved (e.g., number of starved sNICs remains the same; or the same set of sNICs continue to be starved; etc.), additional sNICs may be added to throttled sNIC list 74. The operations may continue until previously starved sNICs 24 are able to perform I/O operations at a desired (e.g., guaranteed) bandwidth utilization. Thereupon, high frequency throttler 68 ceases to reschedule itself and terminates its operation. In some embodiments, before terminating, high frequency throttler 68 also updates QoS monitor 64 to indicate completion of the throttling task.
In various embodiments, periodic sampler 66 detects during execution that certain sNICs 24 are being throttled; thereupon, periodic sampler 66 monitors the condition of such sNICs 24 that have minimum (e.g., guaranteed, required, etc.) bandwidth requirement. If all sNICs 24 are able to perform I/O operations at the minimum (e.g., guaranteed, required, etc.) bandwidth utilization, periodic sampler 66 starts unblocking sNICs 24 by traversing the throttled sNIC list 74 in the reverse order. In some embodiments, low frequency periodic sampler 66 unblocks only a subset of throttled sNICs to avoid overload on communication system 10. Periodic sampler 66 also monitors the current starvation situation and stops the unblock operation if it detects that some (or at least one) sNICs 24 are starved. Embodiments of communication system 10 can facilitate achieving both minimum and maximum bandwidth utilization of shared storage resource 18 without any intervention from compute nodes 14 or the administrator.
Turning to
The SCSI CDB and other command parameters are encapsulated in Ethernet command packet 80. Ethernet command packet 80 uses a fake preset destination Media Access Control (MAC) address 82, source MAC address 84, and Ethertype 85 to indicate its status as a SCSI command In an example, source and destination MAC addresses 84 and 82 respectively, comprise unique MAC addresses (e.g., 0xBBBBBBBBBBBB and 0xAAAAAAAAAAAA, respectively); Ethertype 85 comprises a value of 0xFFFF. Values of source MAC address 84 and destination MAC address 82 and Ethertype 85 are programmed in packet classifier 34 to trap Ethernet command packet 80. For example, a value of 0xBBBBBBBBBBBB in source MAC address 84 and a value of 0xAAAAAAAAAAAA in destination MAC address 82 indicate that Ethernet command packet 80 encapsulates a SCSI command.
Ethernet command packet 80 can also include various other fields and corresponding values. For example, an opcode field is one byte long and indicates if the command is READ/WRITE or any other control command according to SCSI specifications. A CDB field can be 6, 10, 12 and 16 bytes based on the size of data transfer or logical block addressing (LBA) being accessed. The CDB field is followed by a data buffer consisting of write data or space where READ data is copied. Ethernet command packet 80 also carries information about a sense buffer to handle termination of the command with a check condition. A reserved field of 4 bytes, which is not updated by the host driver may also be provided to be used by the arbiter routine to record the token for that I/O operation. The host driver forms Ethernet command packet 80 and posts it on command work queue (e.g., 32). Ethernet command packet 80 is passed through packet classifier 34 on its way to data path processor 54, where it is processed and the I/O request is forwarded to shared storage controller 30.
Turning to
According to various embodiments, the I/O completions are formed by firmware executing on data path processor 54. Shared storage controller 30 notifies data path processor 54 after completion of a SCSI command. The firmware finds the associated SCSI command request and forms (e.g., generates, creates, etc.) Ethernet response packet 86 with fields as indicated in the figure. The firmware also places the token (CMD token) and sends the I/O completion notification comprising Ethernet response packet 86 on its response WQ 56. The I/O completion notification passes through packet classifier 34 and flow table 38 and is processed suitably as described herein.
Turning to
Turning to
Turning to
Turning to
State field 102 indicates if I/O operations for associated sNIC-1 are “PAUSED” or “NOT PAUSED” (e.g., operational). sNIC-1 with a state of PAUSED is to be throttled. Priority field 104 indicates one of priorities “High,” “Normal” and “Low” (note that any suitable number of priorities may be specified to indicate relative importance of associated sNIC-1 among a plurality of sNICs 24). The value of priority field 104 indicates the relative priority of associated sNIC-1 and it is used to determine whether particular sNIC-1 should be throttled in the event of over subscription. The administrator sets the value of priority field 104.
Policy type field 106 may indicate, merely as examples and not as limitations, maximum IOPS, maximum bandwidth utilization, minimum bandwidth guarantee, maximum IOPS+minimum bandwidth guarantee, and maximum bandwidth allowed+minimum bandwidth guaranteed. The policy types may be identified by label values, for example: policy type label=0x01 corresponds to maximum IOPS allowed for associated sNIC-1 (or Host-1); policy type label=0x02 corresponds to maximum bandwidth utilization allowed, specifying a maximum percentage utilization of shared storage resource 18 that can be used by associated sNIC-1 (or Host-1); policy type label=0x04 corresponds to minimum bandwidth utilization guaranteed, specifying a minimum percentage utilization of shared storage resource 18 to be reserved for associated sNIC-1 (or Host-1); policy type label=0x05 corresponds to maximum IOPs allowed and minimum bandwidth guaranteed for associated sNIC-1 (or Host-1); and policy type label=0x06 corresponds to maximum bandwidth allowed and minimum bandwidth guaranteed for associated sNIC-1 (or Host-1). Policy types 0x01 and 0x02 specify an upper ceiling for the storage utilization. whereas policy 0x06 defines a lower ceiling. For given sNIC-1 (or Host-1), the administrator can also specify a minimum value and a maximum value combination (e.g., <MIN, MAX>) to define both upper and lower limits. Policy type labels indicated herein (e.g., 0x01, 0x02, etc.) are arbitrary, and could include any suitable alphanumeric identifier within the broad scope of the embodiments.
Policy context 20 further includes a starve counter 108, denoting a count of I/O commands that had to be busied continuously due to lack of tokens. When a specific I/O command is awarded a token, starve counter field 108 is set to zero. Otherwise, every unsuccessful I/O command execution increments (e.g., by 1), the value of starve counter field 108. An outstanding tokens field 110 indicates a count of tokens consumed by associated sNIC-1 which are yet to be returned back to common token pool 46. The value of outstanding tokens field 110 indicates the number of outstanding I/O commands for sNIC-1.
A maximum threshold tokens field 112 indicates the maximum number of tokens that can be outstanding at any given time for any policy type that includes a maximum bandwidth limitation. Any I/O command resulting in the current outstanding token count to increase beyond the value of maximum outstanding tokens field 112 is throttled. A minimum threshold tokens field 114 indicates the minimum number of tokens required to sustain the guaranteed bandwidth utilization for any policy type that includes a minimum bandwidth guarantee. If current outstanding token count decreases below the value of minimum threshold tokens field 114, starve counter 108 is incremented until I/O operations of other sNICs 24 are throttled. A maximum IOPS field 116 specifies the allowed maximum IOPS for any policy type that specifies the maximum IOPS.
Turning to
During operation, packet classifier 34 filters Ethernet command packet 80 and returns key 100, including LIF ID for sNIC-1 and filter ID 1. Key 100 is used to index into flow table 38; the lookup yields command entry 40 for sNIC-1. The total command count for sNIC-1 is entered into the packet count field. The value indicates the total number of I/O operations initiated by sNIC-1. In various embodiments, each flow table entry records the number of hits in flow table 38. For example, the packet count field value for all entries in the aggregate indicates the total number of hits in flow table 38 during a specified predetermined time interval. Because the space allocated for tuples is larger than the size of the key (2 bytes) used to index, the remaining space in flow table 38 can be used to store per sNIC policy context information and to track I/O related information, such as the total bytes transferred in a successful I/O operation. In various embodiments, the total I/O bytes field is updated by appropriate microcode routines invoked as part of the I/O completion handling.
Total I/O bytes field remains empty for filter ID associated with the SCSI command IOPS field indicates the IOPS completion per second for sNIC-1; the value of the field is completed after the associated SCSI command is successfully completed. In an example embodiment, the I/O completions per second are monitored by a thread executing on control processor 50. It measures the IOPS by taking into account the number of successful completions per second from flow table entry 60 corresponding to the same LIF ID (sNIC-1) and filter ID=2. sNIC policy context field indicates the policy type for sNIC-1 (e.g., storage access parameters and the context required to maintain active state). The rewrite rules field identifies the specific arbiter routine to be used for sNIC-1 for the specific filter ID 1. The value of the rewrite rules field provides an address or ID of the rewrite rule to be invoked as a result of the flow table hit. A steering action field provides an RQ number associated with a particular data processor (e.g., 54) where the associated SCSI command is processed.
Similarly, in the response data path, Ethernet response packet 86 for sNIC-1 returns key 100, including LIF ID for sNIC-1 and filter ID 2 at packet classifier 34. Key 100 is used to index into flow table 38; the lookup yields command entry 60 for sNIC-1. The total response count for sNIC-1 is entered into the packet count field. The value indicates the total number of I/O operations successfully completed by sNIC-1. The total bytes transferred in the successful I/O operation is entered in the total I/O bytes field. In some embodiments, the value of the field indicates the cumulative bytes transferred for associated sNIC-1. The sNIC policy context field is populated by an address pointing to the QoS policy context area for associated sNIC-1. The policy context is maintained in flow table entry 40 associated with sNIC-1 and filter ID=1. Rewrite rule field is populated (by firmware executing on control processor 50) with the address or ID of the rewrite rule to be invoked as a result of the flow table hit. The steering action field is populated (by firmware executing on control processor 50) with the host RQ to which the packet is forwarded.
Likewise, in the BUSY response path, Ethernet BUSY packet 92 for sNIC-1 returns key 100, including LIF ID for sNIC-1 and filter ID 3 at packet classifier 34. Key 100 is used to index into flow table 38; the lookup yields command entry 61 for sNIC-1. The total number of commands responded with BUSY status is entered in the packet count field. The total I/O bytes field and the IOPS field remain empty. The rewrite rule field provides a decap rewrite rule to be invoked to strip off the Ethernet header of Ethernet BUSY packet 92. The value of the steering action field indicates the host RQ of sNIC-1 to which the packet is forwarded.
Turning to
At 128, key 100 is used to index into flow table 38, according to the action step mandated in packet classifier 34. At 130, the flow table match returns a steering action and arbiter routine (e.g., rewrite rule) to be invoked on Ethernet command packet 80 comprising the SCSI command. The flow table hit counter (e.g., packet count field) associated with the lookup entry is also incremented at 132. At 134, appropriate arbiter routine fetches per sNIC policy context 48 for corresponding sNIC-1 (or Host-1). In an example embodiment, the policy context is stored in a flow table memory region to ensure its presence in an L2 cache.
At 136, arbiter routine determines whether the policy context permits a token fetch. For example, policy context 20 for sNIC-1 is read. If the value of state field 102 is PAUSED, indicating that the I/O operation is throttled, no token is awarded. If policy type field 106 has a value of 0x01 or 0x05 (or otherwise indicates maximum IOPS count), the arbiter routine checks the current IOPS count, and if it is higher than the value in maximum IOPs field 116, no token is awarded. If the policy type field 106 has a value of 0x02 or 0x06 (or otherwise indicates maximum bandwidth), the arbiter routine checks the current outstanding token count, and if it is greater than the value of maximum threshold tokens field 112, the I/O operations is throttled and no token is awarded. If a token fetch is permitted, at 138, the outstanding token count is incremented. At 140, packet processor 42 attempts a token fetch from common token pool 46. At 142, a determination may be made whether a token is available in common token pool 46. If a token is available, at 144, the SCSI command is marked with the token. At 146, the Ethernet header is stripped from Ethernet command packet 80. At 148, the SCSI command is placed in command RQ 52 for further processing by data processor 54.
Turning back to 142, if no token is available in common token pool 46, at 150, a determination is made whether policy context 20 specifies a minimum bandwidth policy type. For example, policy types 0x04 and 0x06 specify a minimum guaranteed bandwidth. If so, at 152, the value of starve counter field 108 is incremented and the command packet is marked to indicate the unavailability of the token at 156. On the other hand, if the token is awarded, the value of starve counter field 108 is reset to zero. At 150, if the policy type does not specify any minimum bandwidth, the operations step to 156, at which the command packet is marked to indicate the unavailability of the token. The operations step to 148, with the SCSI command being placed in command RQ 52 for further processing by data processor 54. Turning back to 136, if policy context 20 does not permit a token fetch, the operations step to 156, at which the command packet is marked to indicate the unavailability of the token, and continue thereafter. In any case, the command arrives at data path processor 54 either with an assigned token or indication that the command cannot be processed and is to be busied. Data processor 54 uses a command index specified in the token to issue an I/O command to shared storage controller 30, or takes other steps as appropriate.
Turning to
Turning to 168, if the policy type indicates maximum bandwidth at 180, at 182, the current outstanding token count is checked by the arbiter routine in packet processor 42. if it is greater than the value of maximum threshold tokens field 112, the I/O operations is throttled and no token is awarded at 178. If it is not greater than the value of maximum threshold tokens field 112, the token fetch may be permitted at 176. Turning back to 166, if the context state is PAUSED, indicating the I/O operation is throttled, the operations step to 178, at which the token fetch is denied.
Turning to
At 206, the hit counter indicating number of I/O operations completed per second is incremented. At 208, the arbiter routine releases the token back to common token pool 46. At 210, the arbiter routine decrements the outstanding token count in a QoS context table. At 212, the arbiter routine strips the Ethernet header from Ethernet response packet 86, and forwards the response to the designated RQ. At 214, the response packet arrives at the host RQ and interrupts the host driver that initiated the SCSI I/O operation.
Turning to
Turning to
In various embodiments, operations 240 may be performed in a single sweep (e.g., execution, run, etc.) of periodic sampler 66. In other embodiments, operations 240 may be performed piecemeal, for example, within a predetermined time interval, or until starving sNIC list 72 reaches a particular size. Various other options that determine a frequency of execution of periodic sampler 66 may be used within the broad scope of the embodiments.
In some embodiments, low frequency periodic sampler 66 detects during its execution that some of sNICs 24 are being throttled and monitors the condition of sNICs 24 that have minimum bandwidth requirement. If all sNICs 24 are able to perform I/O operations at guaranteed bandwidth, periodic sampler 66 unblocks sNICs 24 from throttled sNIC list 74 in the reverse order in which sNICs 24 were initially added to throttled sNIC list 74. In some embodiments, in every invocation of low frequency periodic sampler 66, a predetermined subset of throttled sNICs 24 are unblocked, for example, to avoid overload on the system. While unblocking, periodic sampler 66 monitors the situation and stops the unblock operation if at least one starved sNIC 24 is detected.
Turning to
For each sNIC on sNIC list 70, throttler 68 performs the following operations. At 266, throttler 68 makes a determination whether the sNIC has any specific policy context 20 associated therewith. If the sNIC has a specific policy context 20 associated therewith, at 268, throttler 68 checks the value of priority field 104 in policy context 20. At 270, throttler 68 makes a determination whether the value of priority field 104 is “low”. If the value of priority field 104 is not “low” (e.g., low priority sNICs are selected before “normal” priority sNICs), at 272, throttler 68 checks the value of policy type field 106 in policy context 20. At 274, throttler 68 makes a determination whether the value of policy type field 106 indicates a Max IOPS (e.g., 0x01) or Max Bandwidth utilization (e.g., 0x02) policy. If not, at 276, throttler 68 checks any bandwidth requirement in policy context 20. At 278, throttler 68 makes a determination whether the bandwidth requirement is low (e.g., relatively lower than other sNICs) and the sNIC is not experiencing any violation of its per sNIC policy context 48. If not, the operations revert to 264, and the next sNIC in sNIC list 70 is reviewed. If bandwidth requirement is low, at 280, the sNIC is added to throttled sNIC list 74.
Turning back to 266, if no policy context 20 is associated with the sNIC, the sNIC is added to throttled sNIC list 74. Turning back to 270, if the value of priority field 104 is “low”, the sNIC is added to throttled sNIC list 74. Turning back to 274, if the value of policy type field 106 indicates a Max IOPS (e.g., 0x01) or Max Bandwidth utilization (e.g., 0x02) policy, the sNIC is added to throttled sNIC list 74.
At 282, the context state of sNICs in throttled sNIC list 74 is set to PAUSED. Setting the context state to PAUSED throttles any I/O operation associated with the sNIC. At 284, throttler 68 waits for a predetermined time interval (e.g., 100 ms). At 286, throttler 68 checks the state of starving sNIC list 72. At 290, throttler 68 makes a determination whether a size of starving sNIC list 72 has decreased (e.g., indicating fewer number of starving sNICs) and the situation has improved. If starving sNIC list 72 has not decreased in size, the operations revert to 264, and additional sNICs are selected to be throttled. If the situation has improved (e.g., previously starved sNICs are able to perform I/O operations at desired bandwidth utilization) throttler 68 is terminated at 292. In some embodiments, before terminating, throttler 68 also updates QoS monitor 64 to indicate completion of the throttling task.
Note that in this Specification, references to various features (e.g., elements, structures, modules, components, steps, operations, characteristics, etc.) included in “one embodiment”, “example embodiment”, “an embodiment”, “another embodiment”, “some embodiments”, “various embodiments”, “other embodiments”, “alternative embodiment”, and the like are intended to mean that any such features are included in one or more embodiments of the present disclosure, but may or may not necessarily be combined in the same embodiments. Furthermore, the words “optimize,” “optimization,” and related terms are terms of art that refer to improvements in speed and/or efficiency of a specified outcome and do not purport to indicate that a process for achieving the specified outcome has achieved, or is capable of achieving, an “optimal” or perfectly speedy/perfectly efficient state.
In example implementations, at least some portions of the activities outlined herein may be implemented in software. In some embodiments, one or more of these features may be implemented in hardware, provided external to these elements, or consolidated in any appropriate manner to achieve the intended functionality. The various components may include software (or reciprocating software) that can coordinate in order to achieve the operations as outlined herein. In still other embodiments, these elements may include any suitable algorithms, hardware, software, components, modules, interfaces, or objects that facilitate the operations thereof.
Furthermore, the VNFs and associated servers described and shown herein (and/or their associated structures) may also include suitable interfaces for receiving, transmitting, and/or otherwise communicating data or information in a network environment. The VNFs described herein may be provisioned on servers comprising memory elements and processors. Additionally, some of the processors and memory elements associated with the various nodes may be removed, or otherwise consolidated such that a single processor and a single memory element are responsible for certain activities. In a general sense, the arrangements depicted in the FIGURES may be more logical in their representations, whereas a physical architecture may include various permutations, combinations, and/or hybrids of these elements. It is imperative to note that countless possible design configurations can be used to achieve the operational objectives outlined here. Accordingly, the associated infrastructure has a myriad of substitute arrangements, design choices, device possibilities, hardware configurations, software implementations, equipment options, etc.
In some of example embodiments, one or more memory elements (e.g., storage resource 18, packet classifier 34, flow table 38) can store data used for the operations described herein. This includes the memory element being able to store instructions (e.g., software, logic, code, etc.) in non-transitory media, such that the instructions are executed to carry out the activities described in this Specification. A processor (e.g., control processor 50, packet processor 42, data path processor 54) can execute any type of instructions associated with the data to achieve the operations detailed herein in this Specification. In one example, processors could transform an element or an article (e.g., data) from one state or thing to another state or thing. In another example, the activities outlined herein may be implemented with fixed logic or programmable logic (e.g., software/computer instructions executed by a processor) and the elements identified herein could be some type of a programmable processor, programmable digital logic (e.g., a field programmable gate array (FPGA), an erasable programmable read only memory (EPROM), an electrically erasable programmable read only memory (EEPROM)), an ASIC that includes digital logic, software, code, electronic instructions, flash memory, optical disks, CD-ROMs, DVD ROMs, magnetic or optical cards, other types of machine-readable mediums suitable for storing electronic instructions, or any suitable combination thereof.
These devices may further keep information in any suitable type of non-transitory storage medium (e.g., random access memory (RAM), read only memory (ROM), field programmable gate array (FPGA), erasable programmable read only memory (EPROM), electrically erasable programmable ROM (EEPROM), etc.), software, hardware, or in any other suitable component, device, element, or object where appropriate and based on particular needs. The information being tracked, sent, received, or stored in the communication system could be provided in any database, register, table, cache, queue, control list, or storage structure, based on particular needs and implementations, all of which could be referenced in any suitable timeframe. Any of the memory items discussed herein should be construed as being encompassed within the broad term ‘memory element.’ Similarly, any of the potential processing elements, modules, and machines described in this Specification should be construed as being encompassed within the broad term ‘processor.’
In various embodiments, the operations described herein facilitate improvements in storage traffic optimization technologies, allowing compute nodes 14 to operate faster, or more efficiently according to administrator specified policies at a central management application in the network. The operations described herein solve problems uniquely associated with a multi-host computing environment, in which multiple compute nodes 14 access shared storage resource 18 through a shared transmission medium (e.g., PCIe bus). Such problems did not exist before computers or computer networks, or before multiple computing devices were aggregated together for shared efficiencies.
It is also important to note that the operations and steps described with reference to the preceding FIGURES illustrate only some of the possible scenarios that may be executed by, or within, the system. Some of these operations may be deleted or removed where appropriate, or these steps may be modified or changed considerably without departing from the scope of the discussed concepts. In addition, the timing of these operations may be altered considerably and still achieve the results taught in this disclosure. The preceding operational flows have been offered for purposes of example and discussion. Substantial flexibility is provided by the system in that any suitable arrangements, chronologies, configurations, and timing mechanisms may be provided without departing from the teachings of the discussed concepts.
Although the present disclosure has been described in detail with reference to particular arrangements and configurations, these example configurations and arrangements may be changed significantly without departing from the scope of the present disclosure. For example, although the present disclosure has been described with reference to particular communication exchanges involving certain network access and protocols, the communication system may be applicable to other exchanges or routing protocols. Moreover, although the communication system has been illustrated with reference to particular elements and operations that facilitate the communication process, these elements, and operations may be replaced by any suitable architecture or process that achieves the intended functionality of the communication system.
Numerous other changes, substitutions, variations, alterations, and modifications may be ascertained to one skilled in the art and it is intended that the present disclosure encompass all such changes, substitutions, variations, alterations, and modifications as falling within the scope of the appended claims. In order to assist the United States Patent and Trademark Office (USPTO) and, additionally, any readers of any patent issued on this application in interpreting the claims appended hereto, Applicant wishes to note that the Applicant: (a) does not intend any of the appended claims to invoke paragraph six (6) of 35 U.S.C. section 112 as it exists on the date of the filing hereof unless the words “means for” or “step for” are specifically used in the particular claims; and (b) does not intend, by any statement in the specification, to limit this disclosure in any way that is not otherwise reflected in the appended claims.
The instant application is a continuation of, and claims priority to, U.S. patent application Ser. No. 14/965,750 filed on Dec. 10, 2015 entitled POLICY-DRIVEN STORAGE IN A MICROSERVER COMPUTING ENVIRONMENT, the contents of which are expressly incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4688695 | Hirohata | Aug 1987 | A |
5263003 | Cowles et al. | Nov 1993 | A |
5339445 | Gasztonyi | Aug 1994 | A |
5430859 | Norman et al. | Jul 1995 | A |
5457746 | Dolphin | Oct 1995 | A |
5535336 | Smith | Jul 1996 | A |
5588012 | Oizumi | Dec 1996 | A |
5617421 | Chin et al. | Apr 1997 | A |
5680579 | Young et al. | Oct 1997 | A |
5690194 | Parker et al. | Nov 1997 | A |
5740171 | Mazzola et al. | Apr 1998 | A |
5742604 | Edsall et al. | Apr 1998 | A |
5764636 | Edsall | Jun 1998 | A |
5809285 | Hilland | Sep 1998 | A |
5812814 | Sukegawa | Sep 1998 | A |
5812950 | Tom | Sep 1998 | A |
5838970 | Thomas | Nov 1998 | A |
5999930 | Wolff | Dec 1999 | A |
6035105 | McCloghrie et al. | Mar 2000 | A |
6043777 | Bergman et al. | Mar 2000 | A |
6101497 | Ofek | Aug 2000 | A |
6148414 | Brown et al. | Nov 2000 | A |
6185203 | Berman | Feb 2001 | B1 |
6188694 | Fine et al. | Feb 2001 | B1 |
6202135 | Kedem et al. | Mar 2001 | B1 |
6208649 | Kloth | Mar 2001 | B1 |
6209059 | Ofer et al. | Mar 2001 | B1 |
6219699 | McCloghrie et al. | Apr 2001 | B1 |
6219753 | Richardson | Apr 2001 | B1 |
6223250 | Yokono | Apr 2001 | B1 |
6226771 | Hilla et al. | May 2001 | B1 |
6260120 | Blumenau et al. | Jul 2001 | B1 |
6266705 | Ullum et al. | Jul 2001 | B1 |
6269381 | St. Pierre et al. | Jul 2001 | B1 |
6269431 | Dunham | Jul 2001 | B1 |
6295575 | Blumenau et al. | Sep 2001 | B1 |
6400730 | Latif et al. | Jun 2002 | B1 |
6408406 | Parris | Jun 2002 | B1 |
6542909 | Tamer et al. | Apr 2003 | B1 |
6542961 | Matsunami et al. | Apr 2003 | B1 |
6553390 | Gross et al. | Apr 2003 | B1 |
6564252 | Hickman et al. | May 2003 | B1 |
6647474 | Yanai et al. | Nov 2003 | B2 |
6675258 | Bramhall et al. | Jan 2004 | B1 |
6683883 | Czeiger et al. | Jan 2004 | B1 |
6694413 | Mimatsu et al. | Feb 2004 | B1 |
6708227 | Cabrera et al. | Mar 2004 | B1 |
6715007 | Williams et al. | Mar 2004 | B1 |
6728791 | Young | Apr 2004 | B1 |
6772231 | Reuter et al. | Aug 2004 | B2 |
6820099 | Huber et al. | Nov 2004 | B1 |
6847647 | Wrenn | Jan 2005 | B1 |
6848759 | Doornbos et al. | Feb 2005 | B2 |
6850955 | Sonoda et al. | Feb 2005 | B2 |
6876656 | Brewer et al. | Apr 2005 | B2 |
6880062 | Ibrahim et al. | Apr 2005 | B1 |
6898670 | Nahum | May 2005 | B2 |
6907419 | Pesola et al. | Jun 2005 | B1 |
6912668 | Brown et al. | Jun 2005 | B1 |
6952734 | Gunlock et al. | Oct 2005 | B1 |
6976090 | Ben-Shaul et al. | Dec 2005 | B2 |
6978300 | Beukema et al. | Dec 2005 | B1 |
6983303 | Pellegrino et al. | Jan 2006 | B2 |
6986015 | Testardi | Jan 2006 | B2 |
6986069 | Oehler et al. | Jan 2006 | B2 |
7051056 | Rodriguez-Rivera et al. | May 2006 | B2 |
7069465 | Chu et al. | Jun 2006 | B2 |
7073017 | Yamamoto | Jul 2006 | B2 |
7108339 | Berger | Sep 2006 | B2 |
7149858 | Kiselev | Dec 2006 | B1 |
7171514 | Coronado et al. | Jan 2007 | B2 |
7171668 | Molloy et al. | Jan 2007 | B2 |
7174354 | Andreasson | Feb 2007 | B2 |
7200144 | Terrell et al. | Apr 2007 | B2 |
7222255 | Claessens et al. | May 2007 | B1 |
7237045 | Beckmann et al. | Jun 2007 | B2 |
7240188 | Takata et al. | Jul 2007 | B2 |
7246260 | Brown et al. | Jul 2007 | B2 |
7266718 | Idei et al. | Sep 2007 | B2 |
7269168 | Roy et al. | Sep 2007 | B2 |
7277431 | Walter et al. | Oct 2007 | B2 |
7277948 | Igarashi et al. | Oct 2007 | B2 |
7305658 | Hamilton et al. | Dec 2007 | B1 |
7328434 | Swanson et al. | Feb 2008 | B2 |
7340555 | Ashmore et al. | Mar 2008 | B2 |
7346751 | Prahlad et al. | Mar 2008 | B2 |
7352706 | Klotz et al. | Apr 2008 | B2 |
7353305 | Pangal et al. | Apr 2008 | B2 |
7359321 | Sindhu et al. | Apr 2008 | B1 |
7383381 | Faulkner et al. | Jun 2008 | B1 |
7403987 | Marinelli et al. | Jul 2008 | B1 |
7433326 | Desai et al. | Oct 2008 | B2 |
7433948 | Edsall | Oct 2008 | B2 |
7434105 | Rodriguez-Rivera et al. | Oct 2008 | B1 |
7441154 | Klotz et al. | Oct 2008 | B2 |
7447839 | Uppala | Nov 2008 | B2 |
7487321 | Muthiah et al. | Feb 2009 | B2 |
7500053 | Kavuri et al. | Mar 2009 | B1 |
7512744 | Banga et al. | Mar 2009 | B2 |
7519004 | Kamity | Apr 2009 | B1 |
7542681 | Cornell et al. | Jun 2009 | B2 |
7558872 | Senevirathne et al. | Jul 2009 | B1 |
7587570 | Sarkar et al. | Sep 2009 | B2 |
7631023 | Kaiser et al. | Dec 2009 | B1 |
7643505 | Colloff | Jan 2010 | B1 |
7654625 | Amann et al. | Feb 2010 | B2 |
7657796 | Kaiser et al. | Feb 2010 | B1 |
7668981 | Nagineni et al. | Feb 2010 | B1 |
7669071 | Cochran et al. | Feb 2010 | B2 |
7689384 | Becker | Mar 2010 | B1 |
7694092 | Mizuno | Apr 2010 | B2 |
7697554 | Ofer et al. | Apr 2010 | B1 |
7706303 | Bose et al. | Apr 2010 | B2 |
7707481 | Kirschner et al. | Apr 2010 | B2 |
7716648 | Vaidyanathan et al. | May 2010 | B2 |
7752360 | Galles | Jul 2010 | B2 |
7757059 | Ofer et al. | Jul 2010 | B1 |
7774329 | Peddy et al. | Aug 2010 | B1 |
7774839 | Nazzal | Aug 2010 | B2 |
7793138 | Rastogi et al. | Sep 2010 | B2 |
7840730 | D'Amato | Nov 2010 | B2 |
7843906 | Chidambaram et al. | Nov 2010 | B1 |
7895428 | Boland, IV et al. | Feb 2011 | B2 |
7904599 | Bennett | Mar 2011 | B1 |
7930494 | Goheer et al. | Apr 2011 | B1 |
7975175 | Votta et al. | Jul 2011 | B2 |
7979670 | Saliba et al. | Jul 2011 | B2 |
7984259 | English | Jul 2011 | B1 |
8031703 | Gottumukkula et al. | Oct 2011 | B2 |
8032621 | Upalekar et al. | Oct 2011 | B1 |
8051197 | Mullendore et al. | Nov 2011 | B2 |
8086755 | Duffy, IV et al. | Dec 2011 | B2 |
8161134 | Mishra et al. | Apr 2012 | B2 |
8196018 | Forhan et al. | Jun 2012 | B2 |
8205951 | Boks | Jun 2012 | B2 |
8218538 | Chidambaram et al. | Jul 2012 | B1 |
8230066 | Heil | Jul 2012 | B2 |
8234377 | Cohn | Jul 2012 | B2 |
8266238 | Zimmer et al. | Sep 2012 | B2 |
8272104 | Chen et al. | Sep 2012 | B2 |
8274993 | Sharma et al. | Sep 2012 | B2 |
8290919 | Kelly et al. | Oct 2012 | B1 |
8297722 | Chambers et al. | Oct 2012 | B2 |
8301746 | Head et al. | Oct 2012 | B2 |
8335231 | Kloth et al. | Dec 2012 | B2 |
8341121 | Claudatos et al. | Dec 2012 | B1 |
8345692 | Smith | Jan 2013 | B2 |
8352941 | Protopopov et al. | Jan 2013 | B1 |
8392760 | Kandula et al. | Mar 2013 | B2 |
8442059 | de la Iglesia et al. | May 2013 | B1 |
8479211 | Marshall et al. | Jul 2013 | B1 |
8495356 | Ashok et al. | Jul 2013 | B2 |
8514868 | Hill | Aug 2013 | B2 |
8532108 | Li et al. | Sep 2013 | B2 |
8560663 | Baucke et al. | Oct 2013 | B2 |
8619599 | Even | Dec 2013 | B1 |
8626891 | Guru et al. | Jan 2014 | B2 |
8630983 | Sengupta et al. | Jan 2014 | B2 |
8660129 | Brendel et al. | Feb 2014 | B1 |
8661299 | Ip | Feb 2014 | B1 |
8677485 | Sharma et al. | Mar 2014 | B2 |
8683296 | Anderson et al. | Mar 2014 | B2 |
8706772 | Hartig et al. | Apr 2014 | B2 |
8719804 | Jain | May 2014 | B2 |
8725854 | Edsall | May 2014 | B2 |
8768981 | Milne et al. | Jul 2014 | B1 |
8775773 | Acharya et al. | Jul 2014 | B2 |
8793372 | Ashok et al. | Jul 2014 | B2 |
8805918 | Chandrasekaran et al. | Aug 2014 | B1 |
8805951 | Faibish et al. | Aug 2014 | B1 |
8832330 | Lancaster | Sep 2014 | B1 |
8855116 | Rosset et al. | Oct 2014 | B2 |
8856339 | Mestery et al. | Oct 2014 | B2 |
8868474 | Leung et al. | Oct 2014 | B2 |
8887286 | Dupont et al. | Nov 2014 | B2 |
8898385 | Jayaraman et al. | Nov 2014 | B2 |
8909928 | Ahmad et al. | Dec 2014 | B2 |
8918510 | Gmach et al. | Dec 2014 | B2 |
8918586 | Todd et al. | Dec 2014 | B1 |
8924720 | Raghuram et al. | Dec 2014 | B2 |
8930747 | Levijarvi et al. | Jan 2015 | B2 |
8935500 | Gulati et al. | Jan 2015 | B1 |
8949677 | Brundage et al. | Feb 2015 | B1 |
8996837 | Bono et al. | Mar 2015 | B1 |
9003086 | Schuller et al. | Apr 2015 | B1 |
9007922 | Mittal et al. | Apr 2015 | B1 |
9009427 | Sharma et al. | Apr 2015 | B2 |
9009704 | McGrath et al. | Apr 2015 | B2 |
9075638 | Barnett et al. | Jul 2015 | B2 |
9141554 | Candelaria | Sep 2015 | B1 |
9141785 | Mukkara et al. | Sep 2015 | B2 |
9164795 | Vincent | Oct 2015 | B1 |
9176677 | Fradkin et al. | Nov 2015 | B1 |
9201704 | Chang et al. | Dec 2015 | B2 |
9203784 | Chang et al. | Dec 2015 | B2 |
9207882 | Rosset et al. | Dec 2015 | B2 |
9207929 | Katsura | Dec 2015 | B2 |
9213612 | Candelaria | Dec 2015 | B2 |
9223564 | Munireddy et al. | Dec 2015 | B2 |
9223634 | Chang et al. | Dec 2015 | B2 |
9244761 | Yekhanin et al. | Jan 2016 | B2 |
9250969 | Lagar-Cavilla et al. | Feb 2016 | B2 |
9264494 | Factor et al. | Feb 2016 | B2 |
9270754 | Iyengar et al. | Feb 2016 | B2 |
9280487 | Candelaria | Mar 2016 | B2 |
9304815 | Vasanth et al. | Apr 2016 | B1 |
9313048 | Chang et al. | Apr 2016 | B2 |
9374270 | Nakil et al. | Jun 2016 | B2 |
9378060 | Jansson et al. | Jun 2016 | B2 |
9396251 | Boudreau et al. | Jul 2016 | B1 |
9448877 | Candelaria | Sep 2016 | B2 |
9471348 | Zuo | Oct 2016 | B2 |
9501473 | Kong et al. | Nov 2016 | B1 |
9503523 | Rosset et al. | Nov 2016 | B2 |
9565110 | Mullendore et al. | Feb 2017 | B2 |
9575828 | Agarwal et al. | Feb 2017 | B2 |
9582377 | Dhoolam et al. | Feb 2017 | B1 |
9614763 | Dong et al. | Apr 2017 | B2 |
9658868 | Hill | May 2017 | B2 |
9658876 | Chang et al. | May 2017 | B2 |
9733868 | Chandrasekaran et al. | Aug 2017 | B2 |
9763518 | Charest et al. | Sep 2017 | B2 |
9830240 | George et al. | Nov 2017 | B2 |
9853873 | Dasu et al. | Dec 2017 | B2 |
20020049980 | Hoang | Apr 2002 | A1 |
20020053009 | Selkirk et al. | May 2002 | A1 |
20020073276 | Howard et al. | Jun 2002 | A1 |
20020083120 | Soltis | Jun 2002 | A1 |
20020095547 | Watanabe et al. | Jul 2002 | A1 |
20020103889 | Markson et al. | Aug 2002 | A1 |
20020103943 | Lo et al. | Aug 2002 | A1 |
20020112113 | Karpoff et al. | Aug 2002 | A1 |
20020120741 | Webb et al. | Aug 2002 | A1 |
20020138675 | Mann | Sep 2002 | A1 |
20020156971 | Jones et al. | Oct 2002 | A1 |
20030023885 | Potter et al. | Jan 2003 | A1 |
20030026267 | Oberman et al. | Feb 2003 | A1 |
20030055933 | Ishizaki et al. | Mar 2003 | A1 |
20030056126 | O'Connor et al. | Mar 2003 | A1 |
20030065986 | Fraenkel et al. | Apr 2003 | A1 |
20030084359 | Bresniker et al. | May 2003 | A1 |
20030118053 | Edsall et al. | Jun 2003 | A1 |
20030131105 | Czeiger et al. | Jul 2003 | A1 |
20030131165 | Asano et al. | Jul 2003 | A1 |
20030131182 | Kumar et al. | Jul 2003 | A1 |
20030140134 | Swanson et al. | Jul 2003 | A1 |
20030140210 | Testardi | Jul 2003 | A1 |
20030149763 | Heitman et al. | Aug 2003 | A1 |
20030154271 | Baldwin et al. | Aug 2003 | A1 |
20030159058 | Eguchi et al. | Aug 2003 | A1 |
20030174725 | Shankar | Sep 2003 | A1 |
20030189395 | Doornbos et al. | Oct 2003 | A1 |
20030210686 | Terrell et al. | Nov 2003 | A1 |
20040024961 | Cochran et al. | Feb 2004 | A1 |
20040030857 | Krakirian et al. | Feb 2004 | A1 |
20040039939 | Cox et al. | Feb 2004 | A1 |
20040054776 | Klotz et al. | Mar 2004 | A1 |
20040057389 | Klotz et al. | Mar 2004 | A1 |
20040059807 | Klotz et al. | Mar 2004 | A1 |
20040088574 | Walter et al. | May 2004 | A1 |
20040117438 | Considine et al. | Jun 2004 | A1 |
20040123029 | Dalal et al. | Jun 2004 | A1 |
20040128470 | Hetzler et al. | Jul 2004 | A1 |
20040128540 | Roskind | Jul 2004 | A1 |
20040153863 | Klotz et al. | Aug 2004 | A1 |
20040190901 | Fang | Sep 2004 | A1 |
20040215749 | Tsao | Oct 2004 | A1 |
20040230848 | Mayo et al. | Nov 2004 | A1 |
20040250034 | Yagawa et al. | Dec 2004 | A1 |
20050033936 | Nakano et al. | Feb 2005 | A1 |
20050036499 | Dutt et al. | Feb 2005 | A1 |
20050050211 | Kaul et al. | Mar 2005 | A1 |
20050050270 | Horn et al. | Mar 2005 | A1 |
20050053073 | Kloth et al. | Mar 2005 | A1 |
20050055428 | Terai et al. | Mar 2005 | A1 |
20050060574 | Klotz et al. | Mar 2005 | A1 |
20050060598 | Klotz et al. | Mar 2005 | A1 |
20050071851 | Opheim | Mar 2005 | A1 |
20050076113 | Klotz et al. | Apr 2005 | A1 |
20050083958 | Drori | Apr 2005 | A1 |
20050091426 | Horn et al. | Apr 2005 | A1 |
20050114611 | Durham et al. | May 2005 | A1 |
20050114615 | Ogasawara et al. | May 2005 | A1 |
20050117522 | Basavaiah et al. | Jun 2005 | A1 |
20050117562 | Wrenn | Jun 2005 | A1 |
20050138287 | Ogasawara et al. | Jun 2005 | A1 |
20050169188 | Cometto et al. | Aug 2005 | A1 |
20050185597 | Le et al. | Aug 2005 | A1 |
20050188170 | Yamamoto | Aug 2005 | A1 |
20050198523 | Shanbhag et al. | Sep 2005 | A1 |
20050235072 | Smith | Oct 2005 | A1 |
20050283658 | Clark et al. | Dec 2005 | A1 |
20060015861 | Takata et al. | Jan 2006 | A1 |
20060015928 | Setty et al. | Jan 2006 | A1 |
20060034302 | Peterson | Feb 2006 | A1 |
20060045021 | Deragon et al. | Mar 2006 | A1 |
20060075191 | Lolayekar et al. | Apr 2006 | A1 |
20060098672 | Schzukin et al. | May 2006 | A1 |
20060117099 | Mogul | Jun 2006 | A1 |
20060136684 | Le et al. | Jun 2006 | A1 |
20060184287 | Belady et al. | Aug 2006 | A1 |
20060198319 | Schondelmayer et al. | Sep 2006 | A1 |
20060215297 | Kikuchi | Sep 2006 | A1 |
20060221974 | Hilla | Oct 2006 | A1 |
20060230227 | Ogasawara et al. | Oct 2006 | A1 |
20060242332 | Johnsen et al. | Oct 2006 | A1 |
20060251111 | Kloth et al. | Nov 2006 | A1 |
20070005297 | Beresniewicz et al. | Jan 2007 | A1 |
20070067593 | Satoyama et al. | Mar 2007 | A1 |
20070079068 | Draggon | Apr 2007 | A1 |
20070091903 | Atkinson | Apr 2007 | A1 |
20070094465 | Sharma et al. | Apr 2007 | A1 |
20070101202 | Garbow | May 2007 | A1 |
20070121519 | Cuni et al. | May 2007 | A1 |
20070136541 | Herz et al. | Jun 2007 | A1 |
20070162969 | Becker | Jul 2007 | A1 |
20070211640 | Palacharla et al. | Sep 2007 | A1 |
20070214316 | Kim | Sep 2007 | A1 |
20070250838 | Belady et al. | Oct 2007 | A1 |
20070258380 | Chamdani et al. | Nov 2007 | A1 |
20070263545 | Foster et al. | Nov 2007 | A1 |
20070276884 | Hara et al. | Nov 2007 | A1 |
20070283059 | Ho et al. | Dec 2007 | A1 |
20080016412 | White et al. | Jan 2008 | A1 |
20080034149 | Sheen | Feb 2008 | A1 |
20080052459 | Chang et al. | Feb 2008 | A1 |
20080059698 | Kabir et al. | Mar 2008 | A1 |
20080114933 | Ogasawara et al. | May 2008 | A1 |
20080126509 | Subrannanian et al. | May 2008 | A1 |
20080126734 | Murase | May 2008 | A1 |
20080168304 | Flynn et al. | Jul 2008 | A1 |
20080201616 | Ashmore | Aug 2008 | A1 |
20080244184 | Lewis et al. | Oct 2008 | A1 |
20080256082 | Davies et al. | Oct 2008 | A1 |
20080267217 | Colville et al. | Oct 2008 | A1 |
20080288661 | Galles | Nov 2008 | A1 |
20080294888 | Ando et al. | Nov 2008 | A1 |
20090063766 | Matsumura et al. | Mar 2009 | A1 |
20090083484 | Basham et al. | Mar 2009 | A1 |
20090089567 | Boland, IV et al. | Apr 2009 | A1 |
20090094380 | Qiu et al. | Apr 2009 | A1 |
20090094664 | Butler et al. | Apr 2009 | A1 |
20090125694 | Innan et al. | May 2009 | A1 |
20090193223 | Saliba et al. | Jul 2009 | A1 |
20090201926 | Kagan et al. | Aug 2009 | A1 |
20090222733 | Basham et al. | Sep 2009 | A1 |
20090240873 | Yu et al. | Sep 2009 | A1 |
20090282471 | Green et al. | Nov 2009 | A1 |
20090300209 | Elzur | Dec 2009 | A1 |
20090323706 | Germain et al. | Dec 2009 | A1 |
20100011365 | Gerovac et al. | Jan 2010 | A1 |
20100030995 | Wang et al. | Feb 2010 | A1 |
20100046378 | Knapp et al. | Feb 2010 | A1 |
20100083055 | Ozonat | Apr 2010 | A1 |
20100174968 | Charles et al. | Jul 2010 | A1 |
20100318609 | Lahiri et al. | Dec 2010 | A1 |
20100318837 | Murphy et al. | Dec 2010 | A1 |
20110010394 | Carew et al. | Jan 2011 | A1 |
20110022691 | Banerjee et al. | Jan 2011 | A1 |
20110029824 | Schöler et al. | Feb 2011 | A1 |
20110035494 | Pandey et al. | Feb 2011 | A1 |
20110075667 | Li et al. | Mar 2011 | A1 |
20110087848 | Trent | Apr 2011 | A1 |
20110119556 | de Buen | May 2011 | A1 |
20110142053 | Van Der Merwe et al. | Jun 2011 | A1 |
20110161496 | Nicklin | Jun 2011 | A1 |
20110173303 | Rider | Jul 2011 | A1 |
20110228679 | Varma et al. | Sep 2011 | A1 |
20110231899 | Pulier et al. | Sep 2011 | A1 |
20110239039 | Dieffenbach et al. | Sep 2011 | A1 |
20110252274 | Kawaguchi et al. | Oct 2011 | A1 |
20110255540 | Mizrahi et al. | Oct 2011 | A1 |
20110276584 | Cotner et al. | Nov 2011 | A1 |
20110276675 | Singh et al. | Nov 2011 | A1 |
20110276951 | Jain | Nov 2011 | A1 |
20110299539 | Rajagopal et al. | Dec 2011 | A1 |
20110307450 | Hahn et al. | Dec 2011 | A1 |
20110313973 | Srivas et al. | Dec 2011 | A1 |
20120011255 | Kusama | Jan 2012 | A1 |
20120023319 | Chin et al. | Jan 2012 | A1 |
20120030401 | Cowan et al. | Feb 2012 | A1 |
20120054367 | Ramakrishnan et al. | Mar 2012 | A1 |
20120072578 | Alam | Mar 2012 | A1 |
20120072985 | Davne et al. | Mar 2012 | A1 |
20120075999 | Ko et al. | Mar 2012 | A1 |
20120084445 | Brock et al. | Apr 2012 | A1 |
20120084782 | Chou et al. | Apr 2012 | A1 |
20120096134 | Suit | Apr 2012 | A1 |
20120130874 | Mane et al. | May 2012 | A1 |
20120131174 | Ferris et al. | May 2012 | A1 |
20120134672 | Banerjee | May 2012 | A1 |
20120144014 | Natham et al. | Jun 2012 | A1 |
20120159112 | Tokusho et al. | Jun 2012 | A1 |
20120167094 | Suit | Jun 2012 | A1 |
20120173581 | Hartig et al. | Jul 2012 | A1 |
20120173589 | Kwon et al. | Jul 2012 | A1 |
20120177039 | Berman | Jul 2012 | A1 |
20120177041 | Berman | Jul 2012 | A1 |
20120177042 | Berman | Jul 2012 | A1 |
20120177043 | Berman | Jul 2012 | A1 |
20120177044 | Berman | Jul 2012 | A1 |
20120177045 | Berman | Jul 2012 | A1 |
20120177370 | Berman | Jul 2012 | A1 |
20120179909 | Sagi et al. | Jul 2012 | A1 |
20120201138 | Yu et al. | Aug 2012 | A1 |
20120210041 | Flynn et al. | Aug 2012 | A1 |
20120254440 | Wang | Oct 2012 | A1 |
20120257501 | Kucharczyk | Oct 2012 | A1 |
20120265976 | Spiers et al. | Oct 2012 | A1 |
20120281706 | Agarwal et al. | Nov 2012 | A1 |
20120297088 | Wang | Nov 2012 | A1 |
20120303618 | Dutta et al. | Nov 2012 | A1 |
20120311106 | Morgan | Dec 2012 | A1 |
20120311568 | Jansen | Dec 2012 | A1 |
20120320788 | Venkataramanan et al. | Dec 2012 | A1 |
20120324114 | Dutta et al. | Dec 2012 | A1 |
20120331119 | Bose et al. | Dec 2012 | A1 |
20130003737 | Sinicrope | Jan 2013 | A1 |
20130013664 | Baird et al. | Jan 2013 | A1 |
20130028135 | Berman | Jan 2013 | A1 |
20130036212 | Jibbe et al. | Feb 2013 | A1 |
20130036213 | Hasan et al. | Feb 2013 | A1 |
20130036449 | Mukkara et al. | Feb 2013 | A1 |
20130054888 | Bhat et al. | Feb 2013 | A1 |
20130061089 | Valiyaparambil et al. | Mar 2013 | A1 |
20130067162 | Jayaraman et al. | Mar 2013 | A1 |
20130080823 | Roth et al. | Mar 2013 | A1 |
20130086340 | Fleming et al. | Apr 2013 | A1 |
20130100858 | Kamath et al. | Apr 2013 | A1 |
20130111540 | Sabin | May 2013 | A1 |
20130138816 | Kuo et al. | May 2013 | A1 |
20130138836 | Cohen et al. | May 2013 | A1 |
20130139138 | Kakos | May 2013 | A1 |
20130144933 | Hinni et al. | Jun 2013 | A1 |
20130152076 | Patel | Jun 2013 | A1 |
20130152175 | Hromoko et al. | Jun 2013 | A1 |
20130163426 | Beliveau et al. | Jun 2013 | A1 |
20130163606 | Bagepalli et al. | Jun 2013 | A1 |
20130179941 | McGloin et al. | Jul 2013 | A1 |
20130182712 | Aguayo et al. | Jul 2013 | A1 |
20130185433 | Zhu et al. | Jul 2013 | A1 |
20130185451 | Gelter | Jul 2013 | A1 |
20130191106 | Kephart et al. | Jul 2013 | A1 |
20130198730 | Munireddy et al. | Aug 2013 | A1 |
20130208888 | Agrawal et al. | Aug 2013 | A1 |
20130212130 | Rahnama | Aug 2013 | A1 |
20130223236 | Dickey | Aug 2013 | A1 |
20130238641 | Mandelstein et al. | Sep 2013 | A1 |
20130246552 | Underwood | Sep 2013 | A1 |
20130266307 | Garg et al. | Oct 2013 | A1 |
20130268922 | Tiwari et al. | Oct 2013 | A1 |
20130275470 | Cao et al. | Oct 2013 | A1 |
20130297655 | Narasayya et al. | Nov 2013 | A1 |
20130297769 | Chang et al. | Nov 2013 | A1 |
20130318134 | Bolik et al. | Nov 2013 | A1 |
20130318288 | Khan et al. | Nov 2013 | A1 |
20140006708 | Huynh et al. | Jan 2014 | A1 |
20140016493 | Johnsson et al. | Jan 2014 | A1 |
20140019684 | Wei et al. | Jan 2014 | A1 |
20140025770 | Warfield et al. | Jan 2014 | A1 |
20140029441 | Nydell | Jan 2014 | A1 |
20140029442 | Wallman | Jan 2014 | A1 |
20140039683 | Zimmermann et al. | Feb 2014 | A1 |
20140040473 | Ho et al. | Feb 2014 | A1 |
20140040883 | Tompkins | Feb 2014 | A1 |
20140047201 | Mehta | Feb 2014 | A1 |
20140053264 | Dubrovsky et al. | Feb 2014 | A1 |
20140059187 | Rosset et al. | Feb 2014 | A1 |
20140059266 | Ben-Michael et al. | Feb 2014 | A1 |
20140086253 | Yong | Mar 2014 | A1 |
20140089273 | Borshack et al. | Mar 2014 | A1 |
20140095556 | Lee et al. | Apr 2014 | A1 |
20140096249 | Dupont et al. | Apr 2014 | A1 |
20140105009 | Vos et al. | Apr 2014 | A1 |
20140108474 | David et al. | Apr 2014 | A1 |
20140109071 | Ding et al. | Apr 2014 | A1 |
20140112122 | Kapadia et al. | Apr 2014 | A1 |
20140123207 | Agarwal | May 2014 | A1 |
20140156557 | Zeng et al. | Jun 2014 | A1 |
20140164666 | Yand | Jun 2014 | A1 |
20140164866 | Bolotov et al. | Jun 2014 | A1 |
20140172371 | Zhu et al. | Jun 2014 | A1 |
20140173060 | Jubran et al. | Jun 2014 | A1 |
20140173195 | Rosset et al. | Jun 2014 | A1 |
20140173579 | McDonald et al. | Jun 2014 | A1 |
20140189278 | Peng | Jul 2014 | A1 |
20140195712 | Ryu | Jul 2014 | A1 |
20140198794 | Mehta et al. | Jul 2014 | A1 |
20140211661 | Gorkemli et al. | Jul 2014 | A1 |
20140215265 | Mohanta et al. | Jul 2014 | A1 |
20140215590 | Brand | Jul 2014 | A1 |
20140219086 | Cantu' et al. | Aug 2014 | A1 |
20140222953 | Karve et al. | Aug 2014 | A1 |
20140229790 | Goss et al. | Aug 2014 | A1 |
20140244585 | Sivasubramanian et al. | Aug 2014 | A1 |
20140244897 | Goss et al. | Aug 2014 | A1 |
20140245435 | Belenky | Aug 2014 | A1 |
20140269390 | Ciodaru et al. | Sep 2014 | A1 |
20140281700 | Nagesharao et al. | Sep 2014 | A1 |
20140297941 | Rajani et al. | Oct 2014 | A1 |
20140307578 | DeSanti | Oct 2014 | A1 |
20140317206 | Lomelino et al. | Oct 2014 | A1 |
20140324862 | Bingham et al. | Oct 2014 | A1 |
20140325208 | Resch et al. | Oct 2014 | A1 |
20140331276 | Frascadore et al. | Nov 2014 | A1 |
20140348166 | Yang et al. | Nov 2014 | A1 |
20140355450 | Bhikkaji et al. | Dec 2014 | A1 |
20140366155 | Chang et al. | Dec 2014 | A1 |
20140376550 | Khan et al. | Dec 2014 | A1 |
20150003450 | Salam et al. | Jan 2015 | A1 |
20150003458 | Li et al. | Jan 2015 | A1 |
20150003463 | Li et al. | Jan 2015 | A1 |
20150010001 | Duda et al. | Jan 2015 | A1 |
20150016461 | Qiang | Jan 2015 | A1 |
20150030024 | Venkataswami et al. | Jan 2015 | A1 |
20150046123 | Kato | Feb 2015 | A1 |
20150063353 | Kapadia et al. | Mar 2015 | A1 |
20150067001 | Koltsidas | Mar 2015 | A1 |
20150082432 | Eaton et al. | Mar 2015 | A1 |
20150092824 | Wicker, Jr. et al. | Apr 2015 | A1 |
20150120907 | Niestemski et al. | Apr 2015 | A1 |
20150121131 | Kiselev et al. | Apr 2015 | A1 |
20150127979 | Doppalapudi | May 2015 | A1 |
20150142840 | Baldwin et al. | May 2015 | A1 |
20150169313 | Katsura | Jun 2015 | A1 |
20150180672 | Kuwata | Jun 2015 | A1 |
20150207763 | Bertran Ortiz et al. | Jun 2015 | A1 |
20150205974 | Talley et al. | Jul 2015 | A1 |
20150222444 | Sarkar | Aug 2015 | A1 |
20150229546 | Somaiya et al. | Aug 2015 | A1 |
20150248366 | Bergsten et al. | Sep 2015 | A1 |
20150248418 | Bhardwaj et al. | Sep 2015 | A1 |
20150254003 | Lee et al. | Sep 2015 | A1 |
20150254088 | Chou et al. | Sep 2015 | A1 |
20150261446 | Lee | Sep 2015 | A1 |
20150263978 | Olson | Sep 2015 | A1 |
20150263993 | Kuch et al. | Sep 2015 | A1 |
20150269048 | Marr et al. | Sep 2015 | A1 |
20150277804 | Arnold et al. | Oct 2015 | A1 |
20150281067 | Wu | Oct 2015 | A1 |
20150303949 | Jafarkhani et al. | Oct 2015 | A1 |
20150341237 | Cuni et al. | Nov 2015 | A1 |
20150341239 | Bertran Ortiz et al. | Nov 2015 | A1 |
20150358136 | Medard | Dec 2015 | A1 |
20150379150 | Duda | Dec 2015 | A1 |
20160004611 | Lakshman et al. | Jan 2016 | A1 |
20160011936 | Luby | Jan 2016 | A1 |
20160011942 | Golbourn et al. | Jan 2016 | A1 |
20160054922 | Awasthi et al. | Feb 2016 | A1 |
20160062820 | Jones et al. | Mar 2016 | A1 |
20160070652 | Sundararaman et al. | Mar 2016 | A1 |
20160087885 | Tripathi et al. | Mar 2016 | A1 |
20160088083 | Bharadwaj et al. | Mar 2016 | A1 |
20160119159 | Zhao et al. | Apr 2016 | A1 |
20160119421 | Semke et al. | Apr 2016 | A1 |
20160139820 | Fluman et al. | May 2016 | A1 |
20160149639 | Pham et al. | May 2016 | A1 |
20160205189 | Mopur et al. | Jul 2016 | A1 |
20160210161 | Rosset et al. | Jul 2016 | A1 |
20160231928 | Lewis et al. | Aug 2016 | A1 |
20160274926 | Narasimhamurthy et al. | Sep 2016 | A1 |
20160285760 | Dong | Sep 2016 | A1 |
20160292359 | Tellis et al. | Oct 2016 | A1 |
20160294983 | Kliteynik et al. | Oct 2016 | A1 |
20160334998 | George et al. | Nov 2016 | A1 |
20160366094 | Mason et al. | Dec 2016 | A1 |
20160378624 | Jenkins, Jr. et al. | Dec 2016 | A1 |
20160380694 | Guduru | Dec 2016 | A1 |
20170010874 | Rosset | Jan 2017 | A1 |
20170010930 | Dutta et al. | Jan 2017 | A1 |
20170019475 | Metz et al. | Jan 2017 | A1 |
20170068630 | Iskandar et al. | Mar 2017 | A1 |
20170168970 | Sajeepa et al. | Jun 2017 | A1 |
20170177860 | Suarez et al. | Jun 2017 | A1 |
20170212858 | Chu et al. | Jul 2017 | A1 |
20170273019 | Park et al. | Sep 2017 | A1 |
20170277655 | Das et al. | Sep 2017 | A1 |
20170337097 | Sipos et al. | Nov 2017 | A1 |
20170340113 | Charest et al. | Nov 2017 | A1 |
20170371558 | George et al. | Dec 2017 | A1 |
20180097707 | Wright et al. | Apr 2018 | A1 |
Number | Date | Country |
---|---|---|
2228719 | Sep 2010 | EP |
2439637 | Apr 2012 | EP |
2680155 | Jan 2014 | EP |
2350028 | May 2001 | GB |
2000-242434 | Sep 2000 | JP |
1566104 | Jan 2017 | TW |
W0 2004077214 | Sep 2004 | WO |
2009146165 | Dec 2009 | WO |
WO 2016003408 | Jan 2016 | WO |
WO 2016003489 | Jan 2016 | WO |
Entry |
---|
Aweya, James, et al., “Multi-level active queue management with dynamic thresholds,” Elsevier, Computer Communications 25 (2002) pp. 756-771. |
Petersen, Chris, “Introducing Lightning: A flexible NVMe JBOF,” Mar. 9, 2016, 6 pages. |
Author Unknown, “5 Benefits of a Storage Gateway in the Cloud,” Blog, TwinStrata, Inc., posted Jul. 10, 2012, 4 pages, https://web.archive.org/web/20120725092619/http://blog.twinstrata.com/2012/07/10//5-benefits-of-a-storage-gateway-in-the-cloud. |
Author Unknown, “Configuration Interface for IBM System Storage DS5000, IBM DS4000, and IBM DS3000 Systems,” IBM SAN Volume Controller Version 7.1, IBM® System Storage® SAN Volume Controller Information Center, Jun. 16, 2013, 3 pages. |
Author Unknown, “Coraid EtherCloud, Software-Defined Storage with Scale-Out Infrastructure,” Solution Brief, 2013, 2 pages, Coraid, Redwood City, California, U.S.A. |
Author Unknown, “Coraid Virtual DAS (VDAS) Technology: Eliminate Tradeoffs between DAS and Networked Storage,” Coraid Technology Brief, © 2013 Cora id, Inc., Published on or about Mar. 20, 2013, 2 pages. |
Author Unknown, “Creating Performance-based SAN SLAs Using Finisar's NetWisdom” May 2006, 7 pages, Finisar Corporation, Sunnyvale, California, U.S.A. |
Author Unknown, “Data Center, Metro Cloud Connectivity: Integrated Metro SAN Connectivity in 16 Gbps Switches,” Brocade Communication Systems, Inc., Apr. 2011, 14 pages. |
Author Unknown, “Data Center, SAN Fabric Administration Best Practices Guide, Support Perspective,” Brocade Communication Systems, Inc., May 2013, 21 pages. |
Author Unknown, “delphi—Save a CRC value in a file, without altering the actual CRC Checksum?” Stack Overflow, stackoverfiow.com, Dec. 23, 2011, XP055130879, 3 pages http://stackoverflow.com/questions/8608219/save-a-crc-value-in-a-fiie-wihout-altering-the-actual-crc-checksum. |
Author Unknown, “EMC UNISPHERE: Innovative Approach to Managing Low-End and Midrange Storage; Redefining Simplicity in the Entry-Level and Midrange Storage Markets,” Data Sheet, EMC Corporation; published on or about Jan. 4, 2013 [Retrieved and printed Sep. 12, 2013] 6 pages http://www.emc.com/storage/vnx/unisphere.htm. |
Author Unknown, “HP XP Array Manager Software—Overview & Features,” Storage Device Management Software; Hewlett-Packard Development Company, 3 pages; © 2013 Hewlett-Packard Development Company, L.P. |
Author Unknown, “Joint Cisco and VMWare Solution for Optimizing Virtual Desktop Delivery: Data Center 3.0: Solutions to Accelerate Data Center Virtualization,” Cisco Systems, Inc. and VMware, Inc., Sep. 2008, 10 pages. |
Author Unknown, “Network Transformation with Software-Defined Networking and Ethernet Fabrics,” Positioning Paper, 2012, 6 pages, Brocade Communications Systems. |
Author Unknown, “Recreating Real Application Traffic in Junosphere Lab,” Solution Brief, Juniper Networks, Dec. 2011, 3 pages. |
Author Unknown, “Shunra for HP Softwarer,” Enabiling Confidence in Application Performance Before Deployment, 2010, 2 pages. |
Author Unknown, “Software Defined Networking: The New Norm for Networks,” White Paper, Open Networking Foundation, Apr. 13, 2012, 12 pages. |
Author Unknown, “Software Defined Storage Networks an Introduction,” White Paper, Doc # 01000030-001 Rev. A, Dec. 12, 2012, 8 pages; Jeda Networks, Newport Beach, California, U.S.A. |
Author Unknown, “Standard RAID Levels,” Wikipedia, the Free Encyclopedia, last updated Jul. 18, 2014, 7 pages; http://en.wikipedia.org/wik/Standard_RAID_levels. |
Author Unknown, “Storage Infrastructure for the Cloud,” Solution Brief, © 2012, 3 pages; coraid, Redwood City, California, U.S.A. |
Author Unknown, “Storage Area Network—NPIV: Emulex Virtual HBA and Brocade, Proven Interoperability and Proven Solution,” Technical Brief, Apr. 2008, 4 pages, Emulex and Brocade Communications Systems. |
Author Unknown, “The Fundamentals of Software-Defined Storage, Simplicity at Scale for Cloud-Architectures” Solution Brief, 2013, 3 pages; Coraid, Redwood City, California, U.S.A. |
Author Unknown, “VirtualWisdom® SAN Performance Probe Family Models: Probe FC8, HD, and HD48,” Virtual Instruments Data Sheet, Apr. 2014 Virtual Instruments. All Rights Reserved; 4 pages. |
Author Unknown, “Xgig Analyzer: Quick Start Feature Guide 4.0,” Feb. 2008, 24 pages, Finisar Corporation, Sunnyvale, California, U.S.A. |
Author Unknown, “Sun Storage Common Array Manager Installation and Setup Guide,” Software Installation and Setup Guide Version 6.7.×821-1362-10, Appendix D: Configuring In-Band Management, Sun Oracle; retrieved and printed Sep. 12, 2013, 15 pages. |
Author Unknown, “Vblock Solution for SAP: Simplified Provisioning for Operation Efficiency,” VCE White Paper, VCE—The Virtual Computing Environment Company, Aug. 2011, 11 pages. |
Berman, Stuart, et al., “Start-Up Jeda Networks in Software Defined Storage Network Technology,” Press Release, Feb. 25, 2013, 2 pages, http://www.storagenewsletter.com/news/startups/jeda-networks. |
Borovick, Lucinda, et al., “White Paper, Architecting the Network for the Cloud,” IDC Analyze the Future, Jan. 2011, pp. 1-8. |
Chakrabarti, Kaushik, et al., “Locally Adaptive Dimensionality Reduction for Indexing Large Time Series Databases,” ACM Transactions on Database Systems, vol. 27, No. 2, Jun. 2009, pp. 188-228. |
Chandola, Varun, et al., “A Gaussian Process Based Online Change Detection Algorithm for Monitoring Periodic Time Series,” Proceedings of the Eleventh SIAM International Conference on Data Mining, SDM 2011, Apr. 28-30, 2011, 12 pages. |
Cisco Systems, Inc. “N-Port Virtualization in the Data Center,” Cisco White Paper, Cisco Systems, Inc., Mar. 2008, 7 pages. |
Cisco Systems, Inc., “Best Practices in Deploying Cisco Nexus 1000V Series Switches on Cisco UCS B and C Series Cisco UCS Manager Servers,” White Paper, Cisco Systems, Inc., Apr. 2011, 36 pages. |
Cisco Systems, Inc., “Cisco Prime Data Center Network Manager 6.1,” At-A-Glance, © 2012, 3 pages. |
Cisco Systems, Inc., “Cisco Prime Data Center Network Manager,” Release 6.1 Data Sheet, © 2012, 10 pages. |
Cisco Systems, Inc., “Cisco Unified Network Services: Overcome Obstacles to Cloud-Ready Deployments,” White Paper, Cisco Systems, Inc., Jan. 2011, 6 pages. |
Clarke, Alan, et al., “Open Data Center Alliance Usage: Virtual Machine (VM) Interoperability in a Hybrid Cloud Environment Rev. 1.2,” Open Data Center Alliance, Inc., 2013, pp. 1-18. |
Cummings, Roger, et al., Fibre Channel—Fabric Generic Requirements (FC-FG), Dec. 4, 1996, 33 pages, American National Standards Institute, Inc., New York, New York, U.S.A. |
Farber, Franz, et al. “An In-Memory Database System for Multi-Tenant Applications,” Proceedings of 14th Business, Technology and Web (BIW) Conference on Database Systems for Business, Technology, and Web, Feb. 28 to Mar. 4, 2011, 17 pages, University of Kaiserslautern, Germany. |
Guo, Chang Jie, et al., “IBM Resarch Report: Data Integration and Composite Business Services, Part 3, Building a Multi-Tenant Data Tier with with [sic] Access Control and Security,” RC24426 (C0711-037), Nov. 19, 2007, 20 pages, IBM. |
Hatzieleftheriou, Andromachi, et al., “Host-side Filesystem Journaling for Durable Shared Storage,” 13th USENIX Conference on File and Storage Technologies (FAST '15), Feb. 16-19, 2015, 9 pages; https://www.usenix.org/system/files/conference/last15/last15-paper-hatzieleftheriou.pdf. |
Hedayat, K., et al., “A Two-Way Active Measurement Protocol (TWAMP),” Network Working Group, RFC 5357, Oct. 2008, 26 pages. |
Horn, C., et al., “Online anomaly detection with expert system feedback in social networks,” 2011 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP), May 22-27, 2011, 2 pages, Prague; [Abstract only]. |
Hosterman, Cody, et al., “Using EMC Symmetrix Storage inVMware vSph ere Environments,” Version 8.0, EMC2Techbooks, EMC Corporation; published on or about Jul. 8, 2008, 314 pages; [Retrieved and printed Sep. 12, 2013]. |
Hu, Yuchong, et al., “Cooperative Recovery of Distributed Storage Systems from Multiple Losses with Network Coding,” University of Science & Technology of China, Feb. 2010, 9 pages. |
Keogh, Eamonn, et al., “Dimensionality Reduction for Fast Similarity Search in Large Time Series Databases,” KAIS Long Paper submitted May 16, 2000; 19 pages. |
Kolyshkin, Kirill, “Virtualization in Linux,” Sep. 1, 2006, pp. 1-5. |
Kovar, Joseph F., “Startup Jeda Networks Takes SDN Approach to Storage Networks,” CRN Press Release, Feb. 22, 2013, 1 page, http://www.crn.com/240149244/printablearticle.htm. |
Lampson, Butler, W., et al., “Crash Recovery in a Distributed Data Storage System,” Jun. 1, 1979, 28 pages. |
Lewis, Michael E., et al., “Design of an Advanced Development Model Optical Disk-Based Redundant Array of Independent Disks (RAID) High Speed Mass Storage Subsystem,” Final Technical Report, Oct. 1997, pp. 1-211. |
Lin, Jessica, “Finding Motifs in Time Series,” SIGKDD'02 Jul. 23-26, 2002, 11 pages, Edmonton, Alberta, Canada. |
Linthicum, David, “VM Import could be a game changer for hybrid clouds”, InfoWorld, Dec. 23, 2010, 4 pages. |
Long, Abraham Jr., “Modeling the Reliability of RAID Sets,” Dell Power Solutions, May 2008, 4 pages. |
Ma, Ao, et al., “RAIDShield: Characterizing, Monitoring, and Proactively Protecting Against Disk Failures,” FAST '15, 13th USENIX Conference on File and Storage Technologies, Feb. 16-19, 2015, 17 pages, Santa Clara, California, U.S.A. |
Mahalingam, M., et al., “Virtual eXtensible Local Area Network (VXLAN): A Framework for Overlaying Virtualized Layer 2 Networks over Layer 3 Networks,” Independent Submission, RFC 7348, Aug. 2014, 22 pages; http://www.hip.at.doc/rfc/rfc7348.html. |
McQuerry, Steve, “Cisco UCS M-Series Modular Servers for Cloud-Scale Workloads,” White Paper, Cisco Systems, Inc., Sep. 2014, 11 pages. |
Monia, Charles, et al., IFCP—A Protocol for Internet Fibre Channel Networking, draft-monia-ips-ifcp-00.txt, Dec. 12, 2000, 6 pages. |
Mueen, Abdullah, et al., “Online Discovery and Maintenance of Time Series Motifs,” KDD'10 The 16th ACM SIGKDD International Conference on Knowledge Discovery and Data Mining, Jul. 25-28, 2010, 10 pages, Washington, DC, U.S.A. |
Muglia, Bob, “Decoding SDN,” Jan. 14, 2013, Juniper Networks, pp. 1-7, http://forums.juniper.net/15/The-New-Network/Decoding-SDN/ba-p/174651. |
Murray, Joseph F., et al., “Machine Learning Methods for Predicting Failures in Hard Drives: A Multiple-Instance Application,” Journal of Machine Learning Research 6 (2005), pp. 783-816; May 2005, 34 pages. |
Nelson, Mark, “File Verification Using CRC,” Dr. Dobb's Journal, May 1, 1992, pp. 1-18, XP055130883. |
Pace, Alberto, “Technologies for Large Data Management in Scientific Computing,” International Journal of Modern Physics C., vol. 25, No. 2, Feb. 2014, 72 pages. |
Pinheiro, Eduardo, et al., “Failure Trends in a Large Disk Drive Population,” FAST '07, 5th USENIX Conference on File and Storage Technologies, Feb. 13-16, 2007, 13 pages, San Jose, California, U.S.A. |
Raginsky, Maxim, et al., “Sequential Anomaly Detection in the Presence of Noise and Limited Feedback,” arXiv:0911.2904v4 [cs.LG] Mar. 13, 2012, 19 pages. |
Saidi, Ali G., et al., “Performance Validation of Network-Intensive Workloads on a Full-System Simulator,” Interaction between Operating System and Computer Architecture Workshop, (IOSCA 2005), Austin, Texas, Oct. 2005, 10 pages. |
Sajassi, A., et al., “BGP MPLS Based Ethernet VPN,” Network Working Group, Oct. 18, 2014, 52 pages. |
Sajassi, Ali, et al., “A Network Virtualization Overlay Solution using EVPN,” L2VPN Workgroup, Nov. 10, 2014, 24 pages; http://tools.ietf.org/pdf/draft-ietf-bess-evpn-overlay-00.pdf. |
Sajassi, Ali, et al., “Integrated Routing and Bridging in EVPN,” L2VPN Workgroup, Nov. 11, 2014, 26 pages; http://tools.ietf.org/pdf/draft-ietf-bess-evpn-inter-subnet-forwarding-00.pdf. |
Schroeder, Bianca, et al., “Disk failures in the real world: What does an MTTF of 1,000,000 hours mean to you?” FAST '07: 5th USENIX Conference on File and Storage Technologies, Feb. 13-16, 2007, 16 pages, San Jose, California, U.S.A. |
Shue, David, et al., “Performance Isolation and Fairness for Multi-Tenant Cloud Storage,” USENIX Association, 10th USENIX Symposium on Operating Systems Design Implementation (OSDI '12), 2012, 14 pages; https://www.usenix.org/system/files/conference/osdi12/osdi12.final-215.pdf. |
Staimer, Marc, “Inside Cisco Systems' Unified Computing System,” Dragon Slayer Consulting, Jul. 2009, 5 pages. |
Swami, Vijay, “Simplifying SAN Management for VMWare Boot from SAN, Utilizing Cisco UCS and Palo,” posted May 31, 2011, 6 pages. |
Tate, Jon, et al., “Introduction to Storage Area Networks and System Networking,” Dec. 2017, 302 pages, ibm.com/redbooks. |
Vuppala, Vibhavasu, et al., “Layer-3 Switching Using Virtual Network Ports,” Computer Communications and Networks, 1999, Proceedings, Eight International Conference in Boston, MA, USA, Oct. 11-13, 1999, Piscataway, NJ, USA, IEEE, ISBN: 0-7803-5794-9, pp. 642-648. |
Wang, Feng, et al. “OBFS: A File System for Object-Based Storage Devices,” Storage System Research Center, MSST. vol. 4., Apr. 2004, 18 pages. |
Weil, Sage A., “CEPH: Reliable, Scalable, and High-Performance Distributed Storage,” Dec. 2007, 239 pages, University of California, Santa Cruz. |
Weil, Sage A., et al. “CRUSH: Controlled, Scalable, Decentralized Placement of Replicated Data.” Proceedings of the 2006 ACM/IEEE conference on Supercomputing. ACM, Nov. 11, 2006, 12 pages. |
Weil, Sage A., et al. “Ceph: A Scalable, High-performance Distributed File System,” Proceedings of the 7th symposium on Operating systems design and implementation. USENIX Association, Nov. 6, 2006, 14 pages. |
Wu, Joel, et al., “The Design, and Implementation of AQuA: An Adaptive Quality of Service Aware Object-Based Storage Device,” Department of Computer Science, MSST, May 17, 2006, 25 pages; http://storageconference.us/2006/Presentations/30Wu.pdf |
Xue, Chendi, et al. “A Standard framework for Ceph performance profiling with latency breakdown,” CEPH, Jun. 30, 2015, 3 pages. |
Zhou, Zihan, et al., “Stable Principal Component Pursuit,” arXiv:1001.2363v1 [cs.IT], Jan. 14, 2010, 5 pages. |
Zhu, Yunfeng, et al., “A Cost-based Heterogeneous Recovery Scheme for Distributed Storage Systems with RAID-6 Codes,” University of Science & Technology of China, 2012, 12 pages. |
Steve McQuerry, “Cisco UCS M-Series Modular Servers for Cloud-Scale Workloads,” White Paper, Cisco Systems, Inc., Sep. 2014, 11 pages; http://www.cisco.conn/c/en/us/solutions/collateral/data-center-virtualization/unifiedconnputing/whitepaper_c11-732876.pdf. |
Stamey, John, et al., “Client-Side Dynamic Metadata in Web 2.0,” SIGDOC '07, Oct. 22-24, 2007, pp. 155-161. |
Number | Date | Country | |
---|---|---|---|
20180137073 A1 | May 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14965750 | Dec 2015 | US |
Child | 15869256 | US |