[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US8185715B1 - Method and system for managing metadata in storage virtualization environment - Google Patents

Method and system for managing metadata in storage virtualization environment Download PDF

Info

Publication number
US8185715B1
US8185715B1 US11/694,698 US69469807A US8185715B1 US 8185715 B1 US8185715 B1 US 8185715B1 US 69469807 A US69469807 A US 69469807A US 8185715 B1 US8185715 B1 US 8185715B1
Authority
US
United States
Prior art keywords
metadata
memory chunk
virtualization
storage
data processing
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US11/694,698
Inventor
William W. Chow
John Logan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Marvell Asia Pte Ltd
Original Assignee
QLogic LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by QLogic LLC filed Critical QLogic LLC
Priority to US11/694,698 priority Critical patent/US8185715B1/en
Assigned to QLOGIC, CORPORATION reassignment QLOGIC, CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CHOW, WILLIAM W., LOGAN, JOHN
Application granted granted Critical
Publication of US8185715B1 publication Critical patent/US8185715B1/en
Assigned to JPMORGAN CHASE BANK, N.A., AS COLLATERAL AGENT reassignment JPMORGAN CHASE BANK, N.A., AS COLLATERAL AGENT SECURITY AGREEMENT Assignors: QLOGIC CORPORATION
Assigned to Cavium, Inc. reassignment Cavium, Inc. MERGER (SEE DOCUMENT FOR DETAILS). Assignors: QLOGIC CORPORATION
Assigned to QLOGIC CORPORATION, CAVIUM NETWORKS LLC, CAVIUM, INC reassignment QLOGIC CORPORATION RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: JP MORGAN CHASE BANK, N.A., AS COLLATERAL AGENT
Assigned to CAVIUM, LLC reassignment CAVIUM, LLC CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: Cavium, Inc.
Assigned to CAVIUM INTERNATIONAL reassignment CAVIUM INTERNATIONAL ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CAVIUM, LLC
Assigned to MARVELL ASIA PTE, LTD. reassignment MARVELL ASIA PTE, LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CAVIUM INTERNATIONAL
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0662Virtualisation aspects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/067Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]

