The present invention relates to a storage apparatus and data access method, and is suitably applied to a storage apparatus and data access method which execute extent overlap determination processing for a plurality of I/O requests in parallel.
A storage apparatus that is connected to host computers via a network comprises a plurality of magnetic disks, for example, as storage devices for storing data. The storage apparatus utilizes RAID (Redundant Arrays of Independent Disks) technology to establish redundancy of the storage areas of the plurality of storage devices and construct a RAID group. In addition, the storage apparatus provides the host computers with storage areas in the capacity required by the host computers and as logical volumes, from part of the RAID group.
Furthermore, if there is a data I/O request from the host computers, the storage apparatus executes exclusive extent processing, prior to executing the data I/O processing, so that there is no concurrent access to identical areas and to preserve the consistency of the access sequence. More specifically, exclusive extent processing is designed to prevent competing access to identical areas by determining whether or not there are I/O requests with overlapping extents (I/O request ranges) in the same logical volume among a plurality of I/O requests, and then if an overlap exists, awaiting I/O processing corresponding to the I/O requests, and if no overlap exists, continuing I/O processing corresponding to the I/O requests.
For example, PTL1 discloses an arrangement whereby, if an I/O request is sent to the storage apparatus, a control table of a logical volume targeted by the I/O request is locked and exclusive extent processing is executed.
However, in PTL1, if exclusive extent processing of an I/O request is being executed with respect to one logical volume, then exclusive extent processing of other I/O requests with respect to the logical volume enters a waiting state. As a result, due to an increase in the multiplicity of I/O requests with respect to identical volumes, there is an increase in the I/O requests awaiting exclusive extent processing and therefore a deterioration in response time performance.
The present invention was conceived in view of the aforementioned points and proposes a storage apparatus and data access method with which exclusive extent processing of a plurality of I/O requests is executed in parallel in order to improve the response time performance.
In order to achieve this object, the present invention provides a storage apparatus which is connected via a network to a host apparatus which requests data I/Os, comprising a plurality of microprocessors which control data I/O to and from a plurality of storage devices on the basis of the data I/O requests from the host apparatus; a first memory which stores, for each storage area of a predetermined range provided by the plurality of storage devices, counter values indicating the order of the I/Os to and from the storage areas; and a second memory which stores control information of the I/O requests for each of the I/O requests, wherein the microprocessors store, if there is one I/O request from the host apparatus, an I/O request range of the one I/O request in an area for storing control information of the one I/O request of the second memory, acquire, from the first memory, the counter value of the storage area which is the target of the one I/O request and store the counter value in the area for storing control information of the one I/O request of the second memory, and compare, if the counter value of the one I/O request is greater than the counter value of another I/O request, the I/O request range of the one I/O request stored in the second memory with the I/O request range of the other I/O request.
With this configuration, when executing I/O processing, the microprocessor is able to provide a counter value to each of the logical volumes which are targets of the I/O processing and determine the access sequence for access to the logical volumes on the basis of these counter values. By providing the counter values, the counter values may be acquired and access by other I/O processing may be restricted only while the counter values are being incremented. It is therefore possible to execute in parallel exclusive extent processing of a plurality of I/O requests with respect to the same logical volume, thereby improving the response time performance.
According to the present invention, the response time performance can be improved by executing, in parallel, exclusive extent processing of a plurality of I/O requests.
[
A block diagram showing the whole configuration of a computer system according to a first embodiment of the present invention.
[
A conceptual diagram showing an external configuration of a storage apparatus according to the first embodiment.
[
A block diagram showing a specific linear configuration of each logical substrate of a control module of the storage apparatus according to the first embodiment.
[
A block diagram showing an internal configuration of a microprocessor package according to the first embodiment.
[
A block diagram showing backend connections between storage media and disk adapters according to the first embodiment.
[
A conceptual view illustrating logical volumes according to the first embodiment.
[
A diagram showing an example of an ownership rights control table according to the first embodiment.
[
A conceptual view illustrating ownership rights according to the first embodiment.
[
A conceptual view providing an overview of conventional exclusive extent processing.
[
A conceptual view providing an overview of exclusive extent processing according to the first embodiment of the present invention.
[
A conceptual view showing an example of storage areas of the logical memory of the microprocessor package according to the first embodiment.
[
A conceptual view showing an example of storage points of counter values defined in the MP shared area according to the first embodiment.
[
A conceptual view showing an example of job control blocks defined in the MP shared area according to the first embodiment.
[
A table showing the details of extent management information which is stored in the job control blocks, according to the first embodiment.
[
A flowchart showing all I/O processing in the microprocessor of the storage apparatus according to the first embodiment.
[
A flowchart showing exclusive extent processing according to the first embodiment.
[
A flowchart showing details of exclusive extent processing according to the first embodiment.
[
A conceptual view of an example of an LDEV queue according to the first embodiment.
[
A conceptual view of an LDEV queue search system according to the first embodiment.
[
A chart showing an example of a search list according to the first embodiment.
[
A flowchart showing search list creation processing according to the first embodiment.
An embodiment of the present invention will be described in detail hereinbelow with reference to the drawings.
As shown in
The hosts 20 are computer apparatuses comprising information processing resources such as a CPU (Central Processing Unit) and a memory, and are configured from a personal computer, workstation, mainframe or similar, for example. The CPU functions as an arithmetic processing unit and controls the operation of the hosts 20 in accordance with programs and computational parameters and the like which are stored in the memory. Furthermore, the hosts 20 comprise information input devices such as a keyboard, switch, pointing device, and/or microphone, and an information output device such as a display monitor and/or speaker.
Furthermore, the host 20 is connected to the storage apparatus 10 via the network 40. The network 40 is configured from a SAN (Storage Area Network) or the like, for example, and inter-device communications are executed in accordance with the Fibre Channel Protocol, for example. Furthermore, the network 40 may also be a LAN (Local Area Network), the Internet, a public line or a dedicated line or similar, for example. If the network 40 is a LAN, inter-device communications are executed in accordance with the TCP/IP (Transmission Control Protocol/Internet Protocol) protocol, for example.
The storage apparatus 10 is configured from information processing resources such as a CPU and memory and a plurality of storage media 15a, 15b, and 15c (may also be referred to hereinbelow simply as ‘storage media 15’). Moreover, the storage apparatus 10 parses commands transmitted from the hosts 20 and executes data I/Os with respect to storage areas of the storage media 15.
The storage media 15 are configured, for example, from a plurality of hard disk drives (HDD: Hard Disk Drives) which are high-cost hard disk drives such as SSD (Solid State Disk), SCSI (Small Computer System Interface) disks or low-cost hard disk drives such as SATA (Serial AT Attachment) disks. The storage media 15 may also be referred to hereinbelow as ‘hard disks 15’.
The management server 30 is a computer apparatus comprising information processing resources such as a CPU and memory, and is configured from a personal computer, workstation, or mainframe or similar, for example. The CPU functions as an arithmetic processing unit and controls the operation of the management server 30 in accordance with programs and computational parameters and the like which are stored in the memory. Furthermore, the management server 30 comprises information input devices such as a keyboard, switch, pointing device, and/or microphone, or the like, and an information output device such as a monitor display and/or speaker, and manages the storage apparatus 10 in response to inputs from an operator or the like.
Furthermore, the management server 30 is connected to the storage apparatus 10 via the network 50. The network 50 is configured from a SAN or LAN or the like, for example, similarly to the network 40.
In addition, the program stored in the memory of the management server 30 is a program for managing the storage media 15 of the storage apparatus 10, and manages, for example, the configuration of the RAID group and the capacities of the logical volumes configured from part of the RAID group. The management server 30 changes the RAID configuration information and so forth by transmitting commands corresponding to user operations to the storage apparatus 10.
Module 100 comprises a control module 110 for controlling the overall operation of the storage apparatus 10 and a driving module 120 in which a plurality of disk drives are stored. As shown in
The rack boxes from which the control module 110 is configured are loaded with a plurality of logical substrates for controlling data I/Os between the hosts 20 and driver modules 120. Logical substrates which are loaded into the rack boxes which the control module 110 comprises include, for example, a CPU (Central Processing Unit) for controlling data I/Os, channel adapters for communicating with the hosts 20, and disk adapters for exercising control of data I/Os with respect to the disk drives stored in the driver modules 120.
The channel adapters 210 are channel interface boards. The channel adapters 210 have a function for the data transfer of commands received from the hosts via local routers (abbreviated as ‘LR’ in
The microprocessor packages 230 function as four-microprocessor CPUs. The microprocessor packages 230 include a memory and a processor which are connected via a memory controller hub (abbreviated as ‘MCH’ in the drawings) 232. The cache packages (abbreviated as ‘CPK’ in the drawings) 240 include a function for temporarily storing data. The cache packages 240 perform data transfers via cache memory adapters (abbreviated as ‘CMA’ in the drawings). The path switches 250 interconnect the microprocessor packages 230, the channel adapters 210, the disk adapters 220, and the cache packages 240 and include a function for distributing data by means of switches (abbreviated as ‘SW’ in the drawings).
Data transfer in the control module 110 will now be described. First, data is transmitted from the hosts 20 via the channel adapters 210 and the data transmitted to the channel adapters 210 is stored. Notification that data has been transmitted from the hosts 20 is then sent to the microprocessor packages 230. Any of the microprocessors in the microprocessor packages 230 then acquire the data stored in the channel adapters 210. In addition, the microprocessors execute data reads/writes and so on based on instructions from the hosts 20 and store the execution results in the cache packages 240. The microprocessor then informs the channel adapters 210 that data read/write processing or the like has been executed. Furthermore, the channel adapters 210 then transmit the processing results stored in the cache packages 240 to the hosts 20.
It is assumed in the foregoing that the data transmitted from the hosts 20 is stored in the channel adapters 210 but storage is not limited to this example. For example, the data transmitted from the hosts 20 may also be stored in shared memory (not shown) separate from the channel adapter 210. In this case, the microprocessors of the microprocessor packages 230 acquire the data stored in the shared memory and execute data reads/writes and so on based on instructions from the hosts 20.
The logical memory 231 is a local memory in a microprocessor package 230 and temporarily stores programs used in the execution of the CPU 235 and parameters and so on which suitably vary in its execution. The local memory 231 is mutually connected to a CPU 235 by means of a hub which is configured from a memory controller hub 232 and a bus which is configured from a front side bus 237, and so forth.
The flash memory 234 is an involatile memory which stores programs and computation parameters and so on which are used by the CPU 235. The flash memory 234 is mutually connected to the CPU 235 by means of a hub which is configured from the I/O controller hub 233 and a bus which is configured from the front side bus 237, and so forth.
The CPU 235 functions as an arithmetic processing device and a controller and controls the overall operation in the microprocessor packages 230 according to various programs. In addition, the CPU 235 is configured from four Microprocessors (MP) 236a, 236b, 236c, 236d (hereinafter referred to as ‘microprocessors 236’).
The disk adapters 220 transmit data read/write commands to the driver modules 120 based on control of the microprocessors 236 in the microprocessor package 230. In addition, the disk adapters 220 transmit the data read/write commands via the plurality of SAS controllers 221. The SAS controllers 221 transmit commands to hard disks which are data read/write targets.
Furthermore, as shown in
As shown in
In addition, in this embodiment, LDEV ownership rights are configured for each microprocessor package 230. The LDEV ownership rights are rights for accessing LDEV control information. If LDEV ownership rights have not been configured for each microprocessor package 230, I/O processing must be executed with respect to the target logical volume after restricting access to the logical volumes of other microprocessor packages. In this case, information indicating which microprocessor package 230 has accessed which logical volume is stored in the aforementioned shared memory.
The microprocessors 236 may therefore need to access the shared memory when executing exclusive extent processing. However, the time for accessing the shared memory will then be from a few times to several hundred times the time required to access the memory in the microprocessor package 230. Moreover, because, when accessing data stored in the shared memory, access is made with the shared memory locked, if the microprocessors 236 of the plurality of microprocessor packages 230 share the shared memory, the processing time for accessing the shared memory is prolonged.
Therefore, in this embodiment, by configuring LDEV ownership rights for each of the microprocessor packages 230, access to the shared memory can be eliminated in the data read/write processing in order to improve access performance. In addition, by configuring the LDEV ownership rights, the control information which is required in exclusive extent processing (described subsequently) can be managed only in an area which is shared by the microprocessors 236 in the microprocessor packages 230.
For example, an ownership rights control table 700 for configuring ownership rights for each of the logical volumes can be stored in the memory of the storage apparatus 10 so that ownership rights can be configured for each of the microprocessor packages 230. As shown in
As shown in
Conventional exclusive extent processing and the exclusive extent processing according to this embodiment will be compared and described here. As shown in
More specifically, conventionally, in exclusive extent processing it is determined whether or not there is a lock on I/O control information (SM) of access-target logical volumes. Subsequently, if there is no lock on the I/O control information of the access-target logical volumes, exclusive extent processing is executed in a state where there is a lock on the I/O control information. In addition, a state is assumed in which the I/O control information in logical volume units is locked while the exclusive extent processing is being executed. Other I/O processing therefore enters a waiting state until the lock is released while the exclusive extent processing is being executed.
Therefore, in this embodiment, if there are multiple I/O requests with respect to the same volume, a counter value is assigned to each I/O request so that exclusive extent processing of a plurality of I/O requests is executed in parallel. More specifically, I/O control information is only locked when a counter values assigned to logical volume units is acquired for each I/O request. As a result, the exclusive extent processing can be executed in parallel simply by performing exclusion processing so that two or more I/O requests do not acquire counter values simultaneously. To this end, as shown in
Since the logical memory 231 is shared by four microprocessors 236, information in the logical memory 231 may be updated simultaneously by a plurality of the microprocessors 236. Therefore, in order to retain consistency of information in the logical memory 231, access to the logical memory 231 must be restricted if the plurality of microprocessors 236 update this information. Furthermore, the MP shared area 1101 is an area which stores information shared and used by a plurality of microprocessors 236, and which stores counter values indicating the I/O order, for example. Furthermore, the dedicated areas 1102 are areas which store information used when each of the microprocessors 236 accesses the logical volume (LDEV) to which it possesses ownership rights, and which store trace information indicating what kind of processing is performed by the microprocessors 236, for example.
Furthermore,
The job control blocks will be described next with reference to
A job is configured from a command (CCW chain) which indicates an I/O operation from a host 20 which is connected to a channel adapter 210, and which is a single unit of an I/O request. Examples of CCW chains include, for example, a command ‘x63’ to define extent ranges, a command ‘x47’ for searching for target records, and a command ‘x06’ for reading data, and so on.
Furthermore, the job control blocks store job-related information such as extent ranges, counter values, and I/O attributes such as read processing or write processing. In addition, as shown in
When executing jobs such as I/O processing, the microprocessors 236 each refer to the job control blocks of each job stored in the MP shared area 1101 and control job execution. The microprocessors 236 use the job control blocks which are allocated until job execution ends.
Furthermore, after the job ends, the job control blocks enter a free state in which they can be used by other job control blocks. Furthermore, a job control block which is in a usable state is used to control jobs which are executed subsequently. The job control blocks are used repeatedly by a plurality of jobs.
Furthermore, the job control blocks are each assigned an individual JCB number and the microprocessors use the JCB numbers to determine the job processing order and so on. The job control blocks can also be defined in 8K units for each of the microprocessors 236. That is, a 32K-job control block can be defined for a single microprocessor package 230.
The extent processing controller is information for managing the status of the I/O processing, i.e. information such as an extent reservation bit, an exclusive extent waiting bit, an extent significant bit, a counter value significant bit, and so forth.
The extent reservation bit is information which is configured (bit ON) when it is determined, as a result of a job executing exclusive extent processing, that I/O processing can be continued. The exclusive extent waiting bit is configured when, as a result of a job executing exclusive extent processing, it is determined that I/O processing cannot be continued, that is, that I/O processing is in a waiting state.
Furthermore, the extent significant bit is configured in cases where the ‘start position address’ and ‘end position address’ in the job control blocks are valid values. In other words, when this bit is not configured, the ‘start position address’ and ‘end position address’ in the job control blocks are invalid and cannot be trusted.
Furthermore, the counter value significant bits are configured when the microprocessors 236 acquire counter values in the MP shared area 1101. That is, when these bits are not configured, the ‘counter values’ stored in the job control blocks are invalid and cannot be trusted.
Furthermore, if it is detected in step S100 that data has been transmitted from the hosts 20, the microprocessors 236 execute exclusive extent processing to execute the I/O data (S200). The exclusive extent processing in step S200 will be described in detail subsequently.
The microprocessors 236 then execute I/O processing (I/O) based on the I/O data transmitted from the hosts 20 after executing exclusive extent processing in step S200 (S300). Specifically, the microprocessors 236 execute reading/writing of the data stored on the hard disks 15.
The microprocessors 236 then execute I/O end processing (S400). More specifically, the microprocessors 236 notify the channel adapters 210 that I/O processing has ended in order to inform the hosts 20 that I/O processing has been executed.
The job control blocks are areas assigned to each I/O processing and which store control information for I/O processing when the microprocessors 236 execute the I/O processing. Hence the microprocessors 236 store the access range for their own I/O processing in the job control block which corresponds to their own I/O processing. Furthermore, the access range is indicated by the start position address and end position address of the logical volume which is the access target.
The microprocessors 236 then turn ON the extent significant bit of the extent management information 1302 stored in their own job control blocks after storing their own access range in step S202 in the job control blocks (S204).
As mentioned hereinabove, the extent significant bit is a flag which is configured in cases where the ‘start position address’ and ‘end position address’ are valid values in the job control blocks, and is a flag which is configured when the microprocessors 236 store their own access range in the job control blocks. The microprocessors 236 execute exclusive extent processing if the extent significant bit of another I/O job control block is ON, that is, if the other I/O access range is valid.
The microprocessors 236 then lock the counter value area of the access-target logical volume (LDEV) (S206). More specifically, the microprocessors 236 lock the area storing the access-target logical volume counter value, in the MP shared area 1101 of the logical memory 231 in the microprocessor package 230.
The microprocessors 236 subsequently acquire the counter values of the access-target logical volumes in the MP shared area 1101 of the logical memory 231 in the microprocessor package 230, and store these counter values in the job control blocks corresponding to their own I/O processing (S208). The microprocessors 236 then add one to (increment by one) the counter values of the access-target logical volumes in the MP shared area 1101 of the logical memory 231 in the microprocessor package 230 (S210).
The microprocessors 236 then release the lock on the counter value area of the access-target logical volumes in the MP shared area 1101 of the logical memory 231 in the access microprocessor package 230 (S212).
The microprocessors 236 then turn ON the counter value significant bit of the extent management information 1302 stored in their own job control blocks (S214). Like the extent significant bits, the counter value significant bits are flags to which the microprocessors 236 refer when executing exclusive extent processing. The microprocessors 236 execute exclusive extent processing if the counter value significant bit of another I/O is ON, that is, if the counter value is valid.
The microprocessors 236 then execute LDEV queue search processing (S216). The LDEV queue is an I/O wait queue in the microprocessor package 230, i.e. an LDEV unit queue. The LDEV queue is a wait queue which links job control blocks of I/O which access or are accessing the LDEV. The act of introducing data to a queue is known as ‘enqueue’ and the act of taking data from a queue is known as ‘dequeue’. Processing to search for LDEV queues in step S216 will be described in detail subsequently.
The microprocessors 236 then execute exclusive extent determination processing (S218). More specifically, exclusive extent determination processing is processing with which [the microprocessors 236] compare the extent range of job control blocks of the LDEV queue retrieved in step S216 with the extent range of their own I/O job control blocks.
Details of the exclusive extent processing in step S218 will be described in detail subsequently.
The microprocessors 230 then refer to the extent significant bits of the extent management information 1401 of job control blocks of other I/O to determine whether or not the extents of the other I/O are valid (S404). In specific terms, the microprocessors 230 determine that an extent is valid if the extent significant bit is ON. If it determined in step S404 that the extent of the other I/O is invalid, the microprocessors 230 execute the processing of step S412 and beyond.
If it is determined in step S404 that the extent of the other I/O is valid, the microprocessors 236 then refer to the counter value significant bits of the extent management information 1401 of job control blocks of other I/O to determine whether or not the extent of the other I/O are valid (S406). In specific terms, the microprocessors 236 determine that a counter value is valid if the counter value significant bit is ON. If it determined in step S406 that the counter value of the other I/O is invalid, the microprocessors 236 execute the processing of step S412 and beyond.
If it is determined in step S406 that the extent of the other I/O is valid, the microprocessors 236 then compare their own I/O counter value with the counter value of the other I/O, and determine whether or not the counter value of its own I/O is greater than the counter value of the other I/O (S408). If the counter value of its own I/O is greater than the counter value of the other I/O, its own I/O follows on from the other I/O, and it is therefore necessary to determine whether or not there are overlapping extent ranges. If, on the other hand, the counter value of its own I/O is smaller than the counter value of the other I/O, the other I/O follows on from its own I/O. In this case, because its own I/O is processed in advance of the other I/O, it is not necessary to determine whether or not there are overlapping extent ranges.
If it determined in step S408 that the counter value of the other I/O is smaller than the counter value of the other I/O, the microprocessors 236 execute the processing of step S412 and beyond. If, on the other hand, it is determined in step S408 that the counter value of its own I/O is greater than the counter value of the other I/O, the microprocessors 236 determine whether or not there is no overlap between the extent range of its own I/O with the extent range of the other I/O (S410). In specific terms, the microprocessors 236 compare ranges indicated by the start position address and the end position address of the extent management information of the job control blocks of their own I/O and other I/O in order to determine whether or not there is a degree of overlap between these ranges.
If it is determined in step S410 that there is no overlap between the extent range of its own I/O with the extent range of the other I/O, the microprocessors 236 determine whether or not its own I/O has been compared with all the other I/O (S412). In specific terms, the microprocessors 236 determine whether or not the management information of the job control blocks of their own I/O has been compared with the management information of the job control blocks of all the other I/O listed in the search list shown in
Furthermore, if it is determined in step S410 that there is an overlap between the extent range of its own I/O with the extent range of the other I/O, the microprocessors 236 turn ON the exclusive extent waiting bit (S418). More specifically, the microprocessors 236 then turn ON the exclusive extent waiting bit of the extent management information of the job control blocks shown in
If it is then determined in step S412 that their own I/O has been compared with all the other I/O, the microprocessors 236 then turn OFF the exclusive extent waiting bit extent of the extent management information of their own job control blocks and turn ON the extent reservation bit (S414).
The exclusive extent waiting bit and extent reservation bit of the extent management information have an opposing relationship. If the exclusive extent waiting bit is ON, this indicates that the microprocessors 236 are unable to continue their own I/O processing and are waiting for the end of the other I/O processing with which there is an extent range overlap. Furthermore, a case where the extent reservation bit is ON is configured in cases where the microprocessors 236 determine that their own I/O processing can be continued. Details of exclusive extent processing were described hereinabove.
Subsequently, details of LDEV queue search processing will be provided next. As shown in
For example, if the job control blocks which access or are accessing LDEV 0 are JCB (9), JCB (3), and JCB (5), information is stored indicating that the queues of the MP 0 LDEV 0 are waiting queues linking the three job control blocks JCB (9), JCB (3), and JCB (5). When searching for the LDEV queues, a search is performed for all the job control blocks of the target LDEVs which are stored in the memory of four microprocessors, namely MP 0, MP 1, MP 3, and MP 4.
In specific terms, the microprocessors 236 search for their own LDEV queues and the LDEV queues of the other microprocessors in the same microprocessor package 230. For example, as shown in
When I/O processing is initiated, the job control blocks of new I/O processing are enqueued starting with the MRU of the LDEV queues. Normally, when executing a search in order working from the LRU toward the MRU, leakage in the search during queue operation will likely occur. For example, when searching for the LDEV queues, the job control blocks in the search are dequeued and job control blocks of the same JCB number as the job control blocks dequeued by subsequent I/O processing are enqueued starting with the MRU. In this case, LDEV queue search leakage arises between the job control blocks being searched and the job control blocks which are dequeued starting with the MRU.
Suppose, for example, that in a certain LDEV queue, the queues are linked starting with the LRU in the order JCB (3), JCB (1), and then JCB (9), and that JCB (1) is dequeued when the microprocessors 236 are searching for the JCB (1). When JCB (1) is being used by other I/O processing, the JCB (1) is then enqueued starting with the MRU.
Here, the queues are linked starting with the LRU in the order JCB (3), JCB (9), and then JCB (1). At that point, the microprocessors 236 searching for the queues starting with the LRU end the search based on the fact that there is no linked queue following the MRU JCB (1) and the JCB (9) is leaked from the search target.
Therefore, in this embodiment, search leakage is prevented by making the search direction extend not from the LRU to the MRU but instead from the MRU to the LRU. However, in cases where the LDEV queue search processing is executed starting with the MRU, if queue operations such as dequeuing or enqueuing are generated in the job control blocks being searched for and if a queue returns to the MRU, the search must be executed once again starting with the MRU.
When the processing time for the search processing of a single job control block is extended by the microprocessors 236, the queue operation of the job control blocks will probably occur frequently and the search processing will take time. Therefore, before LDEV queue search processing is executed, a search list for a search starting with the MRU and ending with the LRU is created and search processing is executed by referring to the search list. As a result, the processing time for the search processing can be shortened while preventing search leakage.
Furthermore, when a search list indicating the search order of job control blocks is created, the JCB numbers of the job control blocks linked to the LDEV queue of each of the microprocessors 236 and the JCB generation numbers are acquired. The job control blocks are used as areas for storing control information of I/O processing by the plurality of I/O processes. The microprocessors 236 identify which job control blocks are used by which I/O processing from the JCB numbers and generation numbers of the job control blocks.
The MP number field 1901 stores numbers identifying microprocessors 236 in those microprocessor packages 230 to which the microprocessors 236 being searched belong. The JCB number field 1902 stores JCB numbers of the job control blocks linked to the LDEV queue. The generation number field 1903 stores the generation numbers of each of the job control blocks.
The microprocessors 236 acquire the JCB numbers stored in the search list and execute exclusive extent processing in the order of the search list. Although I/O processing will likely also be initiated from the point where the microprocessors 236 create the search list, it is not clear that the I/O processing follows its own I/O processing and hence need not be made a search target.
In reality, the microprocessors 236 replace the variable ‘number of JCBs’ with ‘0’ (S302), and the variable ‘number of MPs’ with ‘0’ (S304). The microprocessors 236 then add ‘1’ to the variable ‘number of MPs’ (S306), and add ‘1’ to the variable ‘number of JCBs’ (S308).
In the subsequent determination processing, by determining whether or not the variable ‘number of MPs’ is equal to or more than the number ‘4’ in the microprocessor package 230 and determining whether or not the variable ‘number of JCBs’ is equal to or more than ‘8K’, a search list can be created by taking, as search targets, all the job control blocks in the microprocessor package 230.
The microprocessors 236 then acquire a terminal (S310). In specific terms, the microprocessors 236 acquire a specific job control block which is stored in the microprocessor package 230 as a terminal. ‘Terminal’ signifies a search processing start value.
The microprocessors 236 then acquire an element which precedes the terminal acquired in step S310 (S312). More specifically, the microprocessors 236 acquire job control blocks closer to the LRU than the job control blocks acquired in step S310 (S314).
The microprocessors 236 then determine whether or not the JCB number of the job control blocks acquired in step S312 is a valid JCB number (S314). Numbers in a quantity ranging from 0 to a prescribed number are assigned to the JCB numbers. The microprocessors 236 therefore determine whether or not the JCB number is a valid JCB number depending on whether the JCB number exceeds the prescribed number. In other words, if the JCB number is no more than the prescribed number, the JCB number is validated, and if the JCB number is larger than the prescribed number, the JCB number is invalidated.
Furthermore, if it is determined in step S314 that the JCB number is valid, the microprocessors 236 then store the JCB numbers and generation numbers of the job control blocks acquired in the search list (S316). In specific terms, the microprocessors 236 add the MP numbers of the microprocessors 236 pertaining to the job control blocks searched for in the search list shown in
If it determined in step S314 that a JCB number is invalid, the microprocessors 236 execute the processing of step S320.
The microprocessors 236 then determine whether the variable ‘the number of JCBs’ is equal to or more than 8K (S318). In step S318, if the variable ‘the number of JCBs’ is smaller than 8K, the migration processing of step S308 is repeated. In step S318, if the variable ‘the number of JCBs’ is equal to or more than 8K, the microprocessors 236 determine whether or not the variable ‘number of MPs’ is equal to or more than four (S320). In step S320, if the variable ‘the number of MPs’ is smaller than four, the processing of step S306 and beyond is repeated. In step S320, if the variable ‘the number of MPs’ is equal to or more than four, the processing is ended.
As described hereinabove, with the storage apparatus 10 according to this embodiment, if there is an I/O request from a host 20, the microprocessors 236 store the access range of the I/O request in the job control blocks, turn ON the extent significant bit of the job control blocks, lock the counter value areas of the logical volumes which are access targets of the I/O requests of the MP shared area 1101, acquire the counter values stored in the counter value areas, store the counter values in the job control blocks, add ‘1’ to (increment by one) the counter values of the MP shared area 1101, and then release the lock on the counter value areas.
Furthermore, when executing their own I/O requests, the microprocessors 236 search for the I/O queues (LDEV queues) of the access-target logical volumes, compare the counter values of the searched for I/O requests with the counter values of their own I/O requests, and if the counter values of their own I/O requests are greater than the counter values of the searched for I/O requests, determine whether or not there is an extent range overlap, executing I/O processing if there is no extent range overlap and waiting to execute I/O processing if there is an extent range overlap.
Thus, according to this embodiment, when executing I/O processing, the microprocessors 236 are able to provide a counter value to each of the logical volumes which are targets for the I/O processing and determine the access sequence for access to the logical volumes on the basis of these counter values.
Conventionally access of the other I/O processing to the logical volumes must be restricted while a determination is made as to whether or not there is an extent range overlap, but by providing counter values, the counter values may be acquired and access by other I/O processing may be restricted only while the counter values are being incremented. It is therefore possible to execute, in parallel, exclusive extent processing of a plurality of I/O requests with respect to the same logical volume, thereby improving the response time performance.
Note that although a case was described in the above embodiment in which the microprocessors 236 implement exclusive extent processing and I/O processing and so forth on the basis of various programs stored in memory such as the logical memory 231 and flash memory 234 in the microprocessor packages 230, the present invention is not limited to such a case, for example various functions may be implemented by storing various programs in storage devices outside the microprocessor package 230 and then calling up these programs.
Moreover, in the above embodiment, a case was described in which four microprocessors 236 are provided in the microprocessor packages 230, but the present invention is not limited to this case, for example more than four microprocessors 236 may be provided in the microprocessor packages 230 and the exclusive extent processing according to this embodiment may be executed in each of the microprocessors 236.
Moreover, in the above embodiment, a case was described where the ownership rights of the microprocessor packages 230 are configured for each of the logical volumes, but the present invention is not limited to such a case; for example, if a virtual volume is provided to the hosts 20 by means of a Thin Provisioning function, ownership rights to the microprocessor packages 230 may also be configured for each virtual volume.
The present invention can be applied to a storage apparatus with which the response time performance can be improved by executing, in parallel, exclusive extent processing of a plurality of I/O requests.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2010/005403 | 9/2/2010 | WO | 00 | 9/14/2010 |