This application claim priority from Chinese Patent Application Number CN201410813708.9, titled “METHOD AND APPARATUS FOR MANAGING RESOURCES BASED ON QUOTA” filed on Dec. 19, 2014 at the State Intellectual Property Office, China, the contents of which are herein incorporated by reference in entirety.
Embodiments of the present disclosure relate to resource management.
In the field of computers, quota may be referred to generally as a mechanism for tracking and controlling resource consumption of user entities, so as to prevent resource over-consumption and also make/generate statistics on resource allocation and report resource allocations. Typically a resource may include, for example, disk space, memory, CPU, etc.; and user entities may include, for example, individual users, user groups, processes, etc. Consider a file system, for example, where a quota may be used to prevent individual users or user groups from overusing disk space in a file system, especially in multi-user environments.
In view of the above and other potential problems, various embodiments of the present disclosure propose a resource management solution that may be adapted to dynamic changes of the amount of resources.
Embodiments of the present disclosure provide a quota-based resource management method that may include configuring a resource quota for each user entity of a plurality of user entities based on a first policy or a second policy, a first policy indicating that a resource quota is to be configured using a percentage of an amount of resources allowed to be configured with respect to an amount of all resources, a second policy indicating that the resource quota is to be configured using the amount of resources allowed to be configured; and applying the resource quota according to the first policy or the second policy.
Through the detailed description of some embodiments of the present disclosure in the accompanying drawings, the features, advantages and other aspects of the present disclosure will become more apparent, wherein several embodiments of the present disclosure are shown for the illustration purpose only, rather than for limiting. In the accompanying drawings:
With reference to the figures, detailed description is presented below to various embodiments of the present disclosure. The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
In this disclosure, “resources” may include, but are not limited to, disk space, memory, CPU, and the like. In addition, “user entities” may include, but are not limited to, individual users, user groups, processes, and the like.
In one embodiment, to apply quota mechanisms, a storage administrator may be required to set quota limits for individual users or user groups. In a further embodiment, usually, setting a quota may be based on current capacity configured for a file system. In a further embodiment, for example, suppose the capacity of a file system is 10 terabytes, and if there are three individual users sharing the file system: User1 a senior engineer, User2 a junior engineer and User3 an intern engineer, in this case, a storage administrator might set quota limits in a file system to be 5 terabytes for User1, 4 terabytes for User2 and 1 terabytes for User3.
In certain embodiment, however, under different circumstances/conditions, a file system's overall capacity may be re-sized. In a further embodiment, for example, if new disks are installed to a file system, the file system may be expanded accordingly. In a further embodiment, many modern file systems may even support thin provisioning, which may automatically re-size a file system's capacity based on actual storage consumption. In a further embodiment, where a file system's capacity may be expanded or shrunk, a storage administrator may have to change quota configuration for user entities, otherwise storage capacity may be overused or underutilized. In a further embodiment, considering the above example, when a file system of 10 terabytes is shrunk to 4 terabytes, if a storage administrator does not change quota settings, a junior engineer may use up the entire capacity and leave nothing to other users in the group. Therefore, there is a need for an efficient resource management solution that may be adapted to dynamic changes of resources.
Embodiments of the present disclosure provide a quota-based resource management system and method. One embodiment may include configuring a resource quota for each user entity of a plurality of user entities based on a first policy or a second policy. A further embodiment may include a first policy indicating that a resource quota is to be configured using a percentage of an amount of resources allowed to be configured with respect to an amount of all resources. A further embodiment may include a second policy indicating that a resource quota is to be configured using an amount of resources allowed to be configured. A further embodiment may include applying a resource quota according to a first policy or a second policy
In one embodiment, configuring a resource quota for each user entity of a plurality of user entities based on a first policy or a second policy may include creating a quota database record for the each user entity. In a further embodiment a quota database record may at least include: an identifier field for identifying a user entity to which the quota database record is directed. A further embodiment may include a first resource upper limit field for indicating a resource upper limit which may be allowed to be allocated to a respective user entity. A further embodiment may include a resource usage field for indicating current resource usage of a respective user entity. A further embodiment may include a policy field for indicating whether a resource upper limit is configured for a respective user entity based on a first policy or a second policy.
In one embodiment, if the resource quota may be configured for the respective user entity based on the first policy, content of a first resource upper limit field indicates a percentage of a maximum amount of resources which may be allowed to be allocated to a respective user entity with respect to an amount of all resources.
In one embodiment, applying a resource quota according to a first policy or a second policy may include: in response to receiving a resource allocation request from a user entity, checking a policy field of a quota database record for a user entity so as to determine whether a resource quota for the user entity is configured based on a first policy or a second policy. A further embodiment may include determining according, at least in part, to a determined policy, whether or not to allocate a requested resource to a user entity.
In one embodiment, determining according, at least in part, to a determined policy, whether or not to allocate the requested resource to a user entity may include: if a resource quota may be configured for a user entity based on a first policy, determining according, at least in part, to a first policy, whether or not to allocate a requested resource to a user entity.
In one embodiment, determining according, at least in part, to a first policy, whether or not to allocate a requested resource to a user entity may include: calculating/computing a maximum amount of resources which may be allowed to be allocated to the user entity, based on content in a first resource upper limit field of a quota database record for the user entity. A further embodiment may include calculating/computing a sum of current resource usage of a user entity and an amount of a requested resources; comparing a sum with a maximum amount of resources. A further embodiment may include allocating a requested resource to a user entity in response to a sum being not exceeding a maximum amount of resources.
In one embodiment, a quota database record for each user entity may further include a second resource upper limit field for indicating a resource threshold which may be allowed to be allocated to a respective user entity. A further embodiment may include in response to current resource usage of a respective user entity exceeding a resource threshold, sending a message to a respective user entity to warn that a current resource usage of a respective user entity may exceed a resource upper limit
In one embodiment, applying a resource quota according to a first policy or a second policy may include: specifying a format of a quota report. A further embodiment may include sending a quota reporting request to a user entity so as to request a user entity reporting information in a quota database record for a user entity using a specified format.
In one embodiment, a specified format of a quota format may include one of: a percentage format, indicating that a user entity should report content in an identifier field, may use a percentage of a maximum amount of resources which may be allowed to be allocated to a respective user entity with respect to an amount of all resources to report content in a first resource upper limit field, and may use a percentage of an amount of resources which may have been used by a respective user entity with respect to an amount of all resources to report content in a resource usage field. A further embodiment may include an amount format, indicating a user entity may report content in an identifier field, may use a maximum amount of resources which may be allowed to be allocated to a respective user entity to report content in a first resource upper limit field. A further embodiment may include use an amount of resources which may have been used by a respective user entity to report content in a resource usage field. A further embodiment may include a default format, indicating a user entity may report contents in all fields of a quota database record for a user entity.
Embodiments of the present disclosure may include a quota-based resource management apparatus. In one embodiment the apparatus may include a quota configuring unit that may be configured to configure a resource quota for each user entity of a plurality of user entities based on a first policy or a second policy. A further embodiment may include a first policy indicating that a resource quota may be configured using a percentage of an amount of resources that may be allowed to be configured with respect to an amount of all resources. A further embodiment may include a second policy indicating that a resource quota may be to be configured using the amount of resources that may be allowed to be configured. A further embodiment may include a quota applying unit that may be configured to apply a resource quota according to a first policy or a second policy.
Embodiments of the present disclosure may include a computer program product, including a computer readable medium, that may be configured to carry computer program code embodied therein and for use with a computer. In a further embodiment, the computer program code may comprise: code for configuring a resource quota for each user entity of a plurality of user entities based on a first policy or a second policy. A further embodiment may include a first policy indicating that a resource quota may be configured using a percentage of an amount of resources that may be allowed to be configured with respect to an amount of all resources. A further embodiment may include a second policy indicating that a resource quota may be configured using an amount of resources that may be allowed to be configured. A further embodiment may include code for applying the resource quota according to the first policy or the second policy.
Embodiments of the present disclosure may offer two options of quota configuration for end users (e.g. storage administrators), so that end users may configure and apply resource quotas based on a policy. In a further embodiment, end users may choose one of “percentage policy” and/or “amount policy” to implement quota configuration according to a usage environment and actual needs. In a further embodiment, the resource management solution of the present disclosure may be adapted to dynamic changes of the amount of resources. In a further embodiment, where a storage administrator uses quota reporting to learn resource consumption, showing a percentage of an amount of resources that may have been used by a user entity with respect to a total amount of resources might be more straightforward and convenient in some cases.
In one embodiment, description is presented for an existing quota-based resource management method by means of a file system. In a further embodiment, in existing quota-based resource management method, resource quotas may be configured for user entities by using the exact amount of resources. In a further embodiment, to implement a quota-based resource management method, typically, a file system may create and maintain a quota database for user entities so as to track and control resource allocation among user entities. In a further embodiment, in a quota database, one quota database record may be created for each user entity to which resources may be allocated.
Table 1 shows an exemplary structure of the quota database.
As shown in Table 1, each quota database record in the quota database, i.e. each row in Table 1 includes at least the following three fields:
In addition, each quota database record in the quota database may optionally include a field as below:
As seen from Table 1, values in both HardLimit and SoftLimit fields represent exact amounts of resources. As shown in Table 1, regarding a user entity having UserID 100, the disk space that may be allowed to be allocated to the user entity is 150G, and current disk space usage of user entity 100 is 100G. When the current disk space usage of UserID 100 exceeds a threshold 100G specified by the SoftLimit field, a message will be sent to UserID 100 warning the user that the current disk space usage will exceed the disk space upper limit specified by the HardLimit field.
In one embodiment, when a user entity may require to perform modification operations in a file system, for example, when a user entity may require to perform such operations in a file system as writing/removing/chown (change owner)/chgrp (change group), user entity may send a disk space allocation request to a system. In a further embodiment, in response to receiving a disk space allocation request from a user entity, a system will look up a quota database record, which may be created for the user entity, in the quota database. In a further embodiment, the system may calculate/compute a sum of a value in a CurrentSpaceUsage filed and an amount of requested disk space, and may compare the sum with a disk space upper limit specified by the HardLimit field. In a further embodiment, if the sum does not exceed a disk space upper limit specified by a HardLimit field, the system may allocate a requested disk space to a user entity; otherwise, the system may reject a user entity's request and return a “quota exceeding” error to the user entity.
The following is an example of pseudo code in a file system's writing path and chown (change owner) path.
Write path:
Chown path:
In the above pseudo code, a SendWarningMessage( ) interface will throttle messages to prevent warning messages from being sent to a user entity too frequently.
In one embodiment, in order to track resource consumption of a user entity, a storage administrator may send a quota reporting request via a control path of the file system, requesting a user entity to report information in a quota database record created for a user entity. In a further embodiment, in response, the system may read required information in a quota database record from a quota database and return read information to a storage administrator and a respective user entity.
In one embodiment, where a file system's capacity may be expanded or shrunk, a storage administrator may have to change quota configurations of user entities, otherwise the storage capacity may be overused or underutilized. To this end, various embodiments of the present disclosure propose a resource management solution that may be adapted to dynamically changes of resources and resource amounts, where configuration and application of resource quotas may be implemented based on a policy.
With reference to
In one embodiment, a first policy indicate that a resource quota may be configured using a percentage of an amount of resources that may be allowed to be configured with respect to an amount of all resources. A further embodiment may include a second policy that may indicate that a resource quota may be configured using the amount of resources that may be allowed to be configured.
In one embodiment, it may be understood that a first policy may be a new quota configuration policy, and a second policy may be an existing policy for configuring resource quotas for user entities by using the exact amount of resources. In a further embodiment, for purpose of description, hereinafter first policy is referred to as “percentage policy” for short and second policy is referred to as “amount policy”.
The embodiments of the present disclosure may provide two choices of quota configuration for end users (e.g., storage administrator), such that an end users may choose one of “percentage policy” and “amount policy” to implement quota configuration according to a usage environment and actual needs. In one embodiment, for example, many end users may have developed facilities/tools, scripts and the like to manage quotas using an existing “amount policy”. In an embodiment, in the present solution an end users may not be compelled to use a “percentage policy” for quota management, but they may still use existing facilities/tools, scripts and the like to adopt an “amount policy” instead of developing new facilities/tools, scripts and the like. In a further embodiment, additionally, in some cases, the only purpose of expanding a file system may be to support new user entities, wherein using an existing “amount policy” to manage quotas might be advantageous.
In the embodiments of the present disclosure, in order to use “percentage policy” or “amount policy” to implement quota management, some changes might be made to quota database records in the quota database shown in Table 1. Table 2 below shows an exemplary structure of a quota database according to one embodiment of the present disclosure.
As shown in Table 2, each quota database record in the quota database, i.e. each row in Table 2 at least comprises the following four fields:
As seen from a comparison of Table 2 with Table 1, a new field Policy has been added to Table 2. In one embodiment, a value in the field Policy may be a binary value, e.g. 1 or 0. In a further embodiment, for example, policy “1” may mean that the “percentage policy” may be used to configure quotas for respective user entities, and policy “0” may mean that the “amount policy” may be used to configure quotas for respective user entities.
In addition, each quota database record in the quota database may optionally include a field as below:
As seen from Table 2, values in HardLimit and SoftLimit fields represent exact amounts or percentages of the disk space for different user entities. In one embodiment, for example, regarding a user entity with UserID of 100, a value in the field Policy of a quota database record is 0, which means the “amount policy” may be used to configure quotas for the user entity; therefore, the disk space that may be allocated to the user entity may be 150G. In a further embodiment, when current disk space usage of user entity 100 exceeds a threshold 100G specified by a SoftLimit field, a message may be sent to user entity 100 to warn that the current disk space usage may exceed the disk space upper limit specified by a HardLimit field. In a further embodiment, additionally, regarding a user entity with UserID of 106, a value in a field Policy of a quota database record is 1, which means the “percentage policy” may be used to configure quotas for a user entity. In a further embodiment, in this case, a value of HardLimit (i.e. 40%) means a percentage of a maximum amount of disk space that may be allowed to be allocated to user entity 106 with respect to a total amount of disk space. In a further embodiment, when current disk space usage of user entity 106 exceeds a threshold (i.e. 30%) specified by SoftLimit, a message may be sent to user entity 106 to warn that a current disk space usage may exceed the disk space upper limit specified by HardLimit.
In one embodiment, when a user entity may require to perform modification operations in a file system, for example, when a user entity may require to perform such operations in the file system as writing/removing/chown (change owner)/chgrp (change group), the user entity may send a disk space allocation request to a system. In a further embodiment, in response to receiving a disk space allocation request from a user entity, a system may look up a quota database record, which may created for a user entity, in a quota database. In a further embodiment, a policy field of a quota database record for a user entity may be checked to determine whether configuring a resource quota for a user entity is based on the “percentage policy” or “amount policy”. In a further embodiment, it may be determined according, at least in part, to a determined policy whether or not to allocate a requested resource to a user entity. In a further embodiment, for example, where a resource quota may be configured for a user entity based on a “percentage policy”, it may be determined according, at least in part, to a “percentage policy” whether or not to allocate a requested resource to a user entity.
In one embodiment, where it may be determined according to a “percentage policy” whether or not allocate a requested resource to a user entity, operations may be performed as below: calculating a maximum amount of resources which may be allowed to be allocated to the user entity, based on a value in HardLimit of a quota database record created for a user entity; calculating a sum of current resource usage of a user entity (i.e. a value in the field CurrentSpaceUsage) and an amount of requested resources; and comparing the sum with a maximum amount of resources; if the sum does not exceed a maximum amount of resources, a requested resource may be allocated to a user entity, otherwise a request from a user entity may be rejected and a “quota exceeding” error may be returned to a user entity. In a further embodiment, before allocating a requested resource to a user entity, a value of CurrentSpaceUsage may be updated with the sum of current resource usage of a user entity and an amount of requested resources, so as to ensure consistency between quota record information and a modification operation.
The following is an example of pseudo code in a file system's writing path according to one embodiment of the present disclosure.
As seen from comparison of the above pseudo code with the pseudo code in the writing path described with reference to Table 1, there are differences between the above pseudo code in lines 6-10, 12 and 17 and corresponding parts of the pseudo code described with reference to Table 1.
The following is an example of pseudo code in a file system's chown (change owner) path according to one embodiment of the present invention.
As seen from comparison of the above pseudo code with the pseudo code in the chown path described with reference to Table 1, there are differences between the above pseudo code in lines 7-12 and 17 and corresponding parts of the pseudo code described with reference to Table 1.
In one embodiment, in order to track resource consumption of a user entity, a storage administrator may request a user entity to report information in a quota database record created for the user entity. According to one embodiment of the present disclosure, a storage administrator may specify a format of a quota report and may send a quota reporting request to a user entity, requesting a user entity to use a specified format to report information in a quota database record created for the user entity.
According to one embodiment of the present disclosure, a format of a quota report comprises one of the following:
In some embodiment, it may be understood before information in each quota record may be returned to a control path, recorded information may be translated to a format specified by a storage administrator.
Table 3 shows below an example of reporting quota record information in the “percentage format”; Table 4 shows below an example of reporting quota record information in the “amount format”; Table 5 shows below an example of reporting quota record information in the “default format”.
In one embodiment, a storage administrator may change a user entity's quota configuration policy at any time through a control path command or GUI operation. In one embodiment, when a storage administrator changes a user entity's quota configuration policy from “amount policy” to “percentage policy”, if a storage administrator provides new percentage value(s) (1-100) for soft upper limit or hard upper limit or both, the new percentage value(s) may be used as new upper limit(s). In a further embodiment, a system may use an existing soft upper limit or hard upper limit value that may divide a current file system's capacity to get a percentage value.
It should be understood that although the present disclosure has been described above by means of disk space management of a file system for the only purpose of illustration, the scope of the present disclosure is not limited thereto. The present application is applicable to any quota-based resource management environment. For example, the present disclosure may also be applied to other storage container than the file system, such as a storage pool resulting from binding several storage addresses together. In addition, the present disclosure may further be applied to other resource management than the disk space management, such as memory management.
The embodiments of the present disclosure further provide a quota-based resource management apparatus.
In one embodiment, quota configuring unit 210 may be further configured to create a quota database record for each user entity. In a further embodiment, a quota database record at least comprises: an identifier field for identifying a user entity to which a quota database record may be directed; a first resource upper limit field for indicating a resource upper limit which may be allowed to be allocated to a respective user entity; a resource usage field for indicating current resource usage of a respective user entity; and a policy field for indicating whether a resource upper limit may be configured for a respective user entity based on a first policy or a second policy.
In one embodiment, if a resource quota may be configured for a respective user entity based on a first policy, content of a first resource upper limit field may indicate a percentage of a maximum amount of resources which may be allowed to be allocated to a respective user entity with respect to an amount of all resources.
In one embodiment, quota applying unit 220 may be further configured, in response to receiving a resource allocation request from a user entity, to check a policy field of a quota database record for a user entity so as to determine whether a resource quota for a user entity is configured based on a first policy or a second policy. A further embodiment may include determining according, at least in part, to a determined policy, whether or not to allocate a requested resource to a user entity.
In one embodiment, quota applying unit 220 may be further configured to determine according, at least in part, to a first policy, whether or not to allocate a requested resource to a user entity if a resource quota may be configured for a user entity based on a first policy.
In one embodiment, a quota applying unit 220 may be further configured: to calculate a maximum amount of resources which may be allowed to be allocated to a user entity, based on content in a first resource upper limit field of a quota database record for a user entity. A further embodiment may include calculating a sum of current resource usage of a user entity and an amount of requested resources. A further embodiment may include comparing the sum with a maximum amount of resources. A further embodiment may include allocating a requested resource to a user entity in response to the sum being not exceeding a maximum amount of resources.
In one embodiment, a quota database record created for each user entity further comprises a second resource upper limit field for indicating a resource threshold which may be allowed to be allocated to a respective user entity.
In one embodiment, quota applying unit 220 may be further configured to specify a format of a quota report; and to send a quota reporting request to a user entity so as to request the user entity reporting information in a quota database record for a user entity using a specified format.
In one embodiment, a specified format of a quota format comprises one of:
a percentage format, indicating that a user entity may report content in an identifier field, may use a percentage of a maximum amount of resources that may be allowed to be allocated to a respective user entity with respect to an amount of all resources to report content in a first resource upper limit field, and may use a percentage of an amount of resources that may have been used by a respective user entity with respect to a n amount of all resources to report content in a resource usage field;
an amount format, indicating a user entity may report content in an identifier field, may use a maximum amount of resources that may be allowed to be allocated to a respective user entity to report content in a first resource upper limit field, and may use an amount of resources that may have been used by a respective user entity to report content in a resource usage field; and
a default format, indicating a user entity may report contents in all fields of a quota database record for a user entity.
The embodiments of the present disclosure further provide a computer program product, comprising a computer readable medium which carries computer program code embodied therein and for use with a computer, the computer program code comprising: code for configuring a resource quota for each user entity of a plurality of user entities based on a first policy or a second policy, the first policy indicating that the resource quota is to be configured using a percentage of an amount of resources allowed to be configured with respect to an amount of all resources, the second policy indicating that the resource quota is to be configured using the amount of resources allowed to be configured; and code for applying the resource quota according to the first policy or the second policy.
With reference to
As shown in
As above mentioned, apparatus 200 may be implemented through pure hardware, for example, chip, ASIC, SOC, etc. Such hardware may be integrated into computer system 300. Besides, the embodiments of the present disclosure may also be implemented in a form of a computer program product. For example, method 100 as described with reference to
It should be noted that, the embodiments of the present disclosure can be implemented in software, hardware or the combination thereof. The hardware part can be implemented by a dedicated logic; the software part can be stored in a memory and executed by a proper instruction execution system such as a microprocessor or a design-specific hardware. One of ordinary skill in the art may understand that the above-mentioned method and system may be implemented with a computer-executable instruction and/or in a processor controlled code, for example, such code is provided on a bearer medium such as a magnetic disk, CD, or DVD-ROM, or a programmable memory such as a read-only memory (firmware) or a data bearer such as an optical or electronic signal bearer. The apparatuses and their modules in the present disclosure may be implemented by hardware circuitry of a very large scale integrated circuit or gate array, a semiconductor such as logical chip or transistor, or a programmable hardware device such as a field-programmable gate array or a programmable logical device, or implemented by software executed by various kinds of processors, or implemented by combination of the above hardware circuitry and software such as firmware.
The communication network as mentioned in this specification may comprise various kinds of networks, including but not limited to local area network (LAN), wide area network (WAN), an IP-protocol based network (for example Internet), and a peer-to-peer network (for example ad hoc peer network).
It should be noted that although a plurality of units or subunits of the apparatuses have been mentioned in the above detailed depiction, such partitioning is merely non-compulsory. In actuality, according to the embodiments of the present disclosure, the features and functions of two or more units above described may be embodied in one unit. On the contrary, the features and functions of one unit above described may be further partitioned to be embodied in more units.
Besides, although operations of the present methods are described in a particular order in the drawings, it does not require or imply that these operations must be performed according to this particular order, or a desired outcome can only be achieved by performing all shown operations. On the contrary, the execution order for the steps as depicted in the flowcharts may be varied. Additionally or alternatively, some steps may be omitted, a plurality of steps may be merged into one step for execution, and/or a step may be divided into a plurality of steps for execution.
Although the present disclosure has been depicted with reference to a plurality of embodiments, it should be understood that the present disclosure is not limited to the disclosed embodiments. On the contrary, the present disclosure intends to cover various modifications and equivalent arrangements included in the spirit and scope of the appended claims. The scope of the appended claims meets the broadest explanations and covers all such modifications and equivalent structures and functions.
Number | Date | Country | Kind |
---|---|---|---|
201410813708.9 | Dec 2014 | CN | national |