The present invention relates to data storage generally and, more particularly, to a method and/or apparatus for implementing remote data mirroring using a virtualized I/O path in a SAS switch.
Conventional storage systems do not support remote mirroring of Serial Attached SCSI (SAS) storage array controllers. In a local mirror operation, the input/output (I/O) path residing inside the SAS storage array controller implements the input/output mirroring. Such mirroring creates overhead to the controller input/output operations and can add to the performance bottleneck in large storage infrastructures.
It would be desirable to implement a system and method for remote data mirroring using a virtualized input/output path in a SAS switch.
The present invention concerns an apparatus comprising a first switch and a second switch. The first switch may include a first plurality of ports, where a first of the ports is connected to a first host device, a second of the ports is connected to a first target device, and a third of the ports is connected to a network. The first target device may include a first storage LUN. The second switch may include a second plurality of ports, where a first of the ports is connected to a second host device, a second of the ports is connected to a second target device, and a third of the ports is connected to the network. The second target device may include a second storage LUN. The first storage LUN and the second storage LUN form a data mirror.
The objects, features and advantages of the present invention include providing a system and method for remote data mirroring using a virtualized I/O path in a SAS switch that may (i) perform LUN mirroring of I/O block processing at an IOV layer in the SAS switch, (ii) act as a virtual target to an actual host and/or as a virtual initiator to an actual target; (iii) provide dedicated mirror ports in the SAS switch, (iv) provide dedicated mirror ports in the SAS switch capable of multi-protocol routing, (v) be discovered and configured for remote volume/LUN mirroring through multiprotocol convertor ports, (vi) provide volume/LUN mirroring to a SAS storage array connected locally to the same SAS switch or to a remote SAS storage array connected to a remote SAS switch through the dedicated mirror ports, (vii) be configured as a redundant SAS switch for another intelligent SAS switch, (viii) provide redundancy in the SAS switch, (ix) reduce the load on an SAS storage controller needed to process the volume/LUN mirror, (x) provide remote volume/LUN mirror capability in SAS storage array controllers, (xi) provide redundancy at the SAS switch level for disaster recovery, (xii) provide LUN mirroring at the same storage array and also at a different array (e.g., a remote or local array) and/or (xiii) provide local mirroring within a fixed distance in the same location using active port functionality on the SAS switch.
These and other objects, features and advantages of the present invention will be apparent from the following detailed description and the appended claims and drawings in which:
Storage virtualization separates the logical representation of data storage from the physical storage components. By provisioning storage at the SAS switch level, the present invention may enable high availability and/or scalability and/or provide substantial improvement in managing a variety of storage arrays. The present invention may be implemented as part of a Serial Attached SCSI (SAS) storage array controller, or as a stand alone application. In one embodiment, a device may be implemented to operate in a heterogeneous environment. The heterogenous environment may include servers and/or storage devices from various vendors. Storage may be flexibly allocated to the servers and/or storage applications through a software program on the SAS switch.
Referring to
The intelligent SAS switch 104 may implement initiator, target and/or logical unit operations. In one example, the switch 104 may implement Initiator Target LUN (ITL) nexus operations. The switch 104 may act as a virtual initiator to one or more physical SAS targets (e.g., the target array 106). Each device in a network (e.g., SCSI, FC, SAS, iSCSI, etc.) may have an ITLX nexus, where X is a queue ID. The switch 104 may also operate as a virtual target for one or more physical hosts. The IOV layer 110 may be linked to the target array 106 through a hardware abstract layer (e.g., an Interlink Layer) located in the SAS layer 108. The target array 106 may be implemented as any SAS physical target.
The system 100 may include an intelligent SAS switch 104 implementing an input/output (I/O) data path virtualization layer linked to one or more SAS storage array controllers (e.g., the target array 106) through interlink layers 108, 110 and/or 112. The I/O path virtualization layer may implement host side LUN mapping and/or other mapping to connect one or more LUNs (e.g., the LUN 114) to one or more hosts (e.g. the host 102). A LUN may refer to a logical unit number that may represent a volume formed by one or more storage devices.
When a user initiates a mirror operation for a particular LUN, the IOV layer 110 may mirror the data and/or write the data to the respective local and/or remote destinations (e.g., the target array 114). In the case of a remote destination, the IOV layer 110 may transfer the I/O data remotely through a dedicated multi-protocol converter in the multi-protocol converter layer 112. The multi-protocol convert layer may mirror ports to a similar remote intelligent SAS switch. The IOV layer 110 may write data to the target array 106 connected to the SAS switch 104. In one example, the switch 104 may be a remote intelligent SAS switch.
Referring to
Referring to
A number of I/O blocks may be mirrored by the IOV layer 110 before being written to the SAS physical targets (e.g., target devices 106a and/or 106b). The mirrored I/O blocks may be written to a local SAS target array 106a (located in the local site 100a and/or 100c) or a remote SAS target array 106b (e.g., located in the local site 100b). To implement a remote SAS array mirror, the IOV layer 110 may use the multi-protocol converter layer 112. Multi-protocol routing may be performed by encapsulating the SAS I/O data frames in fiber channel (FC), Internet Small Computer System Interface (iSCSI), and/or other protocol implemented for a respective network. The ports 130a-130n and/or 132a-132n in the SAS switch 104 may support one or more specific protocols. The encapsulated frames may be received at the remote intelligent SAS switch 104b. The encapsulated frames may be de-capsulated and written to the remote target SAS array 106b.
The IOV layer 110 may present the ports 130a-130n and 132a-132n on the intelligent SAS switch 104 as initiator ports. The storage array 106 may map the ports 130a-130n and 132a-132n as virtual initiator ports in the storage management software. The LUN 114 from the storage array 106 may be mapped to the virtual initiator ports 130a-130n and 132a-132n. The IOV layer 110 may also determine the unique array identifier (UAID) while discovering the LUN 114 through regular SCSI commands. The IOV layer 110 may comprise a list of LUNs. The list of LUNs may be mapped to the virtual initiators from different storage arrays.
A corresponding virtual target identifier may be created for each virtual initiator identifier. The virtual target identifier may be generated by the IOV layer 110. The virtual target identifier may be based on the SAS address of the switch ports 130a-130n and/or 132a-132n connected to the initiators. The virtual target may presented to the actual initiators or the host/server 102. The IOV layer 110 on the intelligent SAS switch 104 may allow the LUN 114 to be available to the actual initiators using virtual target identifications. A user may configure the LUNs 114a-114d from the various targets to the initiators as required.
In one example, the LUNs 114a-114d may be from the same targets. In another example, the LUNs 114a-114d may be from remote SAS arrays. The target devices 106a and/or 106b may be mapped to the initiators 102a and/or 102b to allow communication between the target devices 106a and/or 106b and initiators 102a and/or 102b.
A routing table may be implemented to route the I/Os to the actual storage (e.g., target 106). The routing table may map the initiator 102 to the LUN 114 from a specific virtual storage array to/from the actual storage array UAID of the array. An example of the routing table may be implemented according to the following TABLE 1:
TABLE 1 may be created when a user creates an initiator, virtual target and/or LUN mapping.
I/O data may be stripped to determine the source SAS address, the LUN number to which the I/O is being sent, and/or the virtual target identifier (e.g., the target SAS address) each time an I/O us received from the initiator 102. Once the IOV layer 110 has received the target identifier information, the IOV layer 110 may refer to the routing table and determine the mapping of the actual initiator to the virtual target, the virtual initiator, and/or the actual target. Once the route is determined, the I/O may be acknowledged. Each I/O data frame may be rerouted before I/O data reaches a physical disk on the target array 106. Such rerouting may minimize overhead when stripping each I/O data frame.
A similar process may be repeated when I/O returns from the target 106. The mapping of the actual target to the virtual initiator, the virtual target, and/or the actual initiator may be determined by the IOV layer 110.
Data may be mirrored on an LUN (e.g., the LUN 114a) to another LUN in the same array (e.g., the LUN 114b) or any other array on the network (e.g. the LUN 114d) using the mapping data. LUN mirroring may be implemented across the same storage array or a different storage array. The mirrored LUN generally comprises similar properties as the base LUN. A list of similar LUNs may be created based on the properties of the LUNs at the time of the initiator mapping. The LUNs 114a-114d may be made available from the same storage array, from different arrays in the same location, and/or in different locations. Remote volume mirroring may be implemented using the systems 100a-100c. The I/O blocks to the LUNs 114a, 114b, 114c and/or 114d may be mirrored by the IOV layer 110. The mirror I/O block may be written to the local and/or the remote SAS storage array (e.g., the target device 106b).
Redundancy may be maintained at one or more SAS switch levels. The switch 100a may be configured as a redundant switch for the switch 100b and/or the switch 100c. Disaster recovery of the local site 100a and/or 100b may be implemented through the remote site location 100b with an SAS storage array 106b. The switches 104a and/or 104b may provide high availability and/or high fault tolerance.
A user may select an option for the remote SAS storage array target 106. The IOV layer 110 may encapsulate the I/O blocks to related protocols (e.g., FC, ISCSI, FCoE, etc.) using the multi-protocol ports 132a-132n. The ports 132a-132n may be dedicated mirror ports. The ports 132a-132n may de-capsulate the I/O block and write the mirror I/O blocks to the remote SAS storage array target 106.
The system 100 may implement a virtualized I/O path in the SAS switch 104. The same I/O path for the I/O block mirror may be utilized at the IOV layer 110. The multi-protocol ports 132a-132n may be implemented on the SAS switch 104 for remote intelligent SAS switch and/or SAS storage array discovery. The multi-protocol converter layer 112 may implement a remote volume/LUN mirror on the SAS storage array 106.
The functions performed by the diagrams of
The present invention may also be implemented by the preparation of ASICs (application specific integrated circuits), Platform ASICs, FPGAs (field programmable gate arrays), PLDs (programmable logic devices), CPLDs (complex programmable logic device), sea-of-gates, RFICs (radio frequency integrated circuits), ASSPs (application specific standard products), one or more monolithic integrated circuits, one or more chips or die arranged as flip-chip modules and/or multi-chip modules or by interconnecting an appropriate network of conventional component circuits, as is described herein, modifications of which will be readily apparent to those skilled in the art(s).
The present invention thus may also include a computer product which may be a storage medium or media and/or a transmission medium or media including instructions which may be used to program a machine to perform one or more processes or methods in accordance with the present invention. Execution of instructions contained in the computer product by the machine, along with operations of surrounding circuitry, may transform input data into one or more files on the storage medium and/or one or more output signals representative of a physical object or substance, such as an audio and/or visual depiction. The storage medium may include, but is not limited to, any type of disk including floppy disk, hard drive, magnetic disk, optical disk, CD-ROM, DVD and magneto-optical disks and circuits such as ROMs (read-only memories), RAMS (random access memories), EPROMs (electronically programmable ROMs), EEPROMs (electronically erasable ROMs), UVPROM (ultra-violet erasable ROMs), Flash memory, magnetic cards, optical cards, and/or any type of media suitable for storing electronic instructions.
The elements of the invention may form part or all of one or more devices, units, components, systems, machines and/or apparatuses. The devices may include, but are not limited to, servers, workstations, storage array controllers, storage systems, personal computers, laptop computers, notebook computers, palm computers, personal digital assistants, portable electronic devices, battery powered devices, set-top boxes, encoders, decoders, transcoders, compressors, decompressors, pre-processors, post-processors, transmitters, receivers, transceivers, cipher circuits, cellular telephones, digital cameras, positioning and/or navigation systems, medical equipment, heads-up displays, wireless devices, audio recording, storage and/or playback devices, video recording, storage and/or playback devices, game platforms, peripherals and/or multi-chip modules. Those skilled in the relevant art(s) would understand that the elements of the invention may be implemented in other types of devices to meet the criteria of a particular application.
While the invention has been particularly shown and described with reference to the preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made without departing from the scope of the invention.