This application claims the benefit of Japanese Application No. 2008-183555, filed on Jul. 15, 2008, in the Japan Patent Office, the disclosure of which is incorporated herein by reference.
The present invention relates to a copying technique in association with a storage system, more particularly, to a system including a plurality of storage devices (storage volumes), and copying data for backup and mirroring between the plurality of storage volumes.
Hitherto, in the field of disk array devices such as devices based on Redundant Arrays of Inexpensive Disks (RAID), there is a technique for copying data to another disk array device, which is constituted in the form of another housing, to perform operations such as duplexing (synchronization; Equivalent Copy) of the data for backup and mirroring.
The duplexing of data is performed in accordance with an instruction from a host that is a higher-level device with respect to the disk array device. One example of a copying method is an asynchronous method of replying with a completion report in response to the instruction, which is issued from the host for duplexing (copying), to the host at once in an asynchronous relation to the completion of actual duplexing, and then executing the actual duplexing (see, e.g., Japanese Laid-open Patent Publication No. 7-262070 and Japanese Laid-open Patent Publication No. 2001-134482).
Generally, there are two modes of asynchronous copying (i.e., asynchronous REC (Remote Equivalent Copy) function), namely, a stack mode and a consistency mode.
In the stack mode, when a write operation to a copy source is completed, an updated portion is recorded and a response to the write operation is returned to the host. Data transfer to a copy destination is not executed during an I/O process, such as the write operation, and is executed in a copy data transfer process that is operated in the background. Because the copy data transfer process is executed regardless of I/O processes (hereinafter also simply called the “I/O's”) from the host, the sequence of write operations to a copy destination volume is not ensured in the stack mode.
In the consistency mode, a buffer for holding copy data is provided in units of control module, and when a write operation to the copy source is completed, the copy data is temporarily stored in the buffer. After lapse of a certain time or when the buffer is filled with data, the data is transferred to the copy destination in units equal to that of the buffer, and the transferred data is reflected upon corresponding areas of the copy destination in the sequence in which the data has been stored. Accordingly, the sequence of write operations to the copy destination is ensured in the consistency mode.
Thus, the consistency mode is generally considered superior to the stack mode as a copy technique for mirroring because the sequence of write operations to the copy destination, i.e., the sequence in which data is reflected upon the copy destination, is ensured in the consistency mode.
In the consistency mode, however, the amount of data transferred from a copy source to a copy destination is changed depending on the I/O amount (amount of write operations) with respect to the copy source. Therefore, the bandwidth of a remote line required between housings needs to be prepared based on bandwidth matching the data transfer amount.
Further, in the consistency mode, the capacity of the buffer for temporarily accumulating the I/O's issued to the copy source is required to be set in estimation of the I/O amount with respect to the copy source. Hence, the consistency mode poses problems in various aspects from the viewpoint of system design.
On the other hand, the stack mode is advantageous in that because the copy data transfer process independently functions in an asynchronous relation to the I/O's, the buffer is not required and the copy data transfer process is not affected by the line condition.
Recovery to be made when a disk array device at the copy source has failed during copying (i.e., during transfer of copy data) can be more easily executed in the consistency mode than the stack mode for the reason that data is transmitted in the consistency mode while the sequence is ensured in units of buffer. Stated another way, in the stack mode, because the sequence of write operations is not ensured as described above, what state the copy destination takes is not ensured in the event of a failure during the data transfer.
Thus, the stack mode and consistency mode have respective advantages and disadvantages.
A copy control method of a storage system, and a copy control unit in the storage system is provided. An update control section controls update with respect to a first volume in accordance with an update instruction for the first volume from a higher-level device using a first management table for managing an update situation of the first volume during a period from receipt of a copy instruction from the higher-level device to reception of a predetermined command (update control), and a transfer control section transfers update data of the first volume to a second volume based on the update situation in the first management table (transfer control). Further, the update control section controls, upon receiving the predetermined command, the update with respect to the first volume using, instead of the first management table, a second management table for managing an update situation of the first volume after the reception of the predetermined command (update control).
Additional aspects and/or advantages will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the invention.
These and/or other aspects and advantages will become apparent and more readily appreciated from the following description of the embodiments, taken in conjunction with the accompanying drawings of which:
Reference will now be made in detail to the embodiments, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout. The embodiments are described below to explain the present invention by referring to the figures.
The present invention has been accomplished in view of the above-mentioned and/or other problems, and an object of the present invention is to, when data is copied for duplexing of the data between (among) a plurality of storage areas (e.g., a plurality of disk array devices), eliminate the need for intricacy in system design, enable data to be transferred without being affected by the line condition, and facilitate recovery in the event of a failure, etc.
In accordance with the storage system, a copy control method for the storage system, and a copy control unit in the storage system, a first management table to be used before reception of a predetermined command and a second management table to be used after the reception of the predetermined command are prepared. More specifically, a transfer control section executes the data transfer in accordance with the copy instruction from the higher-level device on the basis of the first management table. Further, upon receiving the predetermined command, the update control section controls the update with respect to the first volume by using the second management table instead of the first management table.
Therefore, when data is copied between a plurality of volumes including for a purpose of duplexing of the data, a guarantee of the copied data can be reliably ensured on the basis of the predetermined command. Hence, recovery can be easily performed in the event of a failure, etc.
Also, since the copy process (data transfer) is executed on the basis of the first management table and the second management table, the copy process can be executed in an asynchronous relation to I/O's from the higher-level device, and the data transfer can be performed without being affected by the line condition. In addition, since there is no need of using a buffer dedicated for the copy process, which is required in the consistency mode, intricacy in system design is not required.
Initially, a storage system 1a according to an embodiment of the present invention (hereinafter referred to as a “present storage system 1a”) is described with reference to a block diagram shown in
It is here assumed that the disk array device 10 is a copy source housing and the disk array device 20 is a copy destination housing.
Each of the disk array devices 10 and 20 has a plurality of control units (denoted by “CMs (Centralized Modules)”, hereinafter simply called “CMs”) 11-1 to 11-n and 21-1 to 21-n (n=three or more integer).
CMs 11-1 to 11-n and 21-1 to 21-n (hereinafter called “CM 11 and 21” respectively when discrimination between the individual modules is not needed) execute processing for disk drives 12 and 22 in response to an I/O request(s) (such as access requests; read/write requests) from corresponding hosts 2 and 3 which process data held in the disk drives 12 and 22 connected respectively to the CM 11 and 21.
Although one disk drive 12 and 22 are each shown in
Each CM 11 and 21 includes, respectively, a Channel Adapter (hereinafter simply called a “CA”) 13 and 23, a Remote Adapter (hereinafter simply called an “RA”) 14 and 24, Fibre Channels (hereinafter simply called “FCs”) 15-1, 15-2 and 25-1, 25-2, and a Central Processing Unit (hereinafter simply called a “CPU”) 16 and 26, and a cache memory (denoted by “Cache” in the drawing) 17 and 27.
The CAs 13 and 23 execute interface control between the host 2 and the CM 11 and between the host 3 and the CM 21, respectively.
The RAs 14 and 24 execute interface control between the disk array devices 10 and 20.
The FCs 15-1 and 15-2 and the FCs 25-1 and 25-2 (hereinafter called “FC 15 and FC 25” respectively when discrimination between the individual channels is not needed) execute interface control between the CM 11 and the disk drive 12 and between the CM 21 and the disk drive 22, respectively.
Each of the CPUs 16 and 26 serves to execute data processing.
Each of the cache memories 17 and 27 serves to store user data and control data.
The present storage system 1a copies data located in a predetermined copy (duplexing) target area in a predetermined disk of the disk array device 10 to a predetermined area in a predetermined disk of the disk array device 20 at the copy destination automatically or in response to an instruction from the host 2.
To describe here outline of copy control in the present storage system 1a, the present storage system 1a applies a check point (check point instruction command) to the copy source during copying of data for duplexing and confirms whether data is copied until the check point, thus making it possible to confirm whether the data being copied is reflected upon the copy destination.
In more detail, the present storage system 1a executes data transfer by a transfer method similar to the above-mentioned stack mode. To ensure the data transfer until the check point, two bitmaps are prepared for copy control. One bitmap (later-described as a first bitmap 31) is used for management of update data until immediately before the check point is applied, and the other bitmap (later-described as a second bitmap 32) is used for management of update data after the application of the check point. After the check point has been issued, data transfer until the check point and confirmation of the data transfer are realized by executing the data transfer on the basis of the former bitmap. Management of data update during the data transfer is executed on the basis of the latter bitmap. Accordingly, when data recovery is required, the recovery can be performed until the check point up to which the data transfer is confirmed.
As shown in
The copy control unit 30a is realized in the disk array device 10 with the CPU 16 and the cache memory 17, and it is realized in the disk array device 20 with the CPU 26 and the cache memory 27.
More specifically, the first bitmap 31 and the second bitmap 32 are realized with the cache memories 17 and 27, respectively. The update control section 33a, the transfer control section 34a, and the status information notifying section 35 are realized with each of the CPU 16 and 26. Alternatively, the update control section 33a, the transfer control section 34a, and the status information notifying section 35, as well as an update control section 33b and a transfer control section 34b in an embodiment described below, may be realized by each of the CPU 16 and 26 executing predetermined software (e.g., a copy control program described below).
The first bitmap 31 and the second bitmap 32 correspond respectively to the copy source storage area and the copy destination storage area in corresponding one of the disk drives 12 and 22. In other words, one data (“0” or “1”) on the first bitmap 31 and the second bitmap 32 correspond respectively to predetermined portions in the copy source storage area and the copy destination storage area. All data on the first bitmap 31 and all data on the second bitmap 32 correspond respectively to the entire copy source storage area and the entire copy destination storage area.
The first bitmap 31 manages the update state of data in the copy source storage area in the disk drive 12 during a period from startup of a copy process (Remote Equivalent Copy (REC)) of data, which is executed for backup or mirroring in response to a copy (duplexing) instruction from the host 2, to reception of the check point from the host 2, or during a period from reception of one check point to reception of another check point when the another check point is received after receiving the one check point.
Herein, a portion of the first bitmap 31 corresponding to a copy source storage area where the copy process is not yet completed, or a portion thereof corresponding to a copy source storage area where data is updated, is set to “1”, and a portion of the first bitmap 31 corresponding to a copy source storage area where the copy process is completed is set to “0”.
The contents of the first bitmap 31 and the second bitmap 32 are controlled by the update control section 33a.
The second bitmap 32 manages the update state of data in the copy destination storage area in the disk drive 12 during a period from reception of one check point from the host 2 to reception of a next check point.
Herein, a portion of the second bitmap 32 corresponding to a copy destination storage area where data is updated is set to “1”, and a portion thereof corresponding to a copy destination storage area where data is not updated is set to “0”.
Details of the update control section 33a, the transfer control section 34a, and the status information notifying section 35 are described below in connection with the case where those sections are provided in the disk array device 10.
The update control section 33a controls, in accordance with an update instruction (a write request) for the copy source storage area from the host 2, an update with respect to the copy source storage area during a period after reception of a copy instruction (REC instruction) from the host 2 to reception of the check point by using the first bitmap 31.
Also, upon receiving the check point, the update control section 33a controls update with respect to the copy source storage area by using the second bitmap 32 instead of the first bitmap 31.
Further, the update control section 33a controls data in the first bitmap 31 and the second bitmap 32.
More specifically, when an update (a write process) is executed on the copy source storage area before receiving the check point, the update control section 33a updates, to “1”, a location on the first bitmap 31 corresponding to the location on the copy source storage area where the update has been executed.
Also, when update is executed on the copy source storage area after receiving the check point, the update control section 33a updates, to “1”, a location on the second bitmap 32 corresponding to the location on the copy source storage area where the update has been executed.
In addition, when an update instruction is issued again on a transfer target area of the copy source storage area from the host 2 after receiving the check point, the update control section 33a executes an update process for the transfer target area of the copy source storage area while the corresponding location on the second bitmap 32 is maintained at “0”.
Each of the first bitmap 31 and the second bitmap 32 includes status information. The status information contains at least a first status indicating a state during copying (during data transfer), a second status indicating a state after completion of the copying (completion of the data transfer), and a third status indicating a state of not receiving (non-receipt) the copy instruction from the host 2.
The update control section 33a changes the status information of the first and second bitmaps 31 and 32.
For example, upon receiving the check point from the host 2, the update control section 33a changes the status information of the first bitmap 31 and the second bitmap 32 to the first status. Further, when the data transfer based on the first bitmap 31 is completed, the update control section 33a changes the status information of the first bitmap 31 and the second bitmap 32 to the second status.
When receiving the check point from the host 2 during a period in which the status information represents the first status, the update control section 33a merges information in the second bitmap 32 into the first bitmap 31. Stated another way, the logical sum of respective data in corresponding locations on the second bitmap 32 and the first bitmap 31 is calculated and the calculated result is reflected upon the first bitmap 31. In addition, the second bitmap 32 to the second status is initialized (namely, all locations are set to “0”).
The transfer control section 34a transfers the update data in the copy source storage area to the copy destination storage area on the basis of the update state of the first bitmap 31.
When the status information notifying section 35 receives a transfer situation confirmation command from the host 2 to confirm the transfer situation (status information), a response regarding the transfer situation, which corresponds to the status represented by that status information, is provided to the host 2 on the basis of the status information of the first bitmap 31.
Next, the operation procedure(s) of the present storage system 1a and more practical processing details of various components will be described.
With reference to a flowchart (operations S1 to S9) shown in
When preparation of a remote copy session is provided as the copy instruction from the host 2 (operation S1), the update control section 33a calculates a capacity of the bitmap corresponding to the designated copy capacity (operation S2). In other words, the update control section 33a calculates a bitmap amount necessary for the designated copy capacity.
Then, the update control section 33a determines whether the cache memory 17 has a bitmap which is not yet used and which is twice the calculated bitmap amount (operation S3). In other words, the update control section 33a confirms whether a free capacity required for preparing the first bitmap 31 and the second bitmap 32 exists on the cache memory 17.
If the update control section 33a determines that the not-yet-used bitmap does not exist in the required amount (NO route of operation S3), this is regarded as indicating a deficiency of the bitmap capacity and the copy process is brought to an end because of an error (operation S4).
On the other hand, if the update control section 33a determines that the not-yet-used bitmap exists in the required amount (YES route of operation S3), it obtains two types of bitmaps and prepares session management information for the copy process (i.e., a session management table 18 (described below) shown in
Then, the update control section 33a initializes all bits of the first bitmap 31 used before the application of the check point to be turned ON (i.e., “1”) (operation S6), and initializes all bits of the second bitmap 32 used after the application of the check point to be turned OFF (i.e., “0”) (operation S7).
More specifically, as shown in
Similarly to the CM 11, as shown in
Further, as shown in
When the preparation of the remote copy session is requested as an ordinary command from the host 2, the update control section 33a sets an REC session (i.e., the session management table 18) in the above-mentioned stack mode (see operation S5). Note that the check point is managed by the host 2 in units of the session. In other words, when one file is constituted in a state separated into a plurality of volumes, the update control section 33a is required to manage the check point for a plurality of sessions.
When the initialization of the first bitmap 31 and the second bitmap 32 is completed, as shown in
Next, the ordinary copy process before application of a check point will be described with reference to
After the update control section 33a replies, as described above, the normal response to the host 2 (see operation S8 in
Then, as shown in
Further, when the write I/O is issued from the host 2 to the disk array device 10 during the copy process, the transfer control section 34a copies data through transfer in the stack mode to locations X1 and Y1 where the data is updated by the issued write I/O.
Also, when the data in the copy source storage area 12a is updated in accordance with the write I/O from the host 2, the update control section 33a changes, to “1”, data at locations X2 and Y2 on the first bitmap 31, which correspond respectively to the updated locations X1 and Y1.
For example, as indicated by “1” in the third line counting from the top of the first bitmap 31 in
At that time, all data in the second bitmap 32 remain “0”.
With reference to a flowchart (operations S10 to S17) shown in
First, upon receiving the check point instruction command from the host 2 (operation S10), the copy control unit 30a communicates (provides) a notice indicating the reception of the check point instruction to the disk array device 20, i.e., the copy destination housing (operation S11).
At that time, as shown in
The copy control unit 30a in the disk array device 20 records the notified ID and sets the check point state (status information) to the first status indicating that the state is during transfer (operation S12). Also, as shown in
Then, the update control section 33a of the copy control unit 30a in the disk array device 10 merges the information in the second bitmap 32 into the first bitmap 31 (operation S13). Stated another way, the update control section 33a sets the logical sum of the data of the second bitmap 32 and the data of the first bitmap 31 as data of the first bitmap 31.
Next, the update control section 33a initializes all data of the second bitmap 32 to “0” (operation S14)
Thereafter, the transfer control section 34a resumes the transfer process on the basis of the first bitmap 31 (operation S15), and the copy control unit 30a provides a normal response to the host 2 (operation S16), following which the check point reception process is brought to an end (operation S17).
On that occasion, as shown in
With reference to a flowchart (operations S20 to S28) shown in
First, when the CM 11 receives the write I/O from the host 2 (operation S20), the update control section 33a determines whether the state is currently during the transfer (i.e., is there a transfer underway) in accordance with the check point instruction (operation S21).
If the update control section 33a determines that the state is not during the transfer in accordance with the check point instruction (NO route of operation S21), the CPU 16 of the CM 11 sends a write instruction to the host 2, thus causing a write process to be executed (operation S22), and the update control section 33a updates corresponding data in the first bitmap 31 to “1” (operation S23), following which the process for the write I/O is brought to an end (operation S24).
On the other hand, if the update control section 33a determines that the state is during the transfer in accordance with the check point instruction (YES route of operation S21), it determines whether a target area of the write I/O process is a not-yet-transferred area (i.e., a storage area where the copying is completed and corresponding information in the first bitmap 31 is set to “1”) (operation S25).
If the update control section 33a determines on the basis of the first bitmap 31 that bitmap data corresponding to the target area of the write I/O is “0” and does not belong to the not-yet-transferred area (NO route of operation S25), the CPU 16 of the CM 11 sends a write instruction to the host 2, thus causing a write process to be executed (operation S26), and the update control section 33a updates corresponding bitmap data in the second bitmap 32 to “1” (operation S27), following which the process for the write I/O is brought to an end (operation S24).
On the other hand, if the write I/O from the host 2 is instructed for a portion of the copy source storage area 12a corresponding to an area of the first bitmap 31, which is surrounded by a broken line Z, for example, in
On that occasion, the CPU 16 of the CM 11 sends a write instruction to the host 2, thus causing a write process to be executed (operation S28), and the process for the write I/O is brought to an end (operation S24).
Stated another way, in that case, the update control section 33a maintains bitmap data in the second bitmap 32 corresponding to the target area of the write I/O as it is without updating the bitmap data to “1”. Of course, the bitmap data in the first bitmap 31 corresponding to the target area of the write I/O is also maintained at “1” as it is.
Next, with reference to a flowchart (operations S30 to S36) shown in
For example, as shown in
If the status information notifying section 35 determines that there is no trace indicating the reception of the check point instruction (NO route of operation S31), it provides a notice indicating that no check point instruction has been received to the host 2 (operation S32), following which the process for the confirmation command is brought to an end (operation S33).
On the other hand, if the status information notifying section 35 determines that there is a trace indicating the reception of the check point instruction (YES route of operation S31), it determines on the basis of the status information whether data corresponding to the check point instruction is in the state during transfer (during copying) (operation S34).
If the data is not in the state during copying (NO route of operation S34), i.e., if the status information is in the second status indicating the completion of data transfer, the status information notifying section 35 provides a notice indicating the completion of transfer to the host 2 (operation S35), following which the process for the confirmation command is brought to an end (operation S33).
On the other hand, if the data is still in the state during copying (YES route of operation S34), i.e., if the status information is in the first status indicating the state during data transfer, the status information notifying section 35 provides a notice indicating the state during transfer to the host 2 (operation S36), following which the process for the confirmation command is brought to an end (operation S33).
Next, with reference to a flowchart (operations S40 to S47) shown in
When the copy control unit 30a in the CM 11 detects on the basis of the status information, for example, that data transfer based on the first bitmap 31 after the check point is completed (operation S40), it communicates (provides) a notice indicating the completion of transfer to the copy control unit 30a in the CM 21 of the disk array device 20, i.e., the copy destination housing (operation S41).
Responsively, the update control section 33a of the copy control unit 30a in the CM 21 changes the status information representing the check point state of the relevant copy session from the state during transfer (first status) to the state after the completion of transfer (second status) (operation S42).
Then, the update control section 33a of the copy control unit 30a in the CM 11 changes the status information representing the check point state of the relevant copy session from the state during transfer to the state after the completion of transfer (operation S43).
Thus, as shown in
Subsequently, the update control section 33a of the CM 11 merges the information in the second bitmap 32 into the first bitmap 31 (operation S44).
For example, by merging the first bitmap 31 and the second bitmap 32 in the states shown in
Then, the update control section 33a of the CM 11 initializes the second bitmap 32 as shown in
Thereafter, the transfer control section 34a of the CM 11 resumes the transfer process on the basis of the first bitmap 31 (operation S46), following which the transfer completion process up to the check point is brought to an end (operation S47).
As shown in
Further, as shown in
Also, the disk array device 10 executes data update by regarding, as copying of ordinary data, the update of the management file made by the software in the host 2.
In addition, as shown in
With reference to a flowchart (operations S50 to S56) shown in
Hitherto, a read operation associated with the copy session at the copy destination during the copy operation (during a period in which the status information is in the first status) is inhibited (namely, such a read causes an error response) for the reason that the read is not ensured because of the state during the copy operation.
In contrast, the present storage system 1a permits the read at the copy destination to be executed by the host 3 because locations where the software in the host 3 can read data is ensured due to the completion of transfer of the check point.
Because of the necessity of the copy session using the check point, however, a read operation associated with the copy destination storage area 22a by the host 3 is permitted only when the copy control unit 30a in the disk array device 10 prepares the copy session in a copy-destination read permission mode designated by the host 2.
More specifically, when the CM 21 of the disk array device 20 receives a read request from the host 3 (operation S50), the CPU 26 determines whether the status information of the relevant session is in the first status (during transfer) (operation S51).
If the relevant session is not during copying (NO route of operation S51), the CPU 26 causes the host 3 to read the designated locations (operation S52), following which the process with respect to the read request is brought to an end (operation S53).
On the other hand, if the relevant session is during copying (YES route of operation S51), the CPU 26 determines whether the relevant session is prepared in the copy-destination read permission mode (operation S54).
The relevant session information is information that is prepared by the update control section 33a in accordance with the instruction, received in the above-described operation S1 of
If the relevant session is not prepared in the copy-destination read permission mode (NO route of operation S54), the CPU 26 replies an error response to the host 3 because the relevant session is during copying (operation S55), following which the process is brought to an end (operation S53).
On the other hand, if the relevant session is prepared in the copy-destination read permission mode (YES route of operation S54), the CPU 26 causes the host 3 to read the designated locations (operation S56), following which the process is brought to an end (operation S53).
With the storage system 1a according to an embodiment of the present invention, as described above, the first bitmap 31 used before the reception of the check point and the second bitmap 32 used after the reception of the check point are prepared. The transfer control section 34a executes data transfer in accordance with a copy instruction from the host 2 on the basis of the first bitmap 31, and when the check point is applied from the host 2, the update control section 33a controls update of the copy source storage area 12a by using the second bitmap 32 instead of the first bitmap 31.
Therefore, when data is copied between the plural disk array devices 10 and 20 for duplexing of the data, a guarantee of the copied data can be reliably ensured on the basis of the check point. Hence, recovery can be easily performed in the event of a failure, etc.
Also, with the present storage system 1a, since the copy process (data transfer) is executed on the basis of the first bitmap 31 and the second bitmap 32, the copy process can be executed in an asynchronous relation to the I/O's from the host, and the data transfer can be performed without being affected by the line condition. Further, since there is no need of using a buffer dedicated for the copy process, which is required in the known consistency mode, intricacy in system design is not required.
Stated another way, since the copy process is executed in the stack mode, the present storage system 1a can provide the above-described advantages of the stack mode as they are, i.e., the advantages that because the copy process functions in an asynchronous relation to the host I/O's, where the buffer is not required and the data transfer is not affected by the line condition.
In addition, since the present storage system 1a includes the two bitmaps 31 and 32 and uses them as described above, it can confirm, with the aid of the check point, the completion of transfer up to the application (reception) of the check point. As a result, recovery in the event of a failure, etc. can be easily executed on the basis of a completion report with respect to the check point.
More specifically, since the update control section 33a updates the first bitmap 31 corresponding to update of data before the reception of the check point, and updates the second bitmap 32 corresponding to update of data after the reception of the check point, the process using the check point can be reliably executed.
Also, when an update instruction is issued again for the copy source storage area 12a after the reception of the check point, the update control section 33a executes an update process for the copy source storage area 12a while corresponding locations in the second bitmap 32 are maintained as they are without updating those locations. This means that data at the time of receiving the check point is not duplicated for the relevant updated locations, but the copy process of data updated by the update process is reliably performed. Thus, the copy process for the copy source storage area 12a can be reliably executed without needing complicated control.
Further, since the update control section 33a manages the status information and, upon receiving the transfer situation confirmation command from the host 2, the status information notifying section 35 replies a response regarding the transfer situation (such as during transfer or after the completion of transfer) to the host 2 on the basis of the status information, the host 2 can reliably confirm the transfer situation.
Still further, when the check point is received during the copying in accordance with the copy instruction from the host 2, the update control section 33a merges the information in the second bitmap 32 into the first bitmap 31 and then initializes the second bitmap 32. Therefore, the copy control unit 30a can reliably execute the processing in relation to the check point.
Next, a storage system 1b according to an embodiment of the present invention (hereinafter referred to as a “present storage system 1b”) is described with reference to the block diagrams shown in
Therefore, the processing executed by the update control section 33b and the transfer control section 34b of the copy control unit 30b will be described in detail below with reference to
Specifically, the present storage system 1b is constituted as follows. When an update request (write I/O) is issued again from the host 2 for the copy source storage area 12a after the reception of the check point, the transfer control section 34b preferentially transfers update target data in the copy source storage area 12a to the disk array device 20 and the CPU 16 then executes the relevant update request. After the relevant update request is executed, the update control section 33b updates corresponding data in the second bitmap 32 to “1”.
With reference to a flowchart (operations S20 to S27, S28′ and S29′) shown in
If the process is during the data transfer in accordance with the copy instruction from the host 2 and the update control section 33b determines that the write I/O received by the CM 11 does not belong to the not-yet-transferred area (NO route of operation S25), the CPU 16 of the CM 11 sends a write instruction to the host 2, thus causing a write process to be executed (operation S26), and the update control section 33b updates corresponding bitmap data in the second bitmap 32 to “1” (operation S27), following which the process for the write I/O is brought to an end (operation S24).
On the other hand, if the write I/O from the host 2 is instructed for a portion of the copy source storage area 12a corresponding to an area of the first bitmap 31, which is surrounded by a broken line Z, for example, in
At that time, the transfer control section 34b preferentially transfers data in the target area of the write I/O to the disk array device 20 (operation S28′).
Then, the update control section 33b updates data in the first bitmap 31 corresponding to the target area to be off (“0”) (operation S29′).
Thereafter, the CPU 16 of the CM 11 sends a write instruction to the host 2, thus causing the host 2 to execute the write process of the write I/O (operation S26), and the update control section 33b updates corresponding bitmap data in the second bitmap 32 to “1” (operation S27), following which the process for the write I/O Is brought to an end (operation S24).
Thus, with the storage system 1b according to this embodiment of the present invention, in addition to working advantages similar to those obtained with the above-described embodiment, when a write I/O is issued for a not-yet-transferred portion of the copy source storage area 12a after the reception of the check point, the transfer control section 34a transfers data in the not-yet-transferred portion and the CPU 16 executes the write I/O. Further, the update control section 33b updates the second bitmap 32 corresponding to the write I/O. Therefore, the copy process for the copy source storage area 12a before the reception of the check point can be executed with higher reliability.
It is to be noted that the present invention is not limited to the above-described embodiments and the present invention can be practiced in variously modified forms within the scope not departing from the gist of the present invention.
For example, the foregoing embodiments have been described in connection with the case where the number of the CMs 11 in the disk array device 10 is the same as the number of the CMs 21 in the disk array device 20. However, the numbers of the CMs 11 and the CMs 12 are not limited to particular values in the present invention.
Also, the foregoing embodiments have been described in connection with the case where the copy process is executed between the disk array devices 10 and 20 in accordance with the copy instruction from the host 2. However, the present invention is not limited to that case, and it can be of course applied to a copy process between different storage volumes within the same housing. Such a modification can also provide working advantages similar to those obtained with the above-described embodiments.
The functions of the above-described copy control units 30a and 30b (specifically, the update control sections 33a and 33b, the transfer control sections 34a and 34b, and the status information notifying section 35) may be realized with a computer (including a CPU, an information processing apparatus, a specialized device, and various types of terminals) executing a predetermined application program (copy control program).
The program may be provided, for example, in the form recorded on a computer-readable recording medium, such as a flexible disk, CD (e.g., CD-ROM, CD-R or CD-RW), DVD (DVD-ROM, DVD-RAM, DVD-R, DVD-RW, DVD+R or DVD+RW). In such a case, the computer reads the copy control program from the recording medium and transfers it to an internal storage device or an external storage device to be loaded therein for use. Further, the program may be recorded on, e.g., a storage device (recording medium), such as a magnetic disk, an optical disk or a magneto-optical disk, and may be provided from the storage device to the computer via a communication line.
Herein, the term “computer” represents the concept including hardware and an OS (Operating System) and refers to hardware operating under control of the OS. Also, when hardware is operated with the application program alone without using the OS, the hardware reference may correspond to the computer. The hardware includes at least a microprocessor such as a CPU, and a means for reading a computer program recorded on the recording medium.
The application program as the above-mentioned copy control program includes program code causing the above-mentioned computer to realize operation(s) including the functions of the copy control units 30a and 30b. Further, a part of those functions may be realized with the OS instead of the application program. Although some operations are described herein as being implemented via hardware component, the present invention is not limited to any specific implementation of an operation.
The recording medium used in the embodiments can be selected from among various computer-readable media including, in addition to the above-mentioned flexible disk, CD, DVD, magnetic disk, optical disk, and magneto-optical disk, an IC card, a ROM cartridge, a magnetic tape, a punched card, an internal storage device (memory such as RAM or ROM) in a computer, an external storage device or the like, a print on which a barcode or other code is printed, etc.
Although a few embodiments have been shown and described, it would be appreciated by those skilled in the art that changes may be made in these embodiments without departing from the principles and spirit of the invention, the scope of which is defined in the claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
2008-183555 | Jul 2008 | JP | national |