The present invention relates to a technology for migrating a volume of either a primary storage apparatus or a secondary storage apparatus to a different storage apparatus in a remote copy system comprising primary storage apparatus and secondary storage apparatus.
The following terminology will be used in the specification.
A remote copy system that has a PDKC and an SDKC, and copies from the PVOL of the PDKC to the SVOL of the SDKC is known. A remote copy may include a synchronous remote copy for synchronizing the writing of data to the PVOL with the writing of this data to the SVOL, and an asynchronous remote copy for not synchronizing the writing of data to the PVOL with the writing of this data to the SVOL.
For example, Patent Literature 1 discloses a technology related to the asynchronous remote copy, that is, a technology for migrating a PVOL to a difference DKC.
[PTL 1]
In the technology according to Patent Literature 1, it is necessary to install a virtual management network in the remote copy system, and to provide a function for the MS-DKC to migrate a PVOL.
The situation for migrating the PVOL here can be considered one wherein the remote copy system migrates the PVOL using a currently operating old model DKC, which manages a PVOL in an asynchronous remote copy, as the MS (migration source), and using a new model DKC, which has been newly installed, as the MD (migration destination). In a situation such as this, the technology according to Patent Literature 1 must provide a function for the MS-DKC to migrate the PVOL, but the MS-DKC does not necessarily come with such a function, making it necessary to go to the trouble of providing this function to the MS-DKC. To begin with, there are cases in which it is not possible to provide the MS-DKC with the required function.
Furthermore, in a case where asynchronous remote copying is ongoing, journals corresponding to PVOL updates are created in the MS-PDKC and the MD-PDKC, and the journals are managed by sequence numbers, but when the creation of the MS-DKC journal and the journal of the migration-destination storage apparatus are not properly handled, it is impossible to create a consistent SVOL based on these journals.
A migration-destination primary storage apparatus (MD-PDKC) is coupled to a migration-source primary storage apparatus (MS-PDKC). The MS-PDKC comprises a first PVOL that forms a copy pair with an SVOL in the SDKC, and a first journal storage area for storing a journal corresponding to write data of the first PVOL, and is configured to transfer a journal to the SDKC. The MD-PDKC comprises a second PVOL, and a second journal storage area for storing a journal corresponding to write data of the second PVOL, and is configured to execute a data copy from the first PVOL to the second PVOL. The MD-PDKC, after completing a copy, acquires the latest write sequence information from the MS-PDKC, and upon receiving a write request with respect to the second PVOL, writes the write-request write data to the second PVOL, creates a journal using journal data corresponding to the write data and update information showing write sequence information based on the acquired latest write sequence information, and writes the journal to the second journal storage area. The journal storage area may be a type of VOL, or may be a storage area in a memory in the DKC (for example, a cache memory). The memory may a memory in the controller inside the DKC.
According to the present invention, it is possible to migrate an MS-PDKC to a MD-PDKC while an asynchronous remote copy is ongoing without adding a special function to the MS-PDKC.
A number of examples will be explained below.
In the following explanation, various information may be explained using the expression “aaa table”, but the various information may also be expressed using a data structure other than a table. To show that the various information is not dependent on the data structure, “aaa table” may be called “aaa information”. Furthermore, a case where processing is explained using a program or software as the doer of the action can actually be understood as one in which a processor or the like is executing the program or the software.
The computer system comprises one or more hosts (host computers) 200, and a remote computer system. The remote computer system comprises multiple DKCs (storage apparatuses) 100.
The host 200 is an ordinary computer, comprising a processor, a cache, and a storage apparatus. The host 200 issues the DKC 100 an access command (a read command (read request) or a write command (write request)) specifying an ID (for example, a LUN) of a VOL (for example, a PVOL 105) provided by the DKC 100. The access command, for example, is a SCSI command. The host 200 also comprises one or more ports 201. The port 201 is an example of a communication interface device, and is an interface for coupling to a network 50. Identification information (for example, a world wide name (WWN) or the like) that makes it possible to uniquely identify a port 201 is configured in the port 201. The host 200 stores path management information. The path management information is information, about a path to a DKC 100, in which identification information (for example, a device number) of an access-target VOL has been associated with identification information (port information) of a port 101 in a DKC 100 to be accessed when accessing the VOL.
A MS-PDKC 100A and a SDKC 100B are coupled via a communication network 60. The MS-PDKC 100A and a MD-PDKC 100C, for example, are installed at the same local site 10, and are communicably coupled to one another. However, the MD-PDKC 100C may also be installed at a site that is separate from the MS-PDKC 100A. The SDKC 100B is installed at a remote site 20, which is a place separate from the local site 10. The MD-PDKC 100C and the SDKC 100B are coupled via the communication network 60.
The DKC 100 (100A through 100C), for example, comprises multiple ports 101, one or more microprocessor packages (MPPKs) 102, one or more cache memory packages (CMPKs) 103, an internal network 104, and a PDEV configuring one or more VOLs. The port 101, MPPK 102, CMPK 103, and VOL-configuring PDEV are communicably coupled via the internal network 104. A group of an MPPK and a CMPK is called a storage controller.
For example, as a VOL managed by a DKC 100, the MS-PDKC 100A manages a PVOL 105. The SDKC 100B manages a SVOL 110. The MD-PDKC 100C manages a MD-PVOL 112.
The port 101 is an example of a communication interface device, and is an interface for connecting to a network. Identification information (for example, a world wide name (WWN) or the like) that makes it possible to uniquely identify a port is configured in the port 101. Arbitrary identification information (virtual identification information) can be virtually allocated to the port 101, and this virtual identification information can be used in communications.
In this example, for example, the MS-PDKC 100A comprises a port 101 for coupling to the host 200, a port 101 for coupling to the MD-PDKC 100C, and a port 101 for coupling to the SDKC 100B.
The MD-PDKC comprises a port 101 for coupling to the host 200, a port 101 for coupling to the MS-PDKC 100A, and a port 101 for coupling to the SDKC 100B.
The SDKC 100B comprises a port 101 for coupling to the host 200, a port 101 for coupling to the MS-PDKC 100A, and a port 101 for coupling to the MD-PDKC 100C.
The MPPK 102 is a control device comprising either one or multiple processors. The processor executes various processes in accordance with a program. The MPPK 102 may comprise a memory for storing a program executed by the processor, and data to be used. In this example, the MPPK 102 of the MD-PDKC 100C comprises a program for realizing a new function in this example, which will be explained further below. The MPPK 102 in the MS-PDKC 100A and the SDKC 100B may comprise existing programs.
The CMPK 103 includes one or more cache memories. The one or more cache memories are a volatile memory and/or a nonvolatile memory. The one of more cache memories may comprise, in addition to a storage area (hereinafter, cache area) for temporarily storing data input/output to/from the PDEV, a storage area (hereinafter, shared area) for storing information that is used by the MPPK 102 processor.
The computer system, in the initial state, comprises a host 200, a MS-PDKC 100A, and a SDKC 100B.
The MS-PDKC 100A comprises a MS-PVOL 105, a primary journal VOL (PJVOL) 108 for storing a journal (JNL) showing update content for the MS-PVOL 105, and sequence information (one example of sequence information, also referred to as write sequence information) 109 for storing the latest sequence number (SEQ #) allocated to the journal. The storage area in which the journal is stored is a single VOL in this example, but may be a storage area provided in a different storage device such as the CMPK 103. The sequence number is information showing the write sequence for a primary volume.
The SDKC 100B comprises a SVOL 110 that configures a pair with the MS-PVOL 105, and a secondary JVOL (SJVOL) 111 for storing a journal acquired from the MS-PDKC 100A.
A path h-m1 is formed between the host 200 and the MS-PDKC 100A. For example, an SCSI command such as either a read command or a write command is sent from the host 200 to the MS-PDKC 100A via the path h-m1.
A path m1-r is formed between the MS-PDKC 100A and the SVOL 100B. For example, a command (asynchronous remote copy command) is sent from the SDKC 100B to the MS-PDKC 100A via the path m1-r. As a command that is sent, for example, there is a command (read journal command (RDJNL)) for reading a journal (update information including journal data and a sequential number) of the PJVOL 108 in the MS-PDKC 100A.
Next, the MD-PDKC connections configuration processing in preparation for migrating a PVOL will be explained.
First, the administrator installs the MD-PDKC 100C for storing the MD-PVOL 112, for example, at the local site 10 (Step S11,
Next, the administrator connects a path m1-m2 between the MS-PDKC 100A and the MD-PDKC 100C (Step 12,
Next, the administrator connects a path h-m2 between the host 200 and the MD-PDKC 100C (Step S13,
Next, path-switching software 202 in the host 200 (or, an FC switch that exists between the host 200 and the DKC) adds a path (path h-m2) that goes through the MD-PDKC 100C as the path between the host 200 and the MS-PDKC 100A (Step S14). Thereafter, the MD-PDKC 100C (specifically, the MPPK 102 processor in the MD-PDKC 100C), upon acquiring a SCSI command from the host 200 for the MS-PDKC 100A via the path h-m2, transfers this SCSI command to the MS-PDKC 100A via the path m1-m2 (
Next, path-switching software 202 in the host 200 (or, an FC switch that exists between the host 200 and the DKC) deletes the path (path h-m1) between the host 200 and the MS-PDKC 100A that does not go through the MD-PDKC 100C (Step S15,
After the MD-PDKC connection configuration processing has ended, it is possible to start PVOL migration processing for migrating the PVOL 105 of the MS-PDKC 100A to the MD-PDKC 100C.
Next, the PVOL migration processing will be explained.
The MD-PDKC 100C prepares, on the PDEV, a VOL (MD-PVOL 112) having a capacity of equal to or greater than the PVOL to be used as the migration destination for the MS-PVOL 105 (Step S21,
Next, the MD-PDKC 100C updates the values of all the bits in the difference bitmap 113 to values showing that the data migration is not complete (Step S22).
Then, the MD-PDKC 100C assumes control and executes the processing of loop (A) (Step S24 through Step S28) targeted at the addresses of the areas for which the MS-PVOL 105 data migration has yet to be completed, thereby executing the data migration from the MS-PVOL 105 to the MD-PVOL 112 (
Specifically, the MD-PDKC 100C, posing as the host 200, sends a read command for reading the target address of the MS-PVOL 105 in the MS-PDKC 100A (Step S24). Upon receiving this read command, the MS-PDKC 100A reads the data of the PVOL 105 target-address in accordance with the read command (Step S25), and sends the read result and the data that was read (read data) to the source of the read command (Step S26). The MS-PDKC 100A perceives the read command source as being the host 200 here, and as such, perceives that the read result and the read data are being sent to the host 200, but actually the read result and the read data are sent to the MD-PDKC 100C posing as the host 200.
The MD-PDKC 100C writes the read data received from the MS-PDKC 100A to the target address in the MD-PVOL 112 (Step S27), and updates the bit of the area corresponding to the target address in the difference bitmap 113 to a value showing that data migration has been completed (Step S28).
Then, after executing the loop (A) processing for all of the addresses in the MS-PVOL 105 for which data migration has not been completed, the MD-PDKC 100C ends the processing.
According to this processing, all of the data in the PVOL 105 in the MS-PDKC 100A is migrated to the MD-PVOL 112 in the MD-PDKC 100C.
Next, the read command processing in a case where the MD-PDKC 100C has received a read command from the host 200 with respect to the PVOL 105 part way through a PVOL migration process will be explained.
The MD-PDKC 110C, upon receiving a read command from the host 200 with respect to the PVOL 105, refers to the difference bitmap 113, and determines whether the value of the bit corresponding to an address targeted by the read command (referred to as the target address in the explanation of the read command processing) is a data-migration-complete value or a data-migration-incomplete value (Step S31). In a case where the result of this is that the value of the bit corresponding to the target address is a data-migration-complete value (Step S32: Y), the MD-PDKC 100C reads the target address of the MD-PVOL 112 (Step S33,
Alternatively, in a case where the value of the bit corresponding to the target address is not a data-migration-complete value (Step S32: N), the MD-PDKC 100C reads the target address data from the PVOL 105 in the MS-PDKC 100A (Steps S34 through S36,
In Step S37, the MD-PDKC 100C, posing as the MS-PDKC 100A, sends the acquired read result and read data to the host 200, which is the source of the read command, and ends the read command processing. In accordance with this, the host 200, which sent the read command, acquires the read result and the read data as information that was sent from the MS-PDKC 100A.
According to the read command processing, the read data migrated to the MD-PVOL 112 is read from the MD-PVOL 112, and as such can be read faster than when read from the PVOL 105.
Next, the write command processing in a case where the MD-PDKC 100C has received a write command from the host 200 with respect to the PVOL 105 part way through a PVOL migration process will be explained.
The MD-PDKC 100C, upon receiving a write command and write-target data (write data) for the PVOL 105 from the host 200, stores the write data in a cache memory of the CMPK 103, and, in addition, updates the value of a difference bitmap 113 bit corresponding to an address being targeted by the write command (referred to as the target address in the explanation of the write command processing) to a data-migration-incomplete value (Step S41,
Next, the MD-PDKC 100C poses as the host 200 and sends the write command and the write data to be written to the target address of the MS-PVOL 105 in the MS-PDKC 100A (Step S42,
Upon receiving this write command and write data, the MS-PDKC 100A writes the write data to the target address in the PVOL 105 (Step S43), and sends the write result to the source of the write command (MD-PDKC 100C) (Step S44). This makes it possible to appropriately store the write data in the PVOL 105, and to maintain the PVOL 105 as the latest data until the migration of the PVOL 105 has ended. A journal showing update content corresponding to the write command is created in the MS-PDKC 100A, a sequence number showing the latest sequence is given in the journal, the journal is stored in the PJVOL 108, and the sequence number showing the latest sequence is stored in the sequence information 109.
The MD-PDKC 100C, in a case where, upon receiving the write result sent from the MS-PDKC 100A, the write result is normal-end, writes the read data stored in the cache memory of the CMPK 103 to the target address in the MD-PVOL 112 (Step S45,
Thereafter, the MD-PDKC 100C poses as the MS-PDKC 100A and sends the acquired write result to the host 200, which is the source of the write command (Step S47), and ends the write command processing. In accordance with this, the host 200, which sent the write command, acquires the write result as information that has been sent from the MS-PDKC 100A.
Next, path addition processing for adding a path between the MD-PDKC 100C and the SDKC 100B will be explained. The path addition processing, for example, may be executed when making preparations for a PVOL 105 migration, or prior to the PVOL 105 migration being completed.
The administrator connects a path m1-m2(2) between the MS-PDKC 100A and the MD-PDKC 100C (Step S51,
Next, the administrator connects a path m2-r between the SDKC 100B and the MD-PDKC 100C (Step S52,
Next, the MS-PDKC 100A (or, an FC switch that exists between the MS-PDKC 100A and the SDKC 100B) adds a path (path m1-m2(2)) that goes through the MD-PDKC 100C as the path between the MS-PDKC 100A and the SDKC 100B (Step S53). Thereafter, the MD-PDKC 100C, upon acquiring a command from the SDKC 100B for the MS-PDKC 100A via the path m2-r, transfers this command to the MS-PDKC 100A via the path m1-m2(2) (
Next, the MS-PDKC 100A (or, an FC switch that exists between the MS-PDKC 100A and the SDKC 100B) deletes the path (path m1-r) between the MS-PDKC 100A and the SDKC 100B that does not go through the MD-PDKC 100C (Step S54,
Next, processing at the completion of data migration, which is executed when a migration of data from the PVOL 105 to the MD-PVOL 112 has been completed, will be explained.
After a migration of data from the PVOL 105 to the MD-PVOL 112 has been completed, the MD-PDKC 100C suspends the transfer of an SCSI command from the path h-m2 to the path m1-m2, and adds a VOL (MD-journal VOL 115) of a capacity equal to or greater than the MS-PJVOL 108 to itself (The capacity may also be arbitrarily configured to a capacity that is equal to or less than the MS-PJVOL 108.) (Step S61). The suspension of the transfer of the SCSI command halts the updating of the PVOL 105, the PJVOL 108, and the sequence information 109 in the MS-PDKC 100A.
Next, the MD-PDKC 100C, posing as the host 200, acquires the latest sequence number of the MS-JVOL 108 from the sequence information 109 in the MS-PDKC 100A (Step S62), and stores the acquired latest sequence number in the sequence information 114 as the latest sequence number of the journal in the MD-JVOL 115 (Step S63,
Next, the MD-PDKC 100C stores the latest sequence number acquired from the MS-PDKC 100A as an acquired latest sequence number (Step S64). The acquired latest sequence number shows that the journals up to this sequence number are stored in the JVOL 108 of the MS-PDKC 100A, and that journals having a larger sequence number are stored in the JVOL 115 of the MD-PDKC 100C.
Next, the MD-PDKC 100C performs a configuration for deleting the path (path m1-m2) between the MS-PDKC 100A and the MD-PDKC 100C on which the MD-PDKC 100C is posing as the host 200 (Step S65,
Next, RDJNL command processing, which is executed in a case where the migration-destination storage 100C has received a RDJNL command for reading a journal from the SDKC 100B after processing at the completion of a data migration has ended, will be explained. A sequence number specifying the read-target journal (specified sequence number) is associated with the RDJNL command here.
The MD-PDKC 100C, upon receiving a RDJNL command and specified sequence number, determines whether or not the sequence information of the journal corresponding to the RDJNL command from the SDKC 100B is sequence information guaranteeing that a RDJNL command targeted at a journal prior to the latest sequence information in the MS-PDKC 110A is not received. Specifically, the MD-PDKC 100C, upon receiving the RDJNL command and the specified sequence number, determines whether or not the specified sequence number is larger than a number obtained by adding the maximum number of RDJNL commands issued in parallel to the acquired latest sequence number (Step S71). The maximum number of RDJNL commands issued in parallel here shows, in a case where RDJNL commands are capable of being issued in parallel, the maximum value of a difference in sequence numbers for which JNL request and reception sequence shifting is allowed according to asynchronous remote copy specifications.
A case in which the result is that the specified sequence number is larger than the number obtained by adding the maximum number of RDJNL commands issued in parallel to the acquired latest sequence number (Step S71: Y) signifies that a RDJNL command for reading a journal stored in the JVOL 108 of the MS-PDKC 100A does not exist even when the allowable sequence shifting of the specified sequence number in the RDJNL command is taken into account. Consequently, the migration-destination storage 100C deletes the path between MS-PDKC 100A and the migration-destination storage 100C (Step S72,
Alternatively, in a case where the specified sequence number is not larger than the number obtained by adding the maximum number of RDJNL commands issued in parallel to the acquired latest sequence number (Step S71: N), an RDJNL command for reading a journal stored in the JVOL 108 of the MS-PDKC 100A could exist, and as such, the MD-PDKC 100C advances the processing to Step S74.
In Step S74, the MD-PDKC 100C determines whether or not the specified sequence number is larger than the acquired latest sequence number. A case in which the result is that the specified sequence number is larger than the acquired latest sequence number (Step S74: Y) signifies that the journal corresponding to the specified sequence number is stored in the JVOL 115 of the MD-PDKC 100C, and as such, the MD-PDKC 100C advances the processing to Step S75. A case in which the specified sequence number is not larger than the acquired latest sequence number (Step S74: N) signifies that the journal corresponding to the specified sequence number is stored in the JVOL 108 of the MS-PDKC 100A, and as such, the MD-PDKC 100C advances the processing to Step S76.
In Step S75, the MD-PDKC 100C acquires the journal (journal data and update information) corresponding to the specified sequence number from the JVOL 115 (
In Step S76, the MD-PDKC 100C, posing as the SDKC 110B, sends the RDJNL command and the specified sequence number to the MS-JVOL 108 in the MS-PDKC 100A. As a result of this, the MS-PDKC 100B acquires from the MS-JVOL 108 the data in the journal corresponding to the specified sequence number (Step S77), and sends the result of the RDJNL command execution and the acquired journal data to the source of the RDJNL command (Step S78). The MD-PDKC 100C acquires the RDJNL command execution result and the acquired journal from the MS-PDKC 100A (
In Step S79, the MD-PDKC 100C, posing as the MS-PDKC 100A, sends the RDJNL command execution result and the acquired journal to the SDKC 100B. This makes it possible for the SDKC 100B to appropriately acquire a required journal and to store this journal in the SJVOL 111.
Next, the computer system that exists after the MS-PDKC 100A has been dismounted from the computer system shown in
As shown in
This read command processing is executed when the MD-PDKC 100C, which is posing as the MS-PDKC 100A, has received a read command from the host 200 for the PVOL 105 of the MS-PDKC 100A after a data migration has ended.
The MD-PDKC 100C, upon having received a read command specifying the ID of the PVOL 105 from the host 200, reads data of the MD-PVOL 112 target address in the read command (Step S81), and, posing as the MS-PDKC 100A, sends the read command execution result and the read data to the host 200 (Step S82). Furthermore, the device information (identification information) for identifying the MD-PVOL 112 may be virtualized to the same device information as that of the PVOL 105.
This write command processing is executed when the MD-PDKC 100C, which is posing as the MS-PDKC 100A, has received a write command and write data from the host 200 for the PVOL 105 of the MS-PDKC 100A after a data migration has ended.
The MD-PDKC 100C, upon having received a write command from the host 200, writes the write data to the MD-PVOL 112 target address in the write command (Step S91), creates a journal corresponding to the write data, and associates a sequence number based on the sequence number in the sequence information 114 (for example, the sequence number in the sequence information 114+1) with the journal (Step S92). This makes it possible to create a journal in the MD-PDKC 100C that is sequentially compatible with the journal created in the MS-PDKC 100A.
Next, the MD-PDKC 100C updates the latest sequence number by adding 1 to the sequence number in the sequence information 114 (Step S93). Next, the MD-PDKC 100C, posing as the MS-PDKC 100A, sends the write command execution result to the host 200 (Step S94). This makes it possible to appropriately store the write data in the MD-PVOL 112, and, in addition, to allocate an appropriate sequence number to the journal in accordance with the sequence number in the sequence information 114.
Next, a computer system related to Example 2 will be explained. The points of difference with Example 1 will be explained for the most part hereinbelow, and explanations of the points in common with Example 1 will either be simplified or omitted.
The computer system comprises one or more hosts 200, and one or more DKCs 100.
The host 200 issues an access command with respect to the PVOL 105 managed by the DKC 100 to the DKC 100. The host 200 comprises one or more ports 201. The port 201 is an example of a communication interface device, and is an interface for connecting to a network. Identification information (for example, a world wide name (WWN) or the like) that makes it possible to uniquely identify a port is configured in the port 201. The host 200 manages information regarding a path to a DKC 100, this information being associated with the identification information of an access-target VOL (for example, the device number) and the identification information (the port information) of the port 101 in the DKC 100 accessed when accessing the VOL.
A PDKC 100A is coupled to an MS-SDKC 100B via a communication network 60. A MD-SDKC 100D is installed in a remote site 20, which is a place that is separated from a local site 10. The PDKC 100A is coupled to the MD-SDKC 100D via the communication network 60. The MS-SDKC 100B and the MD-SDKC 100D are communicably coupled to one another.
The DKCs 100 (100A, 100B, 100D), for example, comprise multiple ports 101, one or more microprocessor packages (MPPKs) 102, one or more cache memory packages (CMPKs) 103, an internal network 104, and a PDEV for configuring one or more VOLs. A VOL is configured using one or more PDEVs. The port 101, the MPPK 102, the CMPK 103, and the VOL-configuring PDEV are communicably coupled via the internal network 104.
For example, the PDKC 100A provides a PVOL 105. The MS-SDKC 100B provides a MS-SVOL 110. The MD-SDKC 100D provides a MD-SVOL 116.
The port 101 is an example of a communication interface device, and is an interface for connecting to a network. Identification information (for example, a world wide name (WWN) or the like) that makes it possible to uniquely identify a port is configured in the port 101. Arbitrary identification information (virtual identification information) can be virtually allocated to the port 101 and used in communications.
In this example, for example, the PDKC 100A comprises a port 101 for coupling to the host 200, a port 101 for coupling to the MS-SDKC 100B, and a port 101 for coupling to the MD-SDKC 100D.
The MS-SDKC 100B comprises a port 101 for coupling to the host 200, a port 101 for coupling to the PDKC 100A, and a port 101 for coupling to the MD-SDKC 100D.
The MD-SDKC 100D comprises a port 101 for coupling to the host 200, a port 101 for coupling to the PDKC 100A, and a port 101 for coupling to the MS-SDKC 100B.
The MPPK 102 is a control device comprising either one or multiple processors. The processor executes various processes in accordance with a program. The MPPK 102 may comprise a memory for storing a program executed by the processor, and data that is to be used. In this example, the MPPK 102 of the MD-SDKC 100D comprises a program for realizing a new function in this example, which will be explained further below. The MPPK 102 in the PDKC 100A and the MS-SDKC 100B may comprise existing programs.
The CMPK 103 includes one or more cache memories. The one or more cache memories are a volatile memory and/or a nonvolatile memory. The one or more cache memories may comprise, in addition to a storage area (hereinafter, cache area) for temporarily storing data input/output to/from the PDEV, a storage area (hereinafter, shared area) for storing information that is used by the MPPK 102 processor.
The computer system, in the initial state, comprises a host 200, a PDKC 100A, and an MS-SDKC 100B.
The PDKC 100A comprises a PVOL 105, and a JVOL 108 for storing a journal (JNL) showing update content with respect to the PVOL 105
The MS-SDKC 100B stores an MS-SVOL 110 that configures a pair with the PVOL 105, an SJVOL 111 for storing a journal acquired from the PDKC 100A, and formalized sequence information 117 for storing a sequence number of a journal that has been formalized (reflected) in the SJVOL 110 (a formalized sequence number).
A path h-m is formed between the host 200 and the PDKC 100A. For example, an SCSI command such as either a read command or a write command is sent from the host 200 to the PDKC 100A via the path h-m.
A path m-r1 is formed between the PDKC 100A and the migration-source SVOL 100B. For example, a command (asynchronous remote copy command) is sent from the MS-SDKC 100B to the PDKC 100A via the path m-r1. As a command that is sent, for example, there is a command (RDJNL command) for reading a journal of the JVOL 108 in the PDKC 100A.
Next, MD-SDKC connections configuration processing in preparation for migrating an SVOL will be explained.
First, the administrator installs the MD-SDKC 100D for storing the MD-SVOL 116, for example, at the remote site 20 (Step S95,
Next, the administrator connects a path r1-r2 between the MS-SDKC 100B and the MD-SDKC 100D (Step S96,
Next, the administrator connects the path m-r2 between the PDKC 100A and the MD-SDKC 100D (Step S97,
Next, PDKC 100A and the MS-SDKC 100B (or, an FC switch that exists therebetween) adds paths (path m-r2 and path r1-r2) that go through the MD-SDKC 100D as paths between the PDKC 100A and the MS-SDKC 100B (Step S98). Thereafter, the MD-SDKC 100D (specifically, the MPPK 102 processor in the MD-SDKC 100D), upon acquiring a command from the MS-PDKC 100B for the PDKC 100A via the path r1-r2, transfers this command to the PDKC 100A via the path m-r2 (
Next, PDKC 100A and the MS-SDKC 100B (or, an FC switch that exists therebetween) deletes the path (path m-r1) between the PDKC 100A and the MS-SDKC 100B that does not go through the MD-SDKC 100D (Step S99,
RDJNL command processing executed in a case where the MD-SDKC 100D has received an RDJNL command from the MS-SDKC 100B with respect to the JVOL 108 of the PDKC 100A after the MD-SDKC connection configuration processing has ended will be explained. Firstly, the RDJNL command processing (first time), which is executed in a case where the MD-SDKC 100D has initially received an RDJNL command from the MS-SDKC 100B with respect to the JVOL 108 of the PDKC 100A after the MD-SDKC configuration setting processing has ended, will be explained.
The MD-SDKC 100D, upon initially receiving an RDJNL command from the MS-SDKC 100B for the JVOL 108 in the PDKC 100A, saves the sequence number specified in the received RDJNL command (referred to as the specified sequence number) to its own MPPK 102 memory (Step S101). The specified sequence number saved to memory here is referred to as the saved specified sequence number.
Next, the MD-SDKC 100D, posing as the MS-SDKC 100B, sends the RDJNL command and the specified sequence number to the JVOL 108 in the PDKC 100A (Step S102).
The PDKC 100A, upon receiving the RDJNL command, reads the journal (update information including journal data and the sequence number) corresponding to the specified sequence number from the JVOL 108 (Step S103), and sends the RDJNL command execution result and journal to the source of the RDJNL command (Step S104). The PDKC 100A perceives the source of the RDJNL command as being the MS-SDKC 100B here, and as such, is under the perception that the RDJNL command execution result and journal are being sent to the MS-SDKC 100B, but actually the RDJNL command execution result and the journal are sent to the MD-SDKC 100D that is posing as the MS-SDKC 100B.
Next, the MD-SDKC 100D, upon receiving the RDJNL command execution result and journal from the PDKC 100A, poses as the PDKC 100A and sends the RDJNL command execution result and journal to the MS-SDKC 100B (Step S105). This makes it possible for the MS-SDKC 100B to appropriately acquire the journal corresponding to the specified sequence number. The MS-SDKC 100B stores the acquired journal in the JVOL 111.
Next, the RDJNL command processing (second time and beyond), which is executed in a case where the MD-SDKC 100D has received an RDJNL command two or more times from the MS-SDKC 100B with respect to the JVOL 108 in the PDKC 100A after the MD-SDKC connection configuration processing has ended, will be explained.
The MD-SDKC 100D, upon receiving a RDJNL command from the MS-SDKC 100B for the JVOL 108 in the PDKC 100A, determines whether or not the specified sequence number corresponding to the received RDJNL command is larger than a value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved specified sequence number (Step S111).
In a case where the result is that the specified sequence number corresponding to the received RDJNL command is larger than the value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved specified sequence number (Step S111: Y), the MD-SDKC 100D, posing as the PDKC 100A, sends no-journal as the RDJNL command execution result to the MS-SDKC 100B (Step S112,
Alternatively, in a case where the result is that the specified sequence number corresponding to the received RDJNL command is not larger than the value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved specified sequence number (Step S111: N), the MD-SDKC 100D, posing as the MS-SDKC 100B, sends the RDJNL command and the specified sequence number to the JVOL 108 in the primary storage 100A (Step S113,
The PDKC 100A, upon receiving the RDJNL command, reads the journal corresponding to the specified sequence number from the JVOL 108 (Step S114), and sends the RDJNL command execution result and the journal to the source of the RDJNL command (Step S115). The PDKC 100A perceives the source of the RDJNL command as being the MS-SDKC 100B here, and as such, is under the perception that the RDJNL command execution result is being sent to the MS-SDKC 100B, but actually the RDJNL command execution result and the journal are sent to the MD-SDKC 100D that is posing as the MS-SDKC 100B.
Next, the MD-SDKC 100D, upon receiving the RDJNL command execution result and journal from the PDKC 100A, poses as the PDKC 100A and sends the RDJNL command execution result and journal to the MS-SDKC 100B (Step S116). This makes it possible for the MS-SDKC 100B to appropriately acquire the journal corresponding to a specified sequence number that is equal to or less than the value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved specified sequence number.
Next, journal formalization processing, formalized sequence number monitoring processing, and migration-destination journal acquisition processing will be explained.
The journal formalization processing is for reflecting a journal in the SJVOL 111 in the migration-source SVOL 110. The MS-SDKC 100B refers to formalized sequence information 117, identifies the sequence number of the journal to be formalized next, acquires the journal corresponding to the sequence number from the SJVOL 111, and on the basis of the journal, writes (updates) the journal data to the SVOL 110, and updates the formalized sequence number in the formalized sequence information 117 (
The formalized sequence number monitoring process is for the MD-SDKC 100D to monitor the progress of journal formalization in the MS-SDKC 100B. This formalized sequence number monitoring processing, for example, is executed at fixed intervals.
The MD-SDKC 100D acquires a formalized sequence number from the MS-SDKC 100B (Step S121,
In a case where the formalized sequence number is larger than the value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved sequence number (Step S122: Y), the MD-SDKC 100D starts an SVOL migration process (refer to
The migration-destination journal acquisition processing is for the MD-SDKC 100D to acquire a journal from the PDKC 100A, and is executed consecutively in order to acquire a journal having a sequence number after the sequence number having the value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved sequence number.
The MD-SDKC 100D, posing as the MS-SDKC 100B, sends the RDJNL command and the specified sequence number to the JVOL 108 in the primary storage 100A (Step S131). Furthermore, the specified sequence number is a sequence number after the sequence number having the value obtained by adding the maximum number of RDJNL commands issued in parallel to the saved sequence number.
The PDKC 100A, upon receiving the RDJNL command, reads the journal corresponding to the specified sequence number from the JVOL 108 (Step S132), and sends the RDJNL command execution result and the journal to the source of the RDJNL command (Step S133). The MD-SDKC 100D, upon receiving the RDJNL command execution result and the journal from the PDKC 100A, stores the journal in a JVOL 119 (Step S134,
Next, SVOL migration processing and journal data formalization processing during a data migration will be explained.
In the SVOL migration process, first of all, the MD-SDKC 100D adds to itself a VOL (a migration-destination SVOL 116) having a capacity of equal to or larger than the SVOL 110 that is the migration destination of the MS-SVOL 110 (Step S141,
Next, the MD-SDKC 100D, posing as the host 200, defines a path to the SVOL 110 in the MS-SDKC 100D (Step S142).
Next, the MD-SDKC 100D updates the values of all the bits in the difference bitmap 120 to values showing that the data migration has not been completed (Step S143).
Then, the MD-SDKC 100D assumes control and executes the processing of loop (B) (Step S145 through Step S149) targeted at the addresses of the areas for which the MS-SVOL 110 data migration has yet to be completed, thereby executing the data migration from the MS-SVOL 110 to the migration-destination SVOL 116 (
Specifically, the MD-SDKC 100D, posing as the host 200, sends a read command for reading the target address in the MS-SVOL 110 in the MD-SDKC 100B (Step S145). Upon receiving this read command, the MS-SDKC 100B reads the data of the SVOL 110 target-address in accordance with the read command (Step S146), and sends the read result and the data that was read (read data) to the source of the read command (Step S147). The MS-SDKC 100B perceives the read command source as being the host 200 here, and as such, perceives that the read result and the read data are being sent to the host 200, but actually the read result and the read data are sent to the MD-SDKC 100D that is posing as the host 200.
The MD-SDKC 100D writes the read data received from the MS-SDKC 100B to the target address of the migration-destination SVOL 116 (Step S148), and updates the bit of the area corresponding to the target address in the difference bitmap 120 to a value showing that data migration has been completed (Step S149).
Then, after executing the loop (B) processing targeted at all the addresses in the area of the MS-SVOL 110 for which data migration has not been completed, the MD-SDKC 100D ends the processing.
According to this processing, all the data of the SVOL 110 in the MS-SDKC 100B is migrated to the migration-destination SVOL 116 in the MD-SDKC 100D.
Next, journal data formalization processing during data migration will be explained. The journal data formalization processing during data migration, for example, is executed after the execution of the SVOL migration process has been started.
The MD-SDKC 100D reads the journal having the oldest (smallest) sequence number stored in the MD-JVOL 119 (Step S151). Next, the MD-SDKC 100D acquires the write-target address (target address) inside the journal (in the update information including the journal) (Step S152).
Next, the MD-SDKC 100D refers to the difference bitmap 120 to determine whether or not the data migration from the SVOL 110 has been completed for the target-address area in the migration-destination SVOL 116 (Step S153). In a case where the result is that the data migration is complete, the MD-SDKC 100D formalizes the processing-target journal. That is, the MD-SDKC 100D writes the journal data, which is the update content of the processing-target journal, to the target address in the migration-destination SVOL 116, and deletes the corresponding journal from the JVOL 119 (Step S154,
Alternatively, in a case where the result is that the data migration is not complete, the MD-SDKC 100D poses as the host 200 and sends a read command for reading the target address of the MS-SVOL 110 in the MS-SDKC 100B (Step S155). Upon receiving this read command, the MS-SDKC 100B reads the target-address data of the SVOL 110 in accordance with the read command (Step S156), and sends the read result and the read data to the source of the read command (Step S157). The MS-SDKC 100B perceives the read command source as being the host 200 here, and as such, perceives that the read result and the read data are being sent to the host 200, but actually the read result and the read data are sent to the MD-SDKC 100D that is posing as the host 200.
Next, the MD-SDKC 100D writes the read data received from the MS-SDKC 100B to the target address of the migration-destination SVOL 116 (Step S158), updates the difference bitmap 120 bit of the area corresponding to the target address to a value showing that data migration has been completed, and the MD-SDKC 100D formalizes the processing-target journal data (Step S154:
Next, processing after the completion of a data migration, which is executed after the SVOL 110 data migration has been completed, will be explained.
After the SVOL 110 data migration has been completed, the MD-SDKC 100D deletes the path (path r1-r2) between the MS-SDKC 100B and the MD-SDKC 100D (Step S161: refer to
Next, the computer system shown in
As shown in
A number of examples have been explained hereinabove, but it goes without saying that the present invention is not limited to these examples, and that various changes are possible without departing from the gist thereof.
For example, Example 1 is an example for migrating a PVOL, and Example 2 is an example for migrating an SVOL, but, for example, it is possible to combine Example 1 and Example 2 to migrate the PVOL and the SVOL in parallel.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2012/082361 | 12/13/2012 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2014/091600 | 6/19/2014 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6240494 | Nagasawa | May 2001 | B1 |
6640291 | Fujibayashi | Oct 2003 | B2 |
7080202 | Kasako | Jul 2006 | B2 |
7117327 | Hirakawa | Oct 2006 | B2 |
7165163 | Kasako | Jan 2007 | B2 |
7200727 | Kasako | Apr 2007 | B2 |
7203806 | Kasako | Apr 2007 | B2 |
7219201 | Kasako | May 2007 | B2 |
7240173 | Hirakawa | Jul 2007 | B2 |
7363461 | Kasako | Apr 2008 | B2 |
7415589 | Hirakawa | Aug 2008 | B2 |
7430648 | Kasako | Sep 2008 | B2 |
7464236 | Sano | Dec 2008 | B2 |
7472173 | Maruyama | Dec 2008 | B2 |
7660957 | Hirakawa | Feb 2010 | B2 |
7707377 | Kasako | Apr 2010 | B2 |
7975116 | Kasako | Jul 2011 | B2 |
8255652 | Kasako | Aug 2012 | B2 |
8291101 | Yan | Oct 2012 | B1 |
8375004 | Kondo | Feb 2013 | B2 |
8510515 | Yamamoto | Aug 2013 | B2 |
8904133 | Kono | Dec 2014 | B1 |
8935496 | Deguchi | Jan 2015 | B2 |
9052839 | Saito | Jun 2015 | B2 |
20020004857 | Arakawa | Jan 2002 | A1 |
20030177321 | Watanabe | Sep 2003 | A1 |
20040148443 | Achiwa | Jul 2004 | A1 |
20040153719 | Achiwa | Aug 2004 | A1 |
20050050115 | Kekre | Mar 2005 | A1 |
20050138308 | Morishita et al. | Jun 2005 | A1 |
20060277378 | Morishita | Dec 2006 | A1 |
20080086608 | Kano | Apr 2008 | A1 |
20080301386 | Matsui | Dec 2008 | A1 |
20090157846 | Shimozono et al. | Jun 2009 | A1 |
20110258406 | Suetsugu | Oct 2011 | A1 |
20130132693 | Kondo | May 2013 | A1 |
20140317366 | Sakata | Oct 2014 | A1 |
20150074364 | Kono | Mar 2015 | A1 |
20150121005 | Deguchi | Apr 2015 | A1 |
Number | Date | Country |
---|---|---|
2005-182222 | Jul 2005 | JP |
2008-165624 | Jul 2008 | JP |
2009-146106 | Jul 2009 | JP |
Number | Date | Country | |
---|---|---|---|
20150227322 A1 | Aug 2015 | US |