This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2003-052517, filed on Feb. 28, 2003, the entire contents of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates to a storage control apparatus and a method thereof for actually accessing a physical storage device constituting a logical unit according to the access request from the host in the units of the logical unit, and more particularly to a storage control apparatus which constitutes a large logical unit by concatenating a plurality of logical units, and a method thereof.
2. Description of the Related Art
In a storage device using such a storage medium as a magnetic disk, magneto-optical disk and optical disk, the storage medium is actually accessed by the request of the data processor. If the data processor uses large capacity data, a storage system comprising a plurality of storage devices and a control apparatus for controlling the storage devices is used.
In such a storage system, the host recognizes the physical disk unit in the units of the logical unit (or logical volume). Depending on the capability of the control apparatus, the capacity of the logical unit is limited.
As
The CAs 120, 122, 124 and 126 are connection modules with the host 100, and the CM 128, 130 includes a cache memory and controls the disk. The CM 128, 130 controls the logical unit 140, 150. The logical unit 140, 150 is comprised of a single or a plurality of physical disk devices which constitutes the logical volume.
For the connection format of the CM 128, 130 and the logical unit 140, 150, the maximum number of logical units (number of physical disks) that can be connected to one CM is limited, considering the load distribution specified depending on the capability of the controller of the CM 128, 130 and the size of the cache memory, and one logical unit is not connected to a plurality of CMs.
In other words, in order to improve the response of host access, a cache memory is disposed in the CM 128, 130, and stores a part of the data of the disk device which the respective CM charges, and the write data from the host.
In other words, when read access is received from the host, the data of the cache memory is read and transferred without actually accessing the disk apparatus if the target data is staged in the cache memory. When write access is received from the host, the write data is written to the cache memory, and the writing is completed. The write data in the cache memory is written back to the target disk device during processing idle time.
If the cache memory is installed to improve host access in this way, the load must be distributed with limiting the number of logical units to be connected to one CM, since the size of the cache memory is limited, and the capability of the controller is also limited.
However, some users have the demand to increase the capacity of the logical unit when viewed from the host side. Therefore conventionally a method for concatenating a plurality of logical units 140 and 142 to be connected to one CM 128, so that the host 100 recognizes them as one large logical unit LU0, has been provided, as shown in
With this prior art, however, a plurality of logical units cannot be concatenating under one CM, so the load of the CM for controlling the concatenated large capacity logical unit increases, which may drop host access performance.
Also in the case of a system which has a plurality of CMs, the logical units to be concatenated must be under one CM, so the number of logical units to be concatenated is limited, and constructing a flexible large capacity logical unit is difficult.
With the foregoing in view, it is an object of the present invention to provide a storage control apparatus and a control method for preventing the increase of load of the controller, even if the logical units are concatenated.
It is another object of the present invention to provide a storage control apparatus and a control method for removing restrictions of the logical units to be concatenated, and constructing a flexible large capacity logical unit.
It is still another object of the present invention to provide a storage control apparatus and a control method thereof for preventing a drop in host access performance, even if the logical units are concatenated.
To achieve these objects, the storage control apparatus of the present invention is a storage control apparatus for accessing data of a logical unit, which is comprised of a single or a plurality of physical units, by a request from a host, having a channel adapter for interfacing with the host, and a plurality of controllers which charge each one of a plurality of logical units, wherein the channel adapter sends an I/O request to one controller which charges one logical unit constituting the concatenation logical unit concatenating the plurality of logical units, out of the plurality of controllers when the host sends an I/O request to the concatenation logical unit, performs the I/O processing in the one controller, then sends the I/O request to another controller which charges another logical unit constituting the concatenated logical unit, and executes the I/O processing in the other controller.
The storage control method of the present invention is a storage control method for accessing data of a logical unit, which is comprised of a single or a plurality of physical units, by a request from a host, having steps of: receiving an I/O request from the host to a concatenation logical unit concatenating a plurality of logical units using a channel adapter; sending the I/O request from the channel adapter to one controller which charges one logical unit constituting the concatenated logical unit out of a plurality of controllers which charges the plurality of logical units, and executing I/O processing in the one controller; and sending the I/O request from the channel adapter to another controller, which charges another logical unit constituting the concatenation logical unit, and executing the I/O processing in the other controller.
In the present invention, logical units extending over a plurality of controllers can be concatenated by data request processing to the plurality of controllers, so the load of I/O processing of a concatenation LU (Logical Unit) in the controllers can be distributed. In other words, the logical units can be concatenated without increasing the performance of the controller and the size of the cache memory. Also flexibility of selecting the logical units to be concatenated increases, a flexible large capacity LU can be constructed, and user convenience can be improved.
In the present invention, it is preferable that the one controller judges for the channel adapter whether the I/O request is an I/O request extending over to another controller, which charges another logical unit constituting the concatenation logical unit after the I/O processing, and responds the judgment result to the channel adapter.
In this aspect, the controller judges whether the I/O request extends over to another controller of another logical unit constituting the concatenation logical unit, so the load of the channel adapter can be decreased, and the I/O request can be accepted without allowing the host to wait.
In the present invention, it is preferable that each of the controllers has a table for storing the LBA range of each logical unit, and refers to this table in the LBA range requested by the I/O request and judges whether the I/O request is an I/O request extending over to another controller, which charges another logical unit constituting the concatenation logical unit, so whether the I/O request extends over to another controller can be easily judged by referring to a table.
Also in the present invention, it is preferable that the channel adapter sends the I/O request to the other controller according to the response that the I/O request extends from the one controller to the other controller, so the channel adapter can easily execute the I/O processing extending over controllers by a message response.
Also in the present invention, it is preferable that the channel adapter has a table for storing the controllers corresponding to each logical unit, the LBA range of each logical unit and the logical units constituting the concatenation logical unit, and selects the controller of the corresponding logical unit when an I/O request is received from the host. Therefore the channel adapter can easily select the controller of the logical unit corresponding to the I/O request from the host.
Also in the present invention, it is preferable that each controller further has a cache memory for storing a part of the data of the logical unit which each controller charges, and a processing section for executing I/O processing using the cache memory according to the I/O request. By this, even an I/O request which extends over the controllers can be I/O processed at high-speed.
Also in the present invention, it is preferable that the channel adapter has a plurality of channel adapters for connecting the plurality of controllers, therefore the concatenation LU access of a plurality of hosts becomes possible.
Embodiments of the present invention will now be described in the sequence of the storage system, I/O processing and other embodiments.
[Storage System]
The storage control apparatus 1 is comprised of function modules of a plurality of CAs (Channel Adapters) 10, 11, . . . , 1n, a plurality of CMs (Centralized Modules) 20, 30, and a plurality of DAS (Device Adapters) 40, . . . 4n.
The CA (Channel Adapter) 10, 11, . . . or 1n is a circuit for controlling the host interface connecting the host 3, and is comprised of a fiber channel circuit (FC), CPU 52, and control table 50 (described later in
The CM (Centralized Module) 20, 30 is comprised of a CPU (Central Processor Unit) 22, 32, cache memory 24, 34 and control table 26, 36 (described later in
The CM 20 charges the disk apparatus 2 of the logical unit LU0, and the CM 30 charges the disk apparatus 2 of the logical unit LUn. In
The CPU 22 receives the read request from the host 3 via the CAs 10, 11, . . . , 1n, refers to the cache memory 24, judges whether access to the physical disk is necessary, and if necessary, requests the disk access request to the DA 40. The CPU 22 also receives the write request from the host 3, writes the write data to the cache memory 24, and requests a write back, which is scheduled internally, to the DA 40.
In the same way, in the CM 30 as well, the CPU 32 receives the read request from the host 3 via the CAs 10, 11, . . . , 1n, refers to the cache memory 34, judges whether access to the physical disk is necessary, and if necessary, requests the disk access request to the DA 4n. The CPU 32 also receives the write request from the host 3, writes the write data to the cache memory 34, and requests a write back, which is scheduled internally, to the DA 4n.
In the CAs 10, 11, . . . , 1n, the control table 50, shown in
In other words, the control table 50 of the CA 10 stores the logical unit number which the host 3 recognizes, the corresponding logical unit number which the storage system recognizes, the CM model number which charges this logical unit, the concatenation logical unit number which is defined for the logical units of one host, and the stored space (start and end logical block addresses) of each logical unit of the storage system.
In the CM 20 (30), the control table 26 (36) shown in
[I/O Processing]
Now the I/O processing of CA 10, . . . , 1n and the CM 20 (30) using the above mentioned control tables 50 and 26 (36) will be described.
At first the host request acceptance processing of the CA will be described with reference to
(S10) The CA 10 receives a read or write I/O request from the host 3.
(S12) The CPU 52 of the CA 10 determines the Concatenation LU Number from the host request LU Number using the CA control table 50 (
(S14) The CPU 52 of the CA 10 determines the CM Number of the CM in-charge from the host request LBA using the CA control table 50 (
(S16) The CA 10 sends the data request:message to the CM in-charge. This data request message includes the above mentioned Concatenation LU Number, I/O request LBA (start LBA), and I/O request range. And processing ends.
Now the data allocation processing of the CM will be described with reference to
(S20) The CM 20 receives the data request message from the CA 10.
(S22) The CPU 22 of the CM 20 checks whether the host request data exists using the management information of the cache memory 24.
(S24) The CPU 22 of the CM 20 advances to step S26 if the requested data exists in the cache memory 24. If the requested data does not exist in the cache memory 24, on the other hand, the CPU 22 executes miss hit processing. In other words, the CPU 22 stages the data from the physical disk 2 constituting the target logical disk to the cache memory 24 via the DA 40.
(S26) When the requested data is allocated to the cache memory 24 in this way, the CM 20 returns the data allocation response to the requesting source CA 10. This data allocation response includes the data storage cache address. And processing ends.
Now the data transfer processing of the CA will be described with reference to
(S30) The CA 10 receives the data allocation response from the CM 20.
(S32) The CPU 52 of the CA 10 DMA-controls the cache memory 24 of the CM 20 using the above mentioned data storage address, and transfers the allocated data to the host 3.
(S34) When the transfer of allocated data ends, the CPU 52 of the CA 10 sends the data transfer completion message to the CM 20. And processing ends.
Now the data transfer completion message processing of the CM will be described with reference to
(S40) The CM 20 receives the data transfer completion message from the CA 10.
(S42) The CPU 22 of the CM 20 refers to the CM control table 26 (
(S44) If the I/O request does not extend over a plurality of CMs, the CPU 22 of the CM 20 sets the concatenation flag to “OFF”. If it is judged that the I/O request extends over a plurality of CMs, on the other hand, the CPU 22 sets the concatenation flag to “ON”. And the CPU 22 refers to the CM control table 26 (
(S46) After this check ends, the CM 20 sends the I/O concatenation message to the CA 10 which issued the request. This I/O concatenation message includes the above mentioned concatenation flag and the concatenated CM model number. And processing ends.
Now the I/O concatenation processing of the CA will be described with reference to
(S50) The CA 10 receives the I/O concatenation message from the CM 20.
(S52) The CPU 52 of the CA 10 judges whether the concatenation flag in the I/O concatenation message is “ON”. If this flag is not “ON”, the CA 10 responds the I/O processing completion status to the host 3. And processing ends.
(S54) If the concatenation flag is ON, on the other hand, the CPU 52 sends the data request message again to the CM with the concatenated CM model number in the I/O concatenation message. And processing ends.
The CM which received this data request message executes the processing in
A concrete example of this I/O processing will be described with reference to
As
Also as
Also as
Then after I/O processing ends, the CM 20 refers to the CM control table 26, and recognizes that the processing must be continued to another LU, and notifies this message to the CA 11. This message includes the information on which CM continues the processing (CM 30 in this case). Then CA 11 sends the I/O data request to the CM 30 by this notified message.
In this way, LUS extending over a plurality of CMs can be concatenated by data request processing to the plurality of CMs, so the load of the I/O processing of the concatenation LU of the CM can be distributed, as shown in
Also the flexibility in selecting logical units to be concatenated increases, a flexible large capacity LU can be constructed, and user convenience can be improved.
The present embodiment can be implemented merely by adding a control table and data transfer completion message processing of the CM, and can be easily implemented without dropping performance very much. The present embodiment can also be implemented by such a simple method as a message.
[Other Embodiments]
In the above embodiment, the I/O request was described using the case of a read access, but write access can also be executed in similar processing. The above embodiment was described using a RAID with the redundant configuration shown in
One concatenation LU was used for the description, but the present invention can be applied to a plurality of concatenation LUs, as shown in the control tables in
The present invention was described using embodiments, but the present invention can be modified in various ways within the scope of the essential character of the present invention, which shall not be excluded from the scope of the present invention.
In this way, according to the present invention, LUs extending over a plurality of CMs can be concatenated by the data request processing to the plurality of CMs, so the load of the I/O processing of the concatenation LU of the CM can be distributed. In other words, logical units can be concatenated without increasing the performance of the controller of the CM and the size of the cache memory.
Also flexibility in selecting logical units to be concatenated increases, a flexible large capacity LU can be constructed, and user convenience can be improved. Also the performance of the controller itself can be improved.
Number | Date | Country | Kind |
---|---|---|---|
2003-52517 | Feb 2003 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5423046 | Nunnelley et al. | Jun 1995 | A |
6009481 | Mayer | Dec 1999 | A |
6948010 | Somers et al. | Sep 2005 | B1 |
20030182503 | Leong et al. | Sep 2003 | A1 |
Number | Date | Country |
---|---|---|
61-136123 | Jun 1986 | JP |
6-004451 | Jan 1994 | JP |
WO9959064 | Nov 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20040186924 A1 | Sep 2004 | US |