The present invention relates to an external storage device system. More specifically, the present invention relates to a technology for prolonging an operation period of a disk device (hereafter also referred to simply as a disk) and decreasing power consumption of a storage device system (hereafter referred to as a disk array). Here, the disk device's operation period signifies a period from the time to start using the disk device to the time when the disk device becomes unusable.
A disk array is a type of storage device systems connected to a computer. The disk array is also referred to as a RAID (Redundant Arrays of Inexpensive Disks) and constitutes a storage device system comprising a plurality of disk devices arranged in an array and a control section to control them. The disk array concurrently operates disk devices to accelerate read requests (requests to read data) and write requests (requests to write data) and to provide data with redundancy. Disk arrays are categorized into five levels depending on types of redundant data to be added and disk array configurations. This is described in non-patent document 1 (Daved A. Patterson, Garth Gibson, and Randy H. Katz, “A Case for Redundant Arrays of Inexpensive Disks (RAID)”, Computer Science Division Department of Electrical Engineering and Computer Sciences, University of California Berkeley, 1988).
Some disk devices used for a disk array may shorten a total active time when they are turned on 24 hours a day in comparison to a case where the disk devices are turned on only when needed. The total active time signifies the accumulated time during which the disk device is turned on. Such problem caused by deterioration and wear of parts constituting the disk devices. The disk device's total active time shortens when the disk device is turned on 24 hours a day and is operated continuously 24 hours a day. As a result, the disk device's operation period shortens. Such disk device is not suited for 24-hour continuous operations. The disk array capacity increases year after year. There is a trend of increasing the number of disk devices to be mounted. The power consumption for disk arrays tends to increase.
The present invention discloses a technology to prolong operation times of disk devices constituting a disk array. The present invention also discloses a technology to decrease the disk array's power consumption.
A computer accessing a disk array has a disk control instruction program which allows the disk array to turn on or off specific disk devices in it. The disk array has a disk power supply control instruction reception program and a disk power supply control circuit. The disk power supply control instruction reception program receives an instruction to turn on or off disk devices from the computer. The disk power supply control circuit turns on or off a disk device corresponding to an LU specified by the computer.
Embodiments of the present invention will be described in further detail with reference to the accompanying drawings.
The first embodiment will now be described.
(1) Description of the System Configuration
The disk array 200 comprises a CPU 210, memory 220, a cache 240, and a disk controller 250. The CPU 210 controls the disk array 200. The cache 240 stores user data of the disk array 200. The disk controller 250 controls a plurality of disk devices.
The disk controller 250 is connected to a plurality of FC disks 271 through 273 (hereafter referred to as an FC disk group) and a plurality of ATA disks 274 through 276 (hereafter referred to as an ATA disk group). The FC disk group and the ATA disk group each use a redundant configuration called RAID. The computer 100 accesses storage areas in the FC disks 271 through 273 as a SCSI logical unit (LU). Likewise, the computer 100 also accesses storage areas in the ATA disks 274 through 276 as a SCSI LU. An LU 261 represents the LU in the FC disks 271 through 273. An LU 262 represents the LU in the ATA disks 274 through 276.
According to the embodiment, the snapshot management program 226 in the disk array 200 manages the LU 261 and the LU 262 duplicatively. When data is written to the LU 261 according to the embodiment, the snapshot management program 226 writes the same data to the LU 262 to duplicate the data. In this manner, storing the same data in the LU 261 and the LU 262 is referred to as mirroring data. The LU 261 contains original data and is referred to as a mirror origin LU. The LU 262 contains a copy of the original data and is referred to as a mirror destination LU. The LU 262 is used to obtain a snapshot. The snapshot is used to back up data on the tape apparatus.
A disk power supply control circuit 280 is connected to the ATA disks 274 through 276. The disk power supply control circuit 280 turns on or off each ATA disk independently of the other ATA disks. The disk power supply control circuit 280 is provided with registers corresponding to the ATA disks 274 through 276. Turning on or off the register turns on or off the corresponding ATA disk.
The following describes programs and management tables in the disk array 200.
The memory 220 of the disk array 200 contains a RAID control program 221, a disk management program 222, a disk power supply control instruction reception program 223, a disk management table 224, a disk power supply control program 225, and a snapshot management program 226. The RAID control program 221 controls the disk array 200. The disk management program 222 manages the FC disks 271 through 273 and the ATA disks 274 through 276. The disk management table 224 records operation parameters and operation states of the FC disks 271 through 273 and the ATA disks 274 through 276. The disk power supply control instruction reception program 223 receives an instruction to turn on or off disk devices from the computer 100. This instruction is hereafter referred to as a disk power supply control instruction. The disk power supply control program 225 turns on or off the ATA disks 274 through 276 based on instructions received from the computer 100. The snapshot management program 226 controls snapshots. According to the embodiment, a snapshot instruction program 127 to be described is contained in the computer 100 and issues instructions to delete or obtain snapshots. In addition, the snapshot instruction program 127 issues ModeSelect commands concerning disk power supply control instructions for the ATA disks 274 through 276. Accordingly, the snapshot management program 226 accepts not only instructions to delete or obtain snapshots, but also disk power supply control instructions for the ATA disks 274 through 276.
The snapshot management program 226 also contains a disk access sub-program 227 and an LU mirror sub-program 228. The disk access sub-program 227 instructs the disk controller 250 to access disks in accordance with requests from the computer 100. The LU mirror sub-program 228 applies an update to one LU and another predetermined LU and writes the same user data to two LUs. The LU mirror sub-program 228 duplicates data written to the LU 261 for the LU 262.
The snapshot management program 226 further contains a non-mirror update monitoring sub-program 230, a non-mirror update position management sub-program 231, and a mirror resynchronization sub-program 229. When the data duplication is inactivated between the LU 261 and the LU 262 (non-mirror state), the non-mirror update monitoring sub-program 230 detects an update to the mirror origin LU. The non-mirror update position management sub-program 231 records the update position in an update position management table 232 to be described later. When the mirror resynchronization is performed to restart data duplication between the LU 261 and the LU 262, the mirror resynchronization sub-program 229 copies the updated part of the mirror origin LU to the mirror destination LU.
The update position management table 232 is used to manage the contents of data stored in the mirror origin LU and the mirror destination LU. When data in the mirror origin LU is updated in the non-mirror mode, the update position management table 232 records the update position in the mirror origin LU.
For example, the update position management table 232 is a bit map as shown in
The update bit indicates whether or not the LBA set corresponding to the update bit is updated in the non-mirror mode. The update bit is set to 1 when the LBA set is updated, or to 0 otherwise. The update bit is initially set to 0. For example, the update position management table 232 in
Referring now to
Returning now to
The input section 610 inputs parameters to be assigned to the disk management table 224. The output section 620 outputs information recorded in the disk management table 224. The input section 610 represents a mouse, a keyboard, and the like. The output section 620 represents a display, an liquid crystal panel, a buzzer, and the like.
Referring now to
The memory 120 stores a database program 126, a snapshot instruction program 127, and a disk power supply control instruction program 128. The snapshot instruction program 127 allows the disk array 200 to obtain snapshots. The disk power supply control instruction program 128 instructs to turn on or off disk devices in the disk array 200. The CPU 110 to control the computer 100 executes these programs. The snapshot instruction program 127 generates and issues SCSI ModeSelect commands. The ModeSelect commands include an instruction to turn on or off the ATA disks 274 through 276 from the disk power supply control instruction program 128 to the disk array 200. The ModeSelect commands also include an instruction to delete or obtain snapshots from the snapshot instruction program 127 to the disk array 200. The database program 126 accesses the LU 261, i.e., the mirror origin LU while the database is referenced or updated. The database program 126 also controls data update. The database program 126 stops accessing the disk array 200 at a check point that indicates a meaningful separation as database information. When data in the LU 261 becomes meaningful as database information, the database program 126 changes the disk array to a backup mode to back up that data. The backup mode ensures the consistency of data in the LU 261.
Referring now to
There has been described the system configuration of the embodiment.
(2) Obtaining and Deleting Snapshots
With reference to the flowchart in
Since the LU 262 stores data of the previously obtained snapshot, the snapshot instruction program 127 running on the computer 100 needs to nullify that snapshot and obtain a new snapshot. Hereafter, this is referred to as deletion of the snapshot. For this purpose, the snapshot instruction program 127 issues a ModeSelect command to the disk array 200 to delete the snapshot (step 2001).
The snapshot management program 226 in the disk array 200 receives the ModeSelect command (step 3001). Based on the disk power supply control instruction included in the ModeSelect command, the snapshot management program 226 turns on the ATA disks 274 through 276 (step 3002). The disk power supply control instruction turns on the disk devices corresponding to the LU 262. According to the instruction, the disk array 200 locates ATA disks constituting the LU 262 from the disk management table 224 in
The snapshot management program 226 inactivates the non-mirror update monitoring sub-program 230 and the non-mirror update position management sub-program 231 to stop recording updates to the LU 261 (step 3004). Thereafter, the update bit in the update position management table 232 is not changed by the non-mirror update position management sub-program 231.
The snapshot management program 226 then activates the mirror resynchronization sub-program 229. The mirror resynchronization sub-program 229 references the update position management table 232. When the LU 261 contains data that differs from data stored in the LU 262, the mirror resynchronization sub-program 229 copies that data from the LU 261 to the LU 262 to resume the mirror state between the LU 261 and LU 262 (step 3005). This is also referred to as resynchronization.
Upon completion of the resynchronization, the snapshot management program 226 inactivates the mirror resynchronization sub-program 229 (step 3006). The snapshot management program 226 sends the termination status of the ModeSelect command to the snapshot instruction program 127 on the computer 100 (step 3007). The snapshot instruction program 127 receives the termination status of the ModeSelect command to terminate the operation (step 2002).
The snapshot instruction program 127 on the computer 100 then issues a ModeSelect command to obtain a snapshot on the disk array 200 (step 2003).
The snapshot management program 226 on the disk array 200 receives the ModeSelect (step 3008). The snapshot management program 226 activates the non-mirror update monitoring sub-program 230 and the non-mirror update position management sub-program 231 to allow the update position management table 232 to record the position information about the data update applied to the LU 261 (step 3009). That is to say, when the LU 261 is updated, the update position management table 232 indicates the update bit set to 1 for the LBA set including the updated LBA to record the update.
The snapshot management program 226 then inactivates the LU mirror sub-program 228 to stop duplication of the LU 261 and the LU 262 (step 3010). This prevents the LU 262 as the mirror destination LU from reflecting the update to the LU 261 as the mirror origin LU.
The snapshot management program 226 then sends the termination status of the ModeSelect command to the snapshot instruction program 127 on the computer 100 (step 3011).
The snapshot instruction program 127 on the computer 100 receives the termination status of the ModeSelect command from the snapshot management program 226 (step 2004). The snapshot instruction program 127 supplies the backup server 400 with an instruction to obtain a backup via the communication I/F 160. The backup server 400 receives the termination report (step 2005). The snapshot instruction program 127 then issues a ModeSelect command to turn off the ATA disks 274 through 276 to the snapshot management program 226 (step 2006). The procedure to turn off the ATA disks 274 through 276 is the same as that at step 3002.
When receiving the ModeSelect command, the snapshot management program 226 in the disk array 200 turns off the ATA disks 274 through 276 according to the disk power supply control instruction contained in the ModeSelect command (step 3012).
There have been described the operations of the snapshot instruction program 127 and the snapshot management program 226 when snapshots are obtained or deleted.
(3) Write Operation
The following describes a write operation of the RAID control program 221 in the disk array 200. When the computer 100 writes data to the LU 261 to update the contents stored in the LU 261, the snapshot management program 226 receives a WRITE command and data issued to the LU 261.
Let us assume that the LU mirror sub-program 231 is active and that the non-mirror update monitoring sub-program 230 and the non-mirror update position management sub-program 231 are inactive. When receiving write data from the computer 100, the snapshot management program 226 writes the write data to both the LU 261 as the mirror origin LU and the LU 262 as the mirror destination LU.
Let us assume that the LU mirror sub-program 231 is inactive and the non-mirror update monitoring sub-program 230 and the non-mirror update position management sub-program are active. In this case, the snapshot management program 226 writes data to the LU 261 as the mirror origin LU. While the update position management table 232 records update positions, the snapshot management program 226 allows this table to set the update bit to 1 for the LBA set including the updated LBA.
Finally, the status is sent to the computer 100.
(4) Mirror Resynchronization
The following describes an example of the mirror resynchronization to copy data from the LU 261 to the LU 262 at step 3003 in
When there is an update record, the mirror resynchronization sub-program 229 references the update position management table 232. Based on the LBA set number corresponding to the update bit set to 1, the mirror resynchronization sub-program 229 calculates a read position on the LU 261 and a write position on the LU 262 (step 1003).
The mirror resynchronization sub-program 229 prevents data from being updated to the corresponding read/write position (step 1004). Based on the calculated read/write position, the mirror resynchronization sub-program 229 copies the data stored at the read position in the LU 261 as the mirror origin LU to the write position in the LU 262 as the mirror destination LU (step 1005). It should be noted that preventing the update is equivalent to inhibiting writing. The update is prevented to ensure the consistency of data between the LU 261 and the LU 262 after the mirror resynchronization.
The mirror resynchronization sub-program 229 then releases the prevention against updating data at the corresponding read/write position (step 1006). The mirror resynchronization sub-program 229 sets 0 to the update bit in the update position management table 232 correspondingly to the mirrored position due to the copy at step 1005 (step 1007), and then returns to step 1001.
There has been described the mirror resynchronization.
(5) Disk Operation Time Management
Using the input section 610 of the management terminal 600, a user can set the life of each of the FC disks 271 through 273 and the ATA disks 274 through 276 in the disk management table 224. The life signifies a product cycle estimated from the disk design specifications of the disk device, or a warranty period, or an accumulated operation time over which the disk is highly possibly subject to errors. It is assumed to find an accumulated time by totaling the time during which the disk device is turned on. When the accumulated time exceeds the life, there is a high possibility of causing an error.
The disk management program 222 records the disk device's accumulated time in the disk management table 224. The disk management program 222 counts the time during which the FC disks 271 through 273 and the ATA disks 274 through 276 are turned on. The disk management program 222 records the counted time as the accumulated time in the disk management table 224. The disk management program 222 compares the life of each of the FC disks 271 through 273 and the ATA disks 274 through 276 with the accumulated time. When the accumulated time exceeds the life, the disk management program 222 displays an alarm on the output section 620 of the management terminal 600.
According to the first embodiment as mentioned above, the snapshot management program obtains a snapshot of the LU 262 in synchronization with the timing when the backup server obtains a backup. It is possible to turn on the ATA disk device storing the snapshot data only when the snapshot management program obtains a snapshot and backs it up on the tape. In other words, the disk device can be turned off while no backup is created. This can extend the operation period of disk devices in the disk array 200 and decrease the power consumption of the disk array 200.
The disk array 200 receives the ModeSelect command issued from the computer 100. At this time, the disk controller 250 controls turning on or off the disk device. While the disk device is turned off, the computer 200 does not access the disk device. This can prevent a time-out condition of access requests from the computer 200.
The second embodiment will now be described.
(1) Description of the System Configuration
The memory 220 stores an LU protection program 234 that protects the LUs against reading or writing instead of the snapshot management program 226.
Unlike the example in
The disk power supply control instruction information storage area 132 stores an address map as shown in
The computer further contains a management I/F 150 that is connected to the management terminal 600.
There has been described the system configuration according to the second embodiment.
(2) Operation of the Disk Power Supply Control Instruction Program
The E-mail application 130 issues a request to write data to the disk array 200 for sequential access. Based on this request, the disk power supply control instruction program 128 in the computer 100 references the address map in
It may be preferable to instruct the disk array 200 to turn on or off disk devices corresponding to the LU based on a user input. For example, the user may use the input section 610 of the management terminal 600 to issue an instruction to the LU protection instruction program 131 so as to protect an LU against reading or writing. In this case, the disk power supply control instruction program 128 instructs the disk power supply control program 225 of the disk array 200 to turn off disk devices belonging to the LU that is instructed to be protected. The user may use the input section 610 of the management terminal 600 to issue an instruction to the LU protection instruction program 131 so as to release the protection of an LU against reading or writing. In this case, the disk power supply control instruction program 128 instructs the disk power supply control program 225 of the disk array 200 to turn on disk devices belonging to the LU that is instructed to be unprotected.
The embodiment has been described using the E-mail application as an example. Consequently, the flowchart in
The embodiment can operate only disk devices reading or writing data and stop the other disk devices not reading or writing data, making it possible to extend the disk array's operation period and decrease its power consumption.
The disk controller 250 controls turning on or off the disk devices in synchronization with the timing when the disk array 200 receives an instruction from the computer 100 to turn on or off the disk devices. While the disk device is turned off, the computer 200 does not access the disk device. This can prevent a time-out condition of access requests from the computer 200.
It is possible to extend the operation period and the total active time of the disk devices constituting the disk array and decrease the disk array's power consumption.
Number | Date | Country | Kind |
---|---|---|---|
2003-394919 | Nov 2003 | JP | national |
This is a continuation of U.S. patent application Ser. No. 10/777,832, filed Feb. 11, 2004, which application claims priority from Japan Patent Application No. 2003-394919, filed Nov. 26, 2003, the entire disclosure of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4980836 | Carter et al. | Dec 1990 | A |
5361364 | Nagashige et al. | Nov 1994 | A |
5423046 | Nunnelley et al. | Jun 1995 | A |
5461266 | Koreeda et al. | Oct 1995 | A |
5471099 | Larabell et al. | Nov 1995 | A |
5481733 | Douglis et al. | Jan 1996 | A |
5637932 | Koreeda et al. | Jun 1997 | A |
5691948 | Sakabe | Nov 1997 | A |
5734912 | Okuno et al. | Mar 1998 | A |
5790773 | DeKoning et al. | Aug 1998 | A |
5809316 | Gouzu | Sep 1998 | A |
5828568 | Sunakawa et al. | Oct 1998 | A |
5875063 | Corrington et al. | Feb 1999 | A |
5875120 | Matsushima et al. | Feb 1999 | A |
5884087 | White et al. | Mar 1999 | A |
5900007 | Nunnelley et al. | May 1999 | A |
5918059 | Tavallaei et al. | Jun 1999 | A |
5926404 | Zeller et al. | Jul 1999 | A |
5937433 | Lee et al. | Aug 1999 | A |
5960169 | Styczinski | Sep 1999 | A |
5964878 | Ryu | Oct 1999 | A |
6052791 | Chen et al. | Apr 2000 | A |
6057974 | Sukigara et al. | May 2000 | A |
6192481 | Deenadhayalan et al. | Feb 2001 | B1 |
6233691 | Atkinson | May 2001 | B1 |
6272591 | Grun | Aug 2001 | B2 |
6317839 | Wells | Nov 2001 | B1 |
6332175 | Birrell et al. | Dec 2001 | B1 |
6378068 | Foster et al. | Apr 2002 | B1 |
6425049 | Yamamoto et al. | Jul 2002 | B1 |
6512652 | Nelson et al. | Jan 2003 | B1 |
6583947 | Hakamata et al. | Jun 2003 | B1 |
6628469 | Hoyt | Sep 2003 | B1 |
6826005 | Hakamata et al. | Nov 2004 | B2 |
7035972 | Guha et al. | Apr 2006 | B2 |
7076607 | Miwa et al. | Jul 2006 | B2 |
7281088 | Yamazaki et al. | Oct 2007 | B2 |
7353406 | Yagisawa et al. | Apr 2008 | B2 |
20020007447 | Oue | Jan 2002 | A1 |
20020034379 | Tanaka | Mar 2002 | A1 |
20020038436 | Suzuki | Mar 2002 | A1 |
20020062387 | Yatziv | May 2002 | A1 |
20020144057 | Li et al. | Oct 2002 | A1 |
20020199129 | Bohrer et al. | Dec 2002 | A1 |
20030041283 | Murphy et al. | Feb 2003 | A1 |
20030097493 | Weast | May 2003 | A1 |
20030145166 | Miwa et al. | Jul 2003 | A1 |
20030189811 | Peeke et al. | Oct 2003 | A1 |
20030193732 | Hakamata et al. | Oct 2003 | A1 |
20030193733 | Hakamata et al. | Oct 2003 | A1 |
20030200473 | Fung | Oct 2003 | A1 |
20030212859 | Ellis et al. | Nov 2003 | A1 |
20030217300 | Fukumori et al. | Nov 2003 | A1 |
20040054939 | Guha et al. | Mar 2004 | A1 |
20040068670 | Suzuki et al. | Apr 2004 | A1 |
20040068672 | Fisk et al. | Apr 2004 | A1 |
20040148477 | Cochran | Jul 2004 | A1 |
20040225903 | Hirezaki et al. | Nov 2004 | A1 |
20040250148 | Tsirkel et al. | Dec 2004 | A1 |
20050259345 | Hakamata et al. | Nov 2005 | A1 |
Number | Date | Country |
---|---|---|
64-059413 | Mar 1989 | JP |
07-302138 | Nov 1995 | JP |
08-190762 | Jul 1996 | JP |
09-251353 | Sep 1997 | JP |
10-283123 | Oct 1998 | JP |
11-203057 | Jul 1999 | JP |
11-327811 | Nov 1999 | JP |
2000-100054 | Apr 2000 | JP |
2000-293314 | Oct 2000 | JP |
2002-032198 | Jan 2002 | JP |
2002-297320 | Oct 2002 | JP |
WO 03081416 | Oct 2003 | WO |
WO2004025628 | Mar 2004 | WO |
Number | Date | Country | |
---|---|---|---|
20080168227 A1 | Jul 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10777832 | Feb 2004 | US |
Child | 12038566 | US |