Definitions

  • Storage virtualization is desirable in SAN communication.
  • the term storage virtualization as used herein means the process by which a logical (virtual) storage device/system/array appears to a host system as being a physical device (or a local device).
  • Storage virtualization allows data to be stored in different storage arrays and devices, but can be presented to a host system in a comprehensive manner, as if the arrays and storage devices were local to the host system.
  • Persistent information includes mapping metadata and copy of the data stored by the host system.
  • metadata as used throughout this specification includes information that describes data.
  • file metadata includes, file name, time of creation and modification, read and write permissions and lists of block addresses at which the file's data is stored.
  • storage metadata includes the mapping tables that link virtual block addresses to logical block addresses of physical storage devices.
  • a method for managing metadata for a plurality of storage platforms that provide virtualization services includes requesting a memory chunk for storing metadata; wherein a data processing agent operating in a storage platform requests the memory chunk and a centralized metadata controller for the plurality of storage platforms receives the request for the memory chunk; determining the memory chunk size and allocating the memory chunk from a pool of memory chunks; and assigning the allocated memory chunk to a virtualization mapping object.
  • a storage area network includes a plurality of virtualization modules that are coupled together in a cluster; wherein each virtualization module runs a data processing agent for providing virtualization services and a centralized metadata controller for the cluster controls allocation of memory chunks to store metadata; and the metadata controller receives a request for a memory chunk from the data processing agent and determines the memory chunk size and allocates the memory chunk from a pool of memory chunks; and assigns the allocated memory chunk to a virtualization mapping object.
  • a virtualization module coupled to other virtualization modules in a cluster.
  • the virtualization module includes a data processing agent for providing virtualization services; and a centralized metadata controller for the cluster that controls allocation of memory chunks to store metadata; and the metadata controller receives a request for a memory chunk from the data processing agent and determines the memory chunk size and allocates the memory chunk from a pool of memory chunks; and assigns the allocated memory chunk to a virtualization mapping object.
  • FIG. 1B shows another example of a system using storage virtualization
  • FIG. 1C shows a block diagram of a network node, according to one embodiment
  • FIG. 1D shows a block diagram of a cluster, according to one embodiment
  • FIG. 1E shows a block diagram of “chunk” pool controlled by a centralized metadata controller, according to one embodiment
  • FIGS. 2A and 2B show process flow diagrams for managing chunks, according to one embodiment
  • FIG. 3 shows a process flow diagram for obtaining control of a chunk, according to one embodiment
  • FIG. 4 shows a process flow diagram for gaining control of an active chunk, according to one embodiment.
  • FIG. 1A shows a top-level block diagram of a system 100 according to one aspect of the present invention.
  • System 100 facilitates communication between plural devices/computing systems.
  • Any device in network system 100 for example, a Fibre Channel switch or node
  • these elements in the network may also perform storage virtualization functions.
  • Various standards protocols may be used for designing and operating SANs.
  • network nodes in a SAN communicate using a storage protocol that operates on logical blocks of data, such as small computer system interface (SCSI).
  • SCSI small computer system interface
  • the SCSI protocol is incorporated herein by reference in its entirety.
  • the storage protocol is delivered, by mapping or encapsulation, using a reliable transport protocol.
  • Fibre Channel is one such standard transport protocol, which is incorporated herein by reference in its entirety.
  • Fibre channel is a set of American National Standard Institute (ANSI) standards, which provide a serial transmission protocol for storage and network protocols such as HIPPI, SCSI, IP, ATM and others.
  • the Fibre Channel Protocol (FCP) maps SCSI commands to the Fibre Channel transport protocol.
  • Other transport protocols may also support SCSI commands, for example, the SCSI parallel bus, Serial Attached SCSI, TCP/IP, and Infiniband. These standard protocols are incorporated herein by reference in their entirety.
  • Fibre channel supports three different topologies: point-to-point, arbitrated loop and Fibre Channel Fabric.
  • the point-to-point topology attaches two devices directly.
  • the arbitrated loop topology attaches devices in a loop.
  • the Fibre Channel Fabric topology attaches devices (i.e., host or storage systems) directly to a Fabric, which may consist of multiple Fabric elements.
  • a Fibre Channel switch device is a multi-port device where each port manages routing of network traffic between its attached systems and other systems that may be attached to other switches in the Fabric. Each port can be attached to a server, peripheral, I/O subsystem, bridge, hub, router, or another switch.
  • system 100 includes a plurality of host computing systems ( 102 - 104 ) that are coupled to a storage services platform (SSP) (also referred to as a “node” or “network node”) 101 via SAN 105 .
  • Host systems ( 102 - 104 ) typically include several functional components. These components may include a central processing unit (CPU), main memory, input/output (“I/O”) devices, and local storage devices (for example, internal disk drives).
  • the main memory is coupled to the CPU via a system bus or a local memory bus.
  • the main memory is used to provide the CPU access to data and/or program information that is stored in main memory at execution time.
  • the main memory is composed of random access memory (RAM) circuits.
  • RAM random access memory
  • SSP (virtualization module) 101 is coupled to SAN 106 that is operationally coupled to plural storage devices, for example, 107 , 108 and 109 .
  • SSP 101 provides virtual storage 110 A to host systems 102 - 104 , while operating as a virtual host 110 B to storage devices 107 - 109 .
  • Virtual storage 110 A includes a set of disk blocks presented to a host operating system as a range of consecutively numbered logical blocks with physical disk-like storage and SCSI (or any other protocol based) input/output semantics.
  • SSP 101 is a multi-port Fabric element in the SAN (e.g., in Fibre Channel, physical ports function as Fx_Ports). As a Fabric element, SSP 101 can process non-blocking Fibre Channel Class 2 (connectionless, acknowledged) and Class 3 (connectionless, unacknowledged) service between any ports.
  • Fibre Channel Fibre Channel
  • Class 3 connectionless, unacknowledged
  • SSP 101 ports are generic to common Fibre Channel port types, for example, F_Port, FL_Port and E_Port.
  • F_Port Fibre Channel port
  • FL_Port FL_Port
  • E_Port Fibre Channel port
  • each GL port can function as any type of switch port.
  • the GL port may function as a special port useful in Fabric element linking, as described below.
  • SSP 101 is a multi-port network node element in a SAN (e.g., in a Fibre Channel based network, physical ports function as Nx_Ports).
  • SSP 101 may originate or respond to network communication (e.g., in a Fibre Channel based network, originate or respond to an exchange).
  • SSP 101 may support both switch ports and node ports simultaneously.
  • the node ports may be supported directly at a physical interface (not shown) or indirectly as a virtual entity that may be reached via one or more of the physical interfaces (not shown) operating as switch ports. For the latter, these virtual node ports are visible to other network elements as if they were physically attached to switch ports on SSP 101 .
  • SSP 101 supports plural upper level protocols, such as SCSI.
  • SCSI SCSI on Fibre Channel (FCP)
  • SSP 101 supports SCSI operation on any of its Nx_Ports.
  • Each SCSI port can support either initiator or target mode operation, or both.
  • FIG. 1B shows a block diagram of a network system where plural SSPs 101 (SSP 1 . . . SSP N ) are operationally coupled in a cluster 100 A.
  • SSP 101 provides virtualization services to different host systems and storage devices.
  • SSP 1 101 provides virtual disk A ( 110 A) (referred to as virtual storage earlier) to host 102
  • SSP N provides virtual disk N ( 110 A) to Host 104 .
  • FIG. 1C shows a top-level block diagram of SSP 101 .
  • SSP 101 has plural ports (shown as Port 1 -Port N ( 115 A, 115 B and 115 C). The ports allow SSP 101 to connect with host systems and other devices including storage devices, either directly or via a SAN.
  • SSP 101 includes a data plane (module/component) 111 and a control plane (module/component) 117 .
  • Data plane 111 and control plane 117 communicate via control path 116 .
  • Control path 116 is a logical communication path that may consist of one or more physical interconnects.
  • control path 116 includes a high speed PCI/PCI-X/PCI-Express bus.
  • control path 116 includes a Fibre Channel connection. It is noteworthy that the adaptive aspects of the present invention are not limited to the type of link 116 .
  • Data plane 111 includes memory (not shown), a backplane 113 , plural ports ( 115 A- 115 C) and plural packet processing engines (PPEs) (shown as 114 A- 114 C).
  • Data plane 111 receives network packets (e.g., command frames, data frames) from host system 102 via plurals ports ( 115 A- 115 C).
  • PPE 114 A- 114 C
  • I_T_Ls are used to process SCSI based commands, where I stands for initiator; T for a target and L for a logical unit number value.
  • PPEs may forward packets via any Port 115 A- 115 C by sending them through backplane 113 .
  • commands that are autonomously processed by data plane 111 , without assistance from control plane 117 are sent directly through back plane 113 .
  • PPEs 114 A- 114 C may also forward packets to control plane 117 via control path 116 .
  • commands which require assistance from control plane 117 , are sent via control path 116 .
  • Control plane 117 includes processor 118 , memory 119 and a data plane interface 118 A.
  • Data plane interface 118 A facilitates communication with data plane 113 via control path 116 for example, for sending/receiving commands.
  • data plane interface 118 A may include a network adapter, such as a Fibre Channel host bus adapter (HBA).
  • HBA Fibre Channel host bus adapter
  • data plane interface 118 A includes a bus interface, such as a PCI bridge.
  • Processor 118 may be a generic microprocessor (for example, Intel® Xeon®)) and an associated chip set (e.g., Intel E7500), a reduced instruction set computer (RISC) or a state machine. Processor 118 executes software for processing input/output (I/O) requests and processing virtual commands.
  • Intel® Xeon® for example, Intel® Xeon®
  • RISC reduced instruction set computer
  • Processor 118 executes software for processing input/output (I/O) requests and processing virtual commands.
  • the following provides an example of processing a virtual command.
  • host 102 sends a command to write to virtual storage 110 A, it is considered a virtual command, since it involves a virtual entity 110 A.
  • a physical command involves actual physical entities.
  • the I/O context for the virtual command i.e. remapped directly to a single corresponding physical command
  • the “Q” in I_T_L_Q identifies the command type.
  • SSP 101 provides various storage related services, including, mirroring, snapshots (including copy on write (COW), journaling and others.
  • mirror as used herein includes creating an exact copy of disk data written in real time to a secondary array or disk.
  • snapshot means a “point-in-time” copy of block level data. Snapshots are used to restore data accesses to a known good point in time if data corruption subsequently occurs or to preserve an image for non-disruptive tape backup.
  • COW means copying only that data that has been modified after an initial snapshot has been taken.
  • journaling as used herein means an operation that maintains a list of storage writes in a log file.
  • Metadata for the foregoing operations changes dynamically.
  • the adaptive aspects disclosed herein provide an efficient system and method to manage metadata, as described below.
  • FIG. 1D shows an example of a system for managing metadata, according to one embodiment.
  • Cluster 100 A includes various nodes (SSPs). For example, Nodes 1 , 2 and N.
  • Nodes 1 and 2 include a data path agent (DPA) 120 (shown as DPA 1 and DPA 2 ).
  • DPA data path agent
  • Each DPA includes software instructions that are executed by processor 118 .
  • DPA 120 provides virtualization services for a plurality of host systems, for example, volume management, data replication, data protection and others.
  • Node N includes a metadata controller (MDC) 121 for cluster 100 A.
  • MDC 121 coordinates actions of all DPAs in different nodes and manages metadata.
  • MDC 121 controls allocation of chunks that are used for persistent storage of metadata, as described below, according to one aspect.
  • the term “chunk” as used herein is persistent storage that is used to store metadata and replicated data.
  • Node N shows MDC 121 , it also runs a DPA (not shown), i.e. at any given time, all nodes execute a DPA, while one of the nodes executes MDC 121 .
  • FIG. 1E shows a chunk pool 125 with plural chunks 122 , 123 and 124 .
  • MDC 121 allocates these chunks to DPAs and once a DPA completes writing metadata in the chunk, MDC 121 regains control back from the DPA. If the DPA fails while the chunk is being written, MDC 121 regains control back, even before the entire chunk is written, as described below.
  • chunk pool 125 may change statically or dynamically.
  • chunks may not be pre-allocated and instead MDC 121 is aware of available chunk storage and may use a dynamic allocation process to retrieve a chunk when needed.
  • FIG. 2A shows a process flow diagram for managing metadata chunks, according to one embodiment.
  • the process starts in step S 200 , when a DPA (for example, 120 ) requests a chunk from MDC 121 for metadata storage services.
  • MDC 121 examines the request from DPA 120 and determines the chunk size that it needs to allocate.
  • step S 204 MDC 121 allocates a chunk to the request from the chunk pool, for example the chunk pool 125 ( FIG. 1E ).
  • Steps S 202 and S 204 are executed as a part of the same transaction, i.e., either both happen or neither step takes place.
  • step S 206 the chunk is assigned to a virtualization-mapping object in a designated node.
  • Virtual disks are composed of a hierarchical layering of mapping objects. Each mapping object represents a particular transformation of an I/O operation. Each mapping object contains metadata that directs the transformation of individual I/Os.
  • step S 208 DPA 120 for the designated node gets control of the chunk and DPA 120 populates the chunk with metadata.
  • FIG. 2B shows a process flow diagram for storing metadata in chunks, according to one embodiment.
  • the process starts in step S 210 , when a DPA (for example, 120 ) that gets control of a chunk stores metadata in the assigned chunk.
  • a DPA for example, 120
  • Metadata for this example is an initiator port on an SSP 101 , a remote target port, a LUN identifier, and a logical block address (LBA) offset value
  • Segment map metadata for this example is a table of fixed size segments, each of which maps a virtual LBA region to an underlying mapping object
  • Point-in-time metadata in this example includes a table of fixed size segments, managed by an application to manage COW operations.
  • control regarding the chunk is passed to MDC 121 in step S 212 . Thereafter, DPA 120 requests another chunk from MDC 121 in step S 214 .
  • FIG. 2C shows an example of metadata 217 for a segment in disk 216 .
  • Metadata 217 includes header and version number 218 and is identified as md-bluhdl.
  • Metadata 217 includes various metadata entries (MD entries 219 ) for example, md_plba (logical block address); UD disk_ID (user data (UD) identifier); UD StartLBA (start of user data LBA); UD size (size of each UD entry); flags; characters and then other metadata entries.
  • MD entries 219 for example, md_plba (logical block address); UD disk_ID (user data (UD) identifier); UD StartLBA (start of user data LBA); UD size (size of each UD entry); flags; characters and then other metadata entries.
  • md_plba logical block address
  • UD disk_ID user data (UD) identifier
  • UD StartLBA start of user data LBA
  • UD size size of each UD entry
  • FIG. 3 shows a process flow diagram for managing chunks when a DPA fails before passing off a chunk to MDC 121 , according to one embodiment.
  • the process starts in step S 300 .
  • a DPA fails before passing off a chunk to MDC 121 .
  • MDC 121 reclaims the control of the allocated chunk, after MDC 121 receives notification of DPA failure.
  • step S 306 when the DPA recovers, it requests another chunk from MDC 121 .
  • FIG. 4 shows a process flow diagram for obtaining control of a chunk, according to one embodiment.
  • the process starts in step S 400 .
  • MDC 121 determines if there is a trigger event to gain control of a chunk from a DPA to MDC 121 .
  • the trigger event my be generated from a user action, for example, creation of a new Point-In-Time copy. If there is no trigger event, the process simply continues to monitor. If yes, then in step S 404 , MDC 121 sends a request to obtain control of an active chunk.
  • An active chunk is a chunk that at any given time is under control of a DPA and is being written by the DPA.
  • step S 406 the DPA completes the pending operation and in step S 408 , the DPA returns control of the chunk to MDC 121 .
  • step S 410 MDC 121 stores a flag indicating that it “owns” (i.e. controls) the chunk.
  • MDC 121 is not aware of any metadata format and simply allocates chunks before the chunk is populated by a DPA. In another aspect, if a DPA fails for whatever reason, MDC 121 obtains control of the chunk.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

Method and system for managing metadata for a plurality of storage platforms that provide virtualization services is provided. The method includes requesting a memory chunk for storing metadata; wherein a data processing agent operating in a storage platform requests the memory chunk and a centralized metadata controller for the plurality of storage platforms receives the request for the memory chunk; determining the memory chunk size and allocating the memory chunk from a pool of memory chunks; and assigning the allocated memory chunk to a virtualization mapping object.

Description

BACKGROUND
1. Field of the Invention
The present invention relates to storage systems, and more particularly, to managing metadata.
2. Background of the Invention
Storage area networks (“SANs”) are commonly used where plural storage devices are made available to various host computing systems. Data in a SAN is typically moved between plural host systems (that include computer systems, servers etc.) and storage systems through various controllers/adapters and switches.
Storage virtualization is desirable in SAN communication. The term storage virtualization as used herein means the process by which a logical (virtual) storage device/system/array appears to a host system as being a physical device (or a local device). Storage virtualization allows data to be stored in different storage arrays and devices, but can be presented to a host system in a comprehensive manner, as if the arrays and storage devices were local to the host system.
SAN-based storage virtualization attempts to provide scalable volume management, data replication, data protection, and data migration services. A common problem encountered when implementing these systems is that of storing and maintaining persistent information (which includes, commands, data and metadata) used by these services. The term persistent information as used herein means information that is saved and is available for future use (for example, in a hard drive, tape drive and others).
Persistent information includes mapping metadata and copy of the data stored by the host system. The term metadata as used throughout this specification includes information that describes data. For example, in file systems, file metadata includes, file name, time of creation and modification, read and write permissions and lists of block addresses at which the file's data is stored. For virtualization, storage metadata includes the mapping tables that link virtual block addresses to logical block addresses of physical storage devices.
Conventional approach makes a single network node (within a distributed network environment) responsible for allocating persistent storage and storing the virtualization metadata. This approach is undesirable for storing metadata that changes dynamically during various operations, for example, snapshots, point-in-time copy, journaling, and mirroring services because the network node responsible for allocating and storing the data becomes a bottleneck for the entire distributed system. Traditional approaches also use independent mechanisms for storing different types for virtualization metadata. For example, the mechanism for allocating and storing snapshot-related metadata differs from the method for allocating and storing dirty region logs for mirroring operations. These methods may in turn differ from the method for allocating and storing journaling data and metadata.
Therefore, there is a need for a method and system for efficiently managing metadata.
SUMMARY
In one embodiment, a method for managing metadata for a plurality of storage platforms that provide virtualization services is provided. The method includes requesting a memory chunk for storing metadata; wherein a data processing agent operating in a storage platform requests the memory chunk and a centralized metadata controller for the plurality of storage platforms receives the request for the memory chunk; determining the memory chunk size and allocating the memory chunk from a pool of memory chunks; and assigning the allocated memory chunk to a virtualization mapping object.
In another embodiment, a storage area network (SAN) is provided. The SAN includes a plurality of virtualization modules that are coupled together in a cluster; wherein each virtualization module runs a data processing agent for providing virtualization services and a centralized metadata controller for the cluster controls allocation of memory chunks to store metadata; and the metadata controller receives a request for a memory chunk from the data processing agent and determines the memory chunk size and allocates the memory chunk from a pool of memory chunks; and assigns the allocated memory chunk to a virtualization mapping object.
In yet another embodiment, a virtualization module coupled to other virtualization modules in a cluster is provided. The virtualization module includes a data processing agent for providing virtualization services; and a centralized metadata controller for the cluster that controls allocation of memory chunks to store metadata; and the metadata controller receives a request for a memory chunk from the data processing agent and determines the memory chunk size and allocates the memory chunk from a pool of memory chunks; and assigns the allocated memory chunk to a virtualization mapping object.
This brief summary has been provided so that the nature of the invention may be understood quickly. A more complete understanding of the invention can be obtained by reference to the following detailed description of the preferred embodiments thereof concerning the attached drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
The foregoing features and other features will now be described with reference to the drawings of the various embodiments. In the drawings, the same components have the same reference numerals. The illustrated embodiments are intended to illustrate, but not to limit the invention. The drawings include the following Figures:
FIG. 1A shows a block diagram illustrating a networking system using virtualization;
FIG. 1B shows another example of a system using storage virtualization;
FIG. 1C shows a block diagram of a network node, according to one embodiment;
FIG. 1D shows a block diagram of a cluster, according to one embodiment;
FIG. 1E shows a block diagram of “chunk” pool controlled by a centralized metadata controller, according to one embodiment;
FIGS. 2A and 2B show process flow diagrams for managing chunks, according to one embodiment;
FIG. 2C shows an example of metadata;
FIG. 3 shows a process flow diagram for obtaining control of a chunk, according to one embodiment; and
FIG. 4 shows a process flow diagram for gaining control of an active chunk, according to one embodiment.
DETAILED DESCRIPTION
To facilitate an understanding of the various embodiments, the general architecture and operation of a network system will be described. The specific architecture and operation of the preferred embodiment will then be described with reference to the general architecture of the Fibre Channel system.
FIG. 1A shows a top-level block diagram of a system 100 according to one aspect of the present invention. System 100 facilitates communication between plural devices/computing systems. Any device in network system 100 (for example, a Fibre Channel switch or node) can be used to connect plural host systems to plural storage devices. Furthermore, these elements in the network may also perform storage virtualization functions.
Various standards protocols may be used for designing and operating SANs. For example, network nodes in a SAN communicate using a storage protocol that operates on logical blocks of data, such as small computer system interface (SCSI). The SCSI protocol is incorporated herein by reference in its entirety. The storage protocol is delivered, by mapping or encapsulation, using a reliable transport protocol. Fibre Channel is one such standard transport protocol, which is incorporated herein by reference in its entirety.
Fibre channel is a set of American National Standard Institute (ANSI) standards, which provide a serial transmission protocol for storage and network protocols such as HIPPI, SCSI, IP, ATM and others. The Fibre Channel Protocol (FCP) maps SCSI commands to the Fibre Channel transport protocol. Other transport protocols may also support SCSI commands, for example, the SCSI parallel bus, Serial Attached SCSI, TCP/IP, and Infiniband. These standard protocols are incorporated herein by reference in their entirety.
It is noteworthy that although the adaptive aspects of the present invention have been described below with respect to Fibre Channel and SCSI protocols, the present invention is not limited to any particular protocol or standard.
Fibre channel supports three different topologies: point-to-point, arbitrated loop and Fibre Channel Fabric. The point-to-point topology attaches two devices directly. The arbitrated loop topology attaches devices in a loop. The Fibre Channel Fabric topology attaches devices (i.e., host or storage systems) directly to a Fabric, which may consist of multiple Fabric elements.
A Fibre Channel switch device is a multi-port device where each port manages routing of network traffic between its attached systems and other systems that may be attached to other switches in the Fabric. Each port can be attached to a server, peripheral, I/O subsystem, bridge, hub, router, or another switch.
Referring back to FIG. 1A, system 100 includes a plurality of host computing systems (102-104) that are coupled to a storage services platform (SSP) (also referred to as a “node” or “network node”) 101 via SAN 105. Host systems (102-104) typically include several functional components. These components may include a central processing unit (CPU), main memory, input/output (“I/O”) devices, and local storage devices (for example, internal disk drives). The main memory is coupled to the CPU via a system bus or a local memory bus. The main memory is used to provide the CPU access to data and/or program information that is stored in main memory at execution time. Typically, the main memory is composed of random access memory (RAM) circuits. A computer system with the CPU and main memory is often referred to as a host system.
SSP (virtualization module) 101 is coupled to SAN 106 that is operationally coupled to plural storage devices, for example, 107, 108 and 109. SSP 101 provides virtual storage 110A to host systems 102-104, while operating as a virtual host 110B to storage devices 107-109. Virtual storage 110A includes a set of disk blocks presented to a host operating system as a range of consecutively numbered logical blocks with physical disk-like storage and SCSI (or any other protocol based) input/output semantics.
The devices of FIG. 1A are operationally coupled via “links” or “paths”. A path may be established between two N ports. A packet-switched path may be established using multiple links, e.g. an N_Port (for example, virtual host 110B) may establish a path with another N_port (for example, storage devices 107-109) via one or more Fabric elements within SAN 106.
In one aspect, SSP 101 is a multi-port Fabric element in the SAN (e.g., in Fibre Channel, physical ports function as Fx_Ports). As a Fabric element, SSP 101 can process non-blocking Fibre Channel Class 2 (connectionless, acknowledged) and Class 3 (connectionless, unacknowledged) service between any ports.
As a Fabric element, SSP 101 ports are generic to common Fibre Channel port types, for example, F_Port, FL_Port and E_Port. In other words, depending upon what it is attached to, each GL port can function as any type of switch port. Also, the GL port may function as a special port useful in Fabric element linking, as described below.
In another aspect, SSP 101 is a multi-port network node element in a SAN (e.g., in a Fibre Channel based network, physical ports function as Nx_Ports). As a node element, SSP 101 may originate or respond to network communication (e.g., in a Fibre Channel based network, originate or respond to an exchange).
SSP 101 may support both switch ports and node ports simultaneously. The node ports may be supported directly at a physical interface (not shown) or indirectly as a virtual entity that may be reached via one or more of the physical interfaces (not shown) operating as switch ports. For the latter, these virtual node ports are visible to other network elements as if they were physically attached to switch ports on SSP 101.
SSP 101 supports plural upper level protocols, such as SCSI. In the case of SCSI on Fibre Channel (FCP), SSP 101 supports SCSI operation on any of its Nx_Ports. Each SCSI port can support either initiator or target mode operation, or both.
FIG. 1B shows a block diagram of a network system where plural SSPs 101 (SSP1 . . . SSPN) are operationally coupled in a cluster 100A. Each SSP 101 provides virtualization services to different host systems and storage devices. For example, SSP 1 101 provides virtual disk A (110A) (referred to as virtual storage earlier) to host 102, while SSP N provides virtual disk N (110A) to Host 104.
FIG. 1C shows a top-level block diagram of SSP 101. SSP 101 has plural ports (shown as Port 1-Port N (115A, 115B and 115C). The ports allow SSP 101 to connect with host systems and other devices including storage devices, either directly or via a SAN.
SSP 101 includes a data plane (module/component) 111 and a control plane (module/component) 117. Data plane 111 and control plane 117 communicate via control path 116. Control path 116 is a logical communication path that may consist of one or more physical interconnects. In one aspect, control path 116 includes a high speed PCI/PCI-X/PCI-Express bus. In another aspect, control path 116 includes a Fibre Channel connection. It is noteworthy that the adaptive aspects of the present invention are not limited to the type of link 116.
Data plane 111 includes memory (not shown), a backplane 113, plural ports (115A-115C) and plural packet processing engines (PPEs) (shown as 114A-114C). Data plane 111 receives network packets (e.g., command frames, data frames) from host system 102 via plurals ports (115A-115C). PPE (114A-114C) analyzes and modifies network packets, if needed, (e.g., modifying I_T_L and/or logical block address (LBA) for virtualization), and then forwards the packets to their next destination. I_T_Ls are used to process SCSI based commands, where I stands for initiator; T for a target and L for a logical unit number value.
PPEs (114A-114C) may forward packets via any Port 115A-115C by sending them through backplane 113. For example, commands that are autonomously processed by data plane 111, without assistance from control plane 117 are sent directly through back plane 113.
PPEs 114A-114C may also forward packets to control plane 117 via control path 116. For example, commands, which require assistance from control plane 117, are sent via control path 116.
Control plane 117 includes processor 118, memory 119 and a data plane interface 118A. Data plane interface 118A facilitates communication with data plane 113 via control path 116 for example, for sending/receiving commands. In one aspect, data plane interface 118A may include a network adapter, such as a Fibre Channel host bus adapter (HBA). In another aspect, data plane interface 118A includes a bus interface, such as a PCI bridge.
Processor 118 may be a generic microprocessor (for example, Intel® Xeon®)) and an associated chip set (e.g., Intel E7500), a reduced instruction set computer (RISC) or a state machine. Processor 118 executes software for processing input/output (I/O) requests and processing virtual commands.
The following provides an example of processing a virtual command. For example, when host 102 sends a command to write to virtual storage 110A, it is considered a virtual command, since it involves a virtual entity 110A. A physical command involves actual physical entities. The I/O context for the virtual command (i.e. remapped directly to a single corresponding physical command) specifies an association between the “I_T_L_Q” of the virtual command and of the actual physical commands. The “Q” in I_T_L_Q identifies the command type.
SSP 101 provides various storage related services, including, mirroring, snapshots (including copy on write (COW), journaling and others. The term mirror as used herein includes creating an exact copy of disk data written in real time to a secondary array or disk.
The term snapshot means a “point-in-time” copy of block level data. Snapshots are used to restore data accesses to a known good point in time if data corruption subsequently occurs or to preserve an image for non-disruptive tape backup. The term “COW” means copying only that data that has been modified after an initial snapshot has been taken. The term journaling as used herein means an operation that maintains a list of storage writes in a log file.
Metadata for the foregoing operations changes dynamically. The adaptive aspects disclosed herein provide an efficient system and method to manage metadata, as described below.
FIG. 1D shows an example of a system for managing metadata, according to one embodiment. Cluster 100A includes various nodes (SSPs). For example, Nodes 1, 2 and N. Nodes 1 and 2 include a data path agent (DPA) 120 (shown as DPA 1 and DPA 2). Each DPA includes software instructions that are executed by processor 118. DPA 120 provides virtualization services for a plurality of host systems, for example, volume management, data replication, data protection and others.
Node N includes a metadata controller (MDC) 121 for cluster 100A. MDC 121 coordinates actions of all DPAs in different nodes and manages metadata. MDC 121 controls allocation of chunks that are used for persistent storage of metadata, as described below, according to one aspect. The term “chunk” as used herein is persistent storage that is used to store metadata and replicated data. Although Node N shows MDC 121, it also runs a DPA (not shown), i.e. at any given time, all nodes execute a DPA, while one of the nodes executes MDC 121.
FIG. 1E shows a chunk pool 125 with plural chunks 122, 123 and 124. MDC 121 allocates these chunks to DPAs and once a DPA completes writing metadata in the chunk, MDC 121 regains control back from the DPA. If the DPA fails while the chunk is being written, MDC 121 regains control back, even before the entire chunk is written, as described below. It is noteworthy that chunk pool 125 may change statically or dynamically. Furthermore, chunks may not be pre-allocated and instead MDC 121 is aware of available chunk storage and may use a dynamic allocation process to retrieve a chunk when needed.
FIG. 2A shows a process flow diagram for managing metadata chunks, according to one embodiment. The process starts in step S200, when a DPA (for example, 120) requests a chunk from MDC 121 for metadata storage services. In step S202, MDC 121 examines the request from DPA 120 and determines the chunk size that it needs to allocate.
In step S204, MDC 121 allocates a chunk to the request from the chunk pool, for example the chunk pool 125 (FIG. 1E). Steps S202 and S204 are executed as a part of the same transaction, i.e., either both happen or neither step takes place.
In step S206, the chunk is assigned to a virtualization-mapping object in a designated node. Virtual disks are composed of a hierarchical layering of mapping objects. Each mapping object represents a particular transformation of an I/O operation. Each mapping object contains metadata that directs the transformation of individual I/Os.
In step S208, DPA 120 for the designated node gets control of the chunk and DPA 120 populates the chunk with metadata.
FIG. 2B shows a process flow diagram for storing metadata in chunks, according to one embodiment. The process starts in step S210, when a DPA (for example, 120) that gets control of a chunk stores metadata in the assigned chunk.
The following provides examples of metadata that may be used by the various embodiments: (a) “Physical storage container (PSC)”—metadata for this example is an initiator port on an SSP 101, a remote target port, a LUN identifier, and a logical block address (LBA) offset value; (b) Segment map—metadata for this example is a table of fixed size segments, each of which maps a virtual LBA region to an underlying mapping object; (c) Point-in-time: metadata in this example includes a table of fixed size segments, managed by an application to manage COW operations.
After DPA 120 has stored the metadata, control regarding the chunk is passed to MDC 121 in step S212. Thereafter, DPA 120 requests another chunk from MDC 121 in step S214.
FIG. 2C shows an example of metadata 217 for a segment in disk 216. Metadata 217 includes header and version number 218 and is identified as md-bluhdl. Metadata 217 includes various metadata entries (MD entries 219) for example, md_plba (logical block address); UD disk_ID (user data (UD) identifier); UD StartLBA (start of user data LBA); UD size (size of each UD entry); flags; characters and then other metadata entries. The following shows a computer code representation for metadata:
typedef struct dpa_chunk {
    • uint32_t version;
    • uint32_t num_entries;
    • dpa_objhdl_t md_bluhdl;
    • dpa_lba_t md_plba;
    • dpa_objhdl_t ud_bluhdl;
    • dpa_lba_t ud_plba;
    • uint32_t ud_size;
    • uint32_t checkdata;
    • dpa_chunkmd_t *mdentries;
} dpa_chunk_t;
typedef struct dpa_chunkmd {
    • dpa_lba_t vlba;
    • dpa_checkmode_t checkmode;
    • uint32_t checkdata;
} dpa_chunkmd_t;
FIG. 3 shows a process flow diagram for managing chunks when a DPA fails before passing off a chunk to MDC 121, according to one embodiment. The process starts in step S300. In step S302, a DPA fails before passing off a chunk to MDC 121. In step S304, MDC 121 reclaims the control of the allocated chunk, after MDC 121 receives notification of DPA failure. Thereafter, in step S306, when the DPA recovers, it requests another chunk from MDC 121.
FIG. 4 shows a process flow diagram for obtaining control of a chunk, according to one embodiment. The process starts in step S400. In step S402, MDC 121 determines if there is a trigger event to gain control of a chunk from a DPA to MDC 121. In one embodiment, the trigger event my be generated from a user action, for example, creation of a new Point-In-Time copy. If there is no trigger event, the process simply continues to monitor. If yes, then in step S404, MDC 121 sends a request to obtain control of an active chunk. An active chunk is a chunk that at any given time is under control of a DPA and is being written by the DPA.
In step S406, the DPA completes the pending operation and in step S408, the DPA returns control of the chunk to MDC 121. In step S410, MDC 121 stores a flag indicating that it “owns” (i.e. controls) the chunk.
The foregoing embodiments have various advantages. For example, MDC 121 is not aware of any metadata format and simply allocates chunks before the chunk is populated by a DPA. In another aspect, if a DPA fails for whatever reason, MDC 121 obtains control of the chunk.
Although the present invention has been described with reference to specific embodiments, these embodiments are illustrative only and not limiting. Many other applications and embodiments of the present invention will be apparent in light of this disclosure and the following claims.

Claims (12)

1. A method comprising:
providing a cluster of a plurality of storage platforms that are operationally coupled to a plurality of storage devices and to a plurality of client computing systems;
wherein each storage platform presents virtual storage to a client computing system and appears as a virtual computing system to a storage device for providing virtualization services to the client computing system and the storage device; and
wherein one of the storage platforms includes a centralized metadata controller for managing metadata for the plurality of storage platforms;
a data processing agent operating in another of the storage platforms requesting a memory chunk for storing metadata;
the centralized metadata controller for the plurality of storage platforms operating in the one of the storage platforms receiving the request for the memory chunk;
the centralized metadata controller determining the memory chunk size and allocating the memory chunk from a pool of memory chunks managed by the centralized metadata controller;
the centralized metadata controller assigning the allocated memory chunk to a virtualization mapping object of the storage platform executing the data processing agent that requested the memory chunk; and
the data processing agent of the another storage platform obtains control of the allocated memory chunk and populates the memory chunk with metadata.
2. The method of claim 1, wherein the data processing agent of the another storage platform passes control of the memory chunk to the metadata controller after the data processing agent has completed storing the metadata.
3. The method of claim 1, wherein if the data processing agent fails before passing off control of the memory chunk to the metadata controller then the metadata controller reclaims control of the memory chunk.
4. The method of claim 3, wherein the metadata controller stores the memory chunk after reclaiming control.
5. A storage area network, comprising:
a plurality of virtualization modules that are coupled together in a cluster;
wherein the plurality of virtualization modules are operationally coupled to a plurality of storage devices and to a plurality of client computing systems, and each virtualization module presents virtual storage to a client computing system and appears as a virtual computing system to a storage device for providing virtualization services to the client computing system and the storage device; and
wherein each virtualization module runs a data processing agent for providing the virtualization services, and one of the virtualization modules runs a centralized metadata controller for the cluster that controls allocation of memory chunks to store metadata; and
wherein the metadata controller receives a request for a memory chunk from the data processing agent of another one of the virtualization modules, determines the memory chunk size, allocates the memory chunk from a pool of memory chunks, and assigns the allocated memory chunk to a virtualization mapping object of the another virtualization module; and
wherein the data processing agent of the another virtualization module gets control of the allocated memory chunk and populates the memory chunk with the metadata.
6. The storage area network of claim 5, wherein the data processing agent of the another virtualization module passes control of the memory chunk to the metadata controller after the data processing agent has completed storing the metadata.
7. The storage area network of claim 6, wherein if the data processing agent fails before passing off control of the memory chunk to the metadata controller then the metadata controller reclaims control of the memory chunk.
8. The storage area network of claim 7, wherein the metadata controller stores the memory chunk after reclaiming control.
9. A virtualization module coupled to other virtualization modules in a cluster, comprising:
a data processing agent executed by each of the virtualization modules for providing virtualization services;
wherein the plurality of virtualization modules are operationally coupled to a plurality of storage devices and to a plurality of client computing systems, and each virtualization module presents virtual storage to a client computing system and appears as a virtual computing system to a storage device for providing the virtualization services to the client computing system and the storage device; and
a centralized metadata controller for the cluster that runs in one of the virtualization modules and controls allocation of memory chunks to store metadata; and the metadata controller receives a request for a memory chunk from the data processing agent of another one of the virtualization modules, determines the memory chunk size, allocates the memory chunk from a pool of memory chunks, and assigns the allocated memory chunk to a virtualization mapping object of the another virtualization module; and
wherein the data processing agent of the another virtualization module gets control of the allocated memory chunk and populates the memory chunk with the metadata.
10. The virtualization module of claim 9, wherein the data processing agent passes control of the memory chunk to the metadata controller after the data processing agent has completed storing the metadata.
11. The virtualization module of claim 10, wherein if the data processing agent fails before passing off control of the memory chunk to the metadata controller then the metadata controller reclaims control of the memory chunk.
12. The virtualization module of claim 11, wherein the metadata controller stores the memory chunk after reclaiming control.
US11/694,698 2007-03-30 2007-03-30 Method and system for managing metadata in storage virtualization environment Active 2029-01-08 US8185715B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/694,698 US8185715B1 (en) 2007-03-30 2007-03-30 Method and system for managing metadata in storage virtualization environment

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US11/694,698 US8185715B1 (en) 2007-03-30 2007-03-30 Method and system for managing metadata in storage virtualization environment

Publications (1)

Publication Number Publication Date
US8185715B1 true US8185715B1 (en) 2012-05-22

Family

ID=46061370

Family Applications (1)

Application Number Title Priority Date Filing Date
US11/694,698 Active 2029-01-08 US8185715B1 (en) 2007-03-30 2007-03-30 Method and system for managing metadata in storage virtualization environment

Country Status (1)

Country Link
US (1) US8185715B1 (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120185618A1 (en) * 2011-01-13 2012-07-19 Avaya Inc. Method for providing scalable storage virtualization
US20130041872A1 (en) * 2011-08-12 2013-02-14 Alexander AIZMAN Cloud storage system with distributed metadata
US20130204849A1 (en) * 2010-10-01 2013-08-08 Peter Chacko Distributed virtual storage cloud architecture and a method thereof
US8849759B2 (en) 2012-01-13 2014-09-30 Nexenta Systems, Inc. Unified local storage supporting file and cloud object access
CN109542342A (en) * 2018-11-09 2019-03-29 锐捷网络股份有限公司 Metadata management and data reconstruction method, equipment and storage medium
US12001355B1 (en) 2019-05-24 2024-06-04 Pure Storage, Inc. Chunked memory efficient storage data transfers

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020049731A1 (en) * 2000-05-31 2002-04-25 Takuya Kotani Information processing method and apparatus
US20020059309A1 (en) * 2000-06-26 2002-05-16 International Business Machines Corporation Implementing data management application programming interface access rights in a parallel file system
US20020184463A1 (en) * 2000-07-06 2002-12-05 Hitachi, Ltd. Computer system
US20030028514A1 (en) * 2001-06-05 2003-02-06 Lord Stephen Philip Extended attribute caching in clustered filesystem
US20070055702A1 (en) * 2005-09-07 2007-03-08 Fridella Stephen A Metadata offload for a file server cluster

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020049731A1 (en) * 2000-05-31 2002-04-25 Takuya Kotani Information processing method and apparatus
US20020059309A1 (en) * 2000-06-26 2002-05-16 International Business Machines Corporation Implementing data management application programming interface access rights in a parallel file system
US20020184463A1 (en) * 2000-07-06 2002-12-05 Hitachi, Ltd. Computer system
US20030028514A1 (en) * 2001-06-05 2003-02-06 Lord Stephen Philip Extended attribute caching in clustered filesystem
US20070055702A1 (en) * 2005-09-07 2007-03-08 Fridella Stephen A Metadata offload for a file server cluster

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130204849A1 (en) * 2010-10-01 2013-08-08 Peter Chacko Distributed virtual storage cloud architecture and a method thereof
US9128626B2 (en) * 2010-10-01 2015-09-08 Peter Chacko Distributed virtual storage cloud architecture and a method thereof
US20120185618A1 (en) * 2011-01-13 2012-07-19 Avaya Inc. Method for providing scalable storage virtualization
US20130041872A1 (en) * 2011-08-12 2013-02-14 Alexander AIZMAN Cloud storage system with distributed metadata
US8533231B2 (en) * 2011-08-12 2013-09-10 Nexenta Systems, Inc. Cloud storage system with distributed metadata
US8849759B2 (en) 2012-01-13 2014-09-30 Nexenta Systems, Inc. Unified local storage supporting file and cloud object access
CN109542342A (en) * 2018-11-09 2019-03-29 锐捷网络股份有限公司 Metadata management and data reconstruction method, equipment and storage medium
CN109542342B (en) * 2018-11-09 2022-04-26 锐捷网络股份有限公司 Metadata management and data reconstruction method, equipment and storage medium
US12001355B1 (en) 2019-05-24 2024-06-04 Pure Storage, Inc. Chunked memory efficient storage data transfers

Similar Documents

Publication Publication Date Title
US11249857B2 (en) Methods for managing clusters of a storage system using a cloud resident orchestrator and devices thereof
US9032164B2 (en) Apparatus for performing storage virtualization
US9639277B2 (en) Storage system with virtual volume having data arranged astride storage devices, and volume management method
US7447197B2 (en) System and method of providing network node services
US9311001B1 (en) System and method for managing provisioning of storage resources in a network with virtualization of resources in such a network
RU2302034C2 (en) Multi-protocol data storage device realizing integrated support of file access and block access protocols
EP2247076B1 (en) Method and apparatus for logical volume management
US8452923B2 (en) Storage system and management method thereof
US10769024B2 (en) Incremental transfer with unused data block reclamation
US9098466B2 (en) Switching between mirrored volumes
US7315914B1 (en) Systems and methods for managing virtualized logical units using vendor specific storage array commands
US8782245B1 (en) System and method for managing provisioning of storage resources in a network with virtualization of resources in such a network
US20240045807A1 (en) Methods for managing input-output operations in zone translation layer architecture and devices thereof
JP2007141216A (en) System, method and apparatus for multiple-protocol-accessible osd storage subsystem
US8266191B1 (en) System and method for flexible space reservations in a file system supporting persistent consistency point image
US10855556B2 (en) Methods for facilitating adaptive quality of service in storage networks and devices thereof
JP5352490B2 (en) Server image capacity optimization
US9158637B2 (en) Storage control grid and method of operating thereof
US8185715B1 (en) Method and system for managing metadata in storage virtualization environment
US10620843B2 (en) Methods for managing distributed snapshot for low latency storage and devices thereof
US9875059B2 (en) Storage system
US8127307B1 (en) Methods and apparatus for storage virtualization system having switch level event processing
US10872036B1 (en) Methods for facilitating efficient storage operations using host-managed solid-state disks and devices thereof
US10782889B2 (en) Fibre channel scale-out with physical path discovery and volume move
US7299332B1 (en) System and method for managing sessions and allocating memory resources used for replication of data in a data storage environment

Legal Events

Date Code Title Description
AS Assignment

Owner name: QLOGIC, CORPORATION, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CHOW, WILLIAM W.;LOGAN, JOHN;REEL/FRAME:019095/0768

Effective date: 20070329

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: JPMORGAN CHASE BANK, N.A., AS COLLATERAL AGENT, IL

Free format text: SECURITY AGREEMENT;ASSIGNOR:QLOGIC CORPORATION;REEL/FRAME:041854/0119

Effective date: 20170228

AS Assignment

Owner name: CAVIUM, INC., CALIFORNIA

Free format text: MERGER;ASSIGNOR:QLOGIC CORPORATION;REEL/FRAME:044812/0504

Effective date: 20160615

AS Assignment

Owner name: CAVIUM, INC, CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JP MORGAN CHASE BANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:046496/0001

Effective date: 20180706

Owner name: QLOGIC CORPORATION, CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JP MORGAN CHASE BANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:046496/0001

Effective date: 20180706

Owner name: CAVIUM NETWORKS LLC, CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JP MORGAN CHASE BANK, N.A., AS COLLATERAL AGENT;REEL/FRAME:046496/0001

Effective date: 20180706

AS Assignment

Owner name: CAVIUM, LLC, CALIFORNIA

Free format text: CHANGE OF NAME;ASSIGNOR:CAVIUM, INC.;REEL/FRAME:047205/0953

Effective date: 20180921

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

AS Assignment

Owner name: CAVIUM INTERNATIONAL, CAYMAN ISLANDS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CAVIUM, LLC;REEL/FRAME:051948/0807

Effective date: 20191231

AS Assignment

Owner name: MARVELL ASIA PTE, LTD., SINGAPORE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:CAVIUM INTERNATIONAL;REEL/FRAME:053179/0320

Effective date: 20191231

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12