This application is based upon and claims the benefit of priority of the prior
Japanese Patent Application No, 2021-018863 filed on February 9, 2021, the entire contents of which are incorporated herein by reference.
A certain aspect of the embodiments is related to a method of calculating a predicted exhaustion date and a non-transitory computer-readable medium,
A system built from a plurality of servers may not operate as designed if resources such as a CPU (Central Processing Unit) and a memory in each server arc exhausted. therefore, a system administrator predicts a future exhaustion date when the resources will be exhausted, based on a current resource usage or the like, and add serveis before the predicted exhaustion date.
However, the resource usage fluctuates on a daily basis, and it is difficult to determine the predicted exhaustion date of the resource in consideration of the fluctuation. Note that the technique related to the present disclosure is disclosed in Japanese Laid-open Patent Publications No. 2005-182697 and No. 2008-003736.
According to an aspect of the present disclosure. there. is provided a :Method of calculating a predicted exhaustion date for causing a computer to execute a process, the process including: calculating a first predicted exhaustion date when a resource in a system is predicted to be exhausted, at a first time point; calculating a. second predicted exhaustion date when the resource is predicted to be exhausted, at a second time point after the first time point; calculating a difference between the first predicted exhaustion date and the second predicted exhaustion date; calculating a third predicted exhaustion. date by correcting the second predicted exhaustion date based on the difference; and presenting the third predicted exhaustion date.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
Prior to the description of the present embodiment, matters studied b an inventor will be described.
A system such as a charge calculation system may be realized by combining a plurality of application programs executed by a plurality of servers, respectively. In this case, a system administrator needs to calculate the predicted exhaustion date when resources are exhausted in order to prevent the system from not working as designed due to lack of server resources such as a CPU and a memory.
It is difficult for the system administrator to accurately calculate the predicted exhaustion date based on his/her own experience and intuition, Therefore, it is conceivable to automatically calculate the predicted exhaustion date using a computer as follows.
In
Here, it is assumed that a predicted value U of a future resource usage is calculated from the past resource usage Uold by linear regression. The resource usage includes, for example, the usage of the CPU, the memory and a NIC (Network Interface Card) of the server. In addition, the resource usage Udd for the past 2 to 4 weeks is used for prediction. Further, in this example, it is assumed that the resource is exhausted when the resource usage exceeds a predetermined threshold value Th. When the resource is the CPU, for example, a CPU usage rate is set as the resource usage, and the threshold Th is set to 90%, for example.
In the example of
However, the predicted exhaustion date differs depending on when the prediction is made, as follows.
In
The reason why the predicted exhaustion date differs depending on the prediction date is that the resource usage fluctuates on the daily basis and the predicted exhaustion date is not calculated in consideration of the fluctuation. However, in this case, the administrator cannot know when to add the server in order to prevent the resource shortage, and the administrator may add more servers unnecessarily early or may not add more servers in time.
In the example of
In this case, January 26 is a predicted exhaustion date d2 when the possibility of resource exhaustion is 10%. January 30 is a predicted exhaustion date d1 when the possibility of resource exhaustion is 50%, February 4 is a predicted exhaustion date d3 when the possibility of resource exhaustion is 90%.
According to this method, the predicted exhaustion date d2 in a pessimistic case of the earliest resource exhaustion and the predicted exhaustion date d3 in an optimistic case of the latest resource exhaustion can be found.
The time required to incorporate a device such as the server into the system after deciding to purchase it is called a lead time. Assuming that the lead time is L, the computer notifies the administrator of warning at the time of d2 -L d3 -L, so that the administrator can purchase the device and incorporate it into the system before the resource is exhausted.
However, even with this method, since the predicted exhaustion dates d1, d2 and d3 are not calculated in consideration of the daily fluctuation of the resource usage the predicted exhaustion date changes depending on the prediction date as in
(Present Embodiment)
A system 10 is a system for calculating usage charges and the like, and includes a plurality of servers 11, a plurality of network devices 12, an information processing device 13, and a display device 14.
Each server 11 is a computer in which a CPU 11a and a memory 11b cooperate to execute an application program such as a charge calculation program. Further, each network device 12 is, for example, a switch that connects the plurality of servers 11 to each other, and is connected to a network 15 such as a LAN (Local Area Network) or an Internet.
The information processing device 13 is the computer such as a PC (Personal Computer) or server that calculates the predicted exhaustion date when the resource in each of the server 11 and the network device 12 is exhausted, and is connected to the server 11 and the network device 12 via the network 15.
Here, the information processing device 13 is provided as a part of the system 10, but the information processing device 13 may be provided outside the system 10. Further, a virtual machine may be started on the server 11, and the virtual machine may have the function of the information processing device 13.
The display device 14 is a display device such as a liquid crystal display that displays the predicted exhaustion date.
Next, a method in which the information processing device 13 calculates the predicted exhaustion date of the resource will be described.
First, the information processing device 13 calculates a first predicted exhaustion date D1 when the resource exhaustion is predicted, at a first time point p1. For example, the information processing device 13 calculates the first predicted exhaustion date D1 based on the past resource usage in a period T having the first time point p1 as an end point. The algorithm for calculating the first predicted exhaustion date D1 is not particularly limited. As an example, the information processing device 13 calculates the first predicted exhaustion date D1 from the past resource usage in the period T by the linear egression. In this example, it is assumed that the first predicted exhaustion date D3 is February 5.
Next, the information processing device 13 calculates a second predicted exhaustion date D0 when the resource exhaustion is predicted, at a second time point p2after the first time point pl. The algorithm for calculating the second predicted exhaustion date D0 is the same as the algorithm for calculating the first predicted exhaustion date D1, and calculates the second predicted exhaustion date D0 based on the past resource usage in the period T having the second time point p2 as the end point.
In this way, even if the same algorithm is used, the resource usage differs between the first time point p1 and the second time point p2, so that the second predicted exhaustion date D0 is often different from the first predicted exhaustion date D1. Here, it is assumed that the second predicted exhaustion date D0 is January 30, which is earlier than the first predicted exhaustion date D1.
Next, the information processing device 13 calculates a difference F between the first predicted exhaustion date D1 and, the second predicted exhaustion date D0. In this example, the difference F is 6 days. In the present embodiment, it is considered that the predicted exhaustion date of the resource fluctuates by ±F days from the second predicted exhaustion date D0 which is the latest prediction result, due to the daily fluctuation of the resource usage. In particular, in a worst case where the predicted exhaustion date becomes earlier by -F days from the second predicted exhaustion date D0, the administrator of the system 10 does not have enough time to add the server 11 and the network device 12, and it is necessary to notify the administrator of the approach of the predicted exhaustion date as soon as possible.
Therefore, the information processing device 13 calculates a third predicted exhaustion date D0-F when the second predicted exhaustion date D0 is corrected based on the difference F. In this example, the third predicted exhaustion date D0-F is January 24.
After that, the information processing, device 13 presents each of the first predicted exhaustion date D1, the second predicted exhaustion date D0 and the third predicted exhaustion date D0 -F to the administrator. As an example, the information processing device 13 displays a screen 17 including each of the first predicted exhaustion date D1, the second predicted exhaustion date D0 and the third predicted exhaustion date D0-F on the display device 14 (see
This completes the basic processing of the method for calculating the predicted exhaustion date of the resource according to the present embodiment.
According to this calculation method, the difference F due to the fluctuation of the resource usages at respective time points p1 and p2, is calculated, and the third predicted exhaustion date D0-F, where the second predicted exhaustion date D0 is corrected based on the difference F, is presented to the administrator. Thereby, the administrator can know the third predicted exhaustion date D0-F that takes into account the daily fluctuation of the resource usage, and the administrator can add the server 11 and the network device 12 before the resource is exhausted.
In the example in
In this case, the information processing device 13 calculates a plurality of first predicted exhaustion dates D1 sing the plurality of first time points p1, respectively. Then, the information processing device 13 calculates a largest value as the above difference F among the plurality of differences between the plurality of first predicted exhaustion dates D1 and the second predicted exhaustion date D0 and calculates the third predicted exhaustion date D0-F using the difference F and the second predicted exhaustion date D0.
By calculating the first predicted exhaustion date D1 at each of the plurality of first time points p1 in this way, a prediction accuracy of the third predicted exhaustion date D0-F can be improved.
However, if the number of predicted exhaustion dates D1 is increased to some extent, further improvement of the prediction accuracy cannot be expected, and rather the computational resources of the information processing device 13 are consumed unnecessarily. Therefore, it is preferable to limit the number of first predicted exhaustion dates D1 used for correction to an appropriate number as described below.
In the example of
The plurality of first time points p1 are in the past by 1 to 6 days from the second time point p2 (October 7), respectively. The first predicted exhaustion dates calculated by the information processing device 13 at these first time points p1 are represented by D1 to D6, respectively.
In this case, the information processing device 13 calculates a standard deviation S0 of a population having D0-D0 as an element for the second predicted exhaustion date D0, and a standard deviation S1 of the population having D0-D0 and D0 -D1 as elements for the first predicted exhaustion date D1. Further, the information processing device 13 calculates a standard deviation S2 of the population having D0- D0,D0-D1 and D0-D2 as elements for the first predicted exhaustion date D2. Hereinafter, in the same way, the information processing device 13 calculates a standard deviation S6 of the population having D0-D0, D0-D1, D0-D2, . . .D0-D6 as elements for the first predicted exhaustion date D6.
Next, the information processing device 13 calculates an absolute value (=1.5) of the difference between the standard deviations S0 and S1 as the variation of the first predicted exhaustion date D1, and an absolute value (=1.8) of the difference between the standard deviations S1 and S2 as the variation of the first predicted exhaustion date D2. Hereinafter in the same way, the information processing device 13 calculates an absolute value (=0.2) of the difference between the standard deviations S5 and S6 as the variation of the first predicted exhaustion date D6.
Then, the information processing device 13 identifies the first predicted exhaustion dates D1 (October 14) and D2 (October 19) having the variation larger than a threshold value X (for example, 1 day). Furthermore, the information processing device 13 calculates a maximum difference between each of these first predicted exhaustion dates D1 and D2 and the second predicted exhaustion date D0 as the difference F, and calculates the above-mentioned third predicted exhaustion date D0-F. Here, the remaining first predicted exhaustion dates D3 to D6 are not used to calculate the third predicted exhaustion date D0-F. In this example, the diftbrence F is 8days, so October 3is the third predicted exhaustion date,
In this way, by calculating the third predicted exhaustion date D0-F using only the first predicted exhaustion date having the variation larger than the threshold value X. the prediction accuracy of the third predicted exhaustion date D0-F can be maintained while saving the computational resources of the information processing device 13.
Next, the fUnctional configuration of the information processing device 13 according to the present embodiment will be described.
As illustrated in
The communication unit 21 is an interface for connecting the information processing device 13 to the network 15. Further, the storage unit 22 stores the usage information 24 in which the resource usage of the server 11 or the network device 12 is associated with the past date when the resource usage is acquired.
On the other hand, the control unit 23 is a processing unit that controls each unit of the information processing deviec 13. As an example, the control unit 23 includes an acquisition unit 25, a. calculation unit 26, a correction unit 27, and a presentation unit 28.
The acquisition unit 25 is a processing unit that acquires a parameter indicating the resource usage of the system 10. For example, the acquisition unit 25 communicates with each of the server 11 and the network device 12 to acquire parameters indicating these resource usages. Such parameters include the usage rate of the CPU 11a in the server 11 and a memory usage of the memory 11b. Further, the acquisition unit 25 may acquire a disk usage of the server 11 and a traffic passing through the NIC (Network Interface Card) of the server 11 as the parameter. On the other hand, in the network device 12, a traffic through such a network device 12 is such a parameter.
Furthermore, the acquisition unit 25 associates the parameter with a past date when the parameter was acquired, and store it in the storage unit 22 as usage: information 24.
The calculation unit 26 calculates the first predicted exhaustion date D1 in which the resource exhaustion is predicted, at the first time point p1 before a date indicated by the latest parameter included in the usage information 24. The parameter used for calculating the first predicted exhaustion date D1 is a parameter included in the period T haying the first time point p1 as the end point. The calculation unit 26 calculates the first predicted exhaustion date D1 by performing the linear regression on the parameter.
Here, the first time point p1 is not limited to one. For example, the calculation unit 26 may calculate the first predicted exhaustion dates D1 to D6 at the plurality of first time points p1, respectively, as illustrated in
Further, the calculation unit 26 calculates the second predicted exhaustion date D0, in which the resource exhaustion is predicted, at the second time point p2 before a date indicated by the latest parameter included in the usage information 24. As an example, the calculation unit 26 calculates the second predicted exhaustion date D2 by performing the linear regression on the parameter included in the period T having the first time point p2 as the end point.
Then, the calculation unit 26 calculates the difference F between the first predicted exhaustion date D1 and the second predicted exhaustion date D0. The calculation unit 26 may calculate the first predicted exhaustion date D1 at each of the plurality of different first time points p1. In this case, the calculation unit 26 calculates a largest value among the plurality of differences between the plurality of first predicted exhaustion dates D1 and the second predicted exhaustion date D0 as the difference F.
The correction unit 27 is a processing unit that calculates a third predicted exhaustion date D0-F by correcting the second predicted exhaustion date D0 based on the difference F. The correction unit 27 may calculate a fourth predicted exhaustion date D0=F in the optimistic case where the resource is exhausted later than the second predicted exhaustion date D0 for the reference of the administrator.
The presentation unit 28 is a processing unit that presents the third predicted exhaustion date D0-F. As an example, the presentation unit 28 outputs an instruction for displaying the third predicted exhaustion date D0-F to the display device 14 (see
Next, a method of calculating the predicted exhaustion date according to the present embodiment will be described.
Next, the calculation unit 26 calculates the first predicted exhaustion dates D1 to Dn at the plurality of first time points p1 before the second time point p2, respectively (step S12).
Next, the calculation unit 26 calculates the largest value F among the plurality of differences between the plurality of first predicted exhaustion dates D1 to Dn and the second predicted exhaustion date D0 (step S13). As illustrated in
Next, the correction unit 27 calculates the third predicted exhaustion date D0-F (step S14).
Subsequently, the presentation unit 28 outputs an instruction for displaying the third predicted exhaustion date D0-F to the display device 14 (step S15). Also, the presentation unit 28 may output, to the display device 14, an instruction for displaying the second predicted exhaustion date D0 and the fourth predicted exhaustion date D0+F in the optimistic case where the resource is exhausted later than the second predicted exhaustion date D0, for the reference of the administrator. The fourth predicted exhaustion date D1+F is the predicted exhaustion date that is expected to fluctuate from the second predicted exhaustion date D0 due to the daily fluctuation in a resource amount, as in the third predicted exhaustion date D0-F.
Next, the presentation unit 28 determines whether D0-F-L≤p2 is satisfied and step S17 described later is not executed (step S16). Here, L is a lead time which is set to a value of about l to 2 weeks by the administrator. Further, in this example, the second time point p2 is set as the current day, as described above, Therefore, when D0-F-L≤p2 is satisfied, even if the addition of the server 11 and the network device 12 is decided at the current time, the addition will not be in time by the third predicted exhaustion date D0- F.
However, it is assumed that the third predicted exhaustion date D0-F is the worst case where the resource is exhausted earlier than the second predicted exhaustion date D0, so the resource may be exhausted later than the third predicted exhaustion date D0-F in actuality.
Therefore, when D0-F-L≤p2 is satisfied and step S17 is not executed (YES in step S16), the process proceeds to step S17 and the presentation unit 28 outputs an instruction for displaying a preventive warning to the display device 14.
In the example of
Further, the presentation unit 28 may notify the administrator of an email including the preventive warning.
In step S18, the presentation unit 28 determines whether D0L≤p2 is satisfied and step S19 described later is not executed. When D0-L≤p2 is satisfied, even if the addition of the resource is decided at the current time, the addition will not be in time by the second predicted exhaustion date D0.
Therefore, when D0-L≤p2 is satisfied and step S19 is not executed (YES in step S18), the process proceeds to step S19 and the presentation unit 28 outputs an instruction for displaying a standard warning to the display device 14.
In the example of
Further, the presentation unit 28 may riotife the administrator of an email including the standard warning.
In step S20, the presentation unit 28 determines whether D0+F-L≤p2is satisfied and step S21 described later is not executed. The fourth predicted exhaustion date D0+F is the day when the resource exhaustion is predicted in the optimistic case, and the resource is almost certainly exhausted on the fourth predicted exhaustion date D0+F. Therefore, when D0+F-L ≤p2 is satisfied, even if the addition of the resource is decided at the current time, the resource is almost certainly exhausted by the time of the addition,
Therefore, when D0+F-L ≤p2 is satisfied and step S21 is not executed (YES in step S20) the process proceeds to step S21 and the presentation unit 28 outputs an instruction for displaying a final warning to the display device 14.
In the example of
Further, the presentation unit 28 may notify the administrator of an email including the final warning.
After this, the process returns again to step S11 in
According to the present embodiment described above, the calculation unit 26 calculates the difference F due to the difference between the resource usages at respective time points p1 and p2 (step S14). Then, the presentation unit 28 presents to the administrator the third predicted exhaustion date D0-F in which the second predicted exhaustion date D0 is corrected based on the difference F (step S15). Thereby, the administrator can know the third predicted exhaustion date D0-F that takes into account the daily fluctuation of the resource usage, and the administrator can add the server 11 and the network device 12 before the resource is exhausted.
Next, variations of the present embodiment will be described. In the example of
Instead of this, the calculation unit 26 may calculate the first predicted exhaustion date as in each of the following variations.
In this variation, the plurality of first time points p1 (October 6and October 5) are days that go back to a past day (October 5) that is separated from the second time point p2 (October 7) by a predetermined number of days (2days), wherein any one of the plurality of first time points p1 (e.g. October 6) differ by one day from an another first time point (e.g. October 5), Further, 7 days is adopted as the period having the first time point p1 as the end point, and 7 days is similarly adopted as the period having the second time point p2 as the end point,
In this ease, the calculation unit 26 calculates October 15as the second predicted exhaustion date D0 based on the usage information 24 for a period from October 1 to October 7.
The calculation unit 26 calculates October 17as the first predicted exhaustion date D1 at the first time point p1 (October 6) based on the usage information 24 for the period from September 30 to October 6. Similarly, the calculation unit 26 calculates October 20 as the first predicted exhaustion date D2 at the first time point p1 (October 5) based on the usage information 24 for the period from September 29to October 5.
In this case, the largest difference between the first predicted exhaustion dates D1 and D2 and the second predicted exhaustion date D0 is the first predicted exhaustion date D2, and the difference F is 5days. Therefore, the third predicted exhaustion date D0-F is October 10.
According to this, the calculation unit 26 calculates the first predicted exhaustion dates D1 and D2 only at the two first time points p1 close to the second time point p2. Therefore, the correction unit 27 can calculate the third predicted exhaustion date D0-F in consideration of only the fluctuation of the recent prediction result.
In this variation, a ratio of the total number (5) of the plurality of first time points p1 and the second time point p2 to the number of days (10 days) included in the period is set to 1/2. The ratio is constant regardless of the total number of the plurality of first time points p1 and the second time point p2 and the number of days included in the period, This eliminates the need for the administrator of the system 10 to set the number of the plurality of first time points p1.
In the example of
Here, it is considered the case where the second predicted exhaustion date D0 is October 13. In this case, the difference between the second predicted exhaustion date D0 (October 13) and the second time point p2 (October 10) is 3 days. In this variation, the total number of the first time points p1 and the second time point p2 is set to three, which is equal to the difference (3days).
Thereby, the correction unit 27 can calculate the third predicted exhaustion date D0-F (October 11) in consideration of the first predicted exhaustion dates D1 and D2 at the first time points p1 close to the second predicted exhaustion date D0.
In this example, the calculation unit 26 calculates the first predicted exhaustion dates D1 to D4 based on the usage information 24 in a plurality of first periods having different lengths for the plurality of first time points p1, respectively.
Furthermore, the calculation unit 26 calculates the second predicted exhaustion date D0 (October 20) based on the usage information 24 in the second period having the second time point p2 as the end point and having a different length from any of the plurality of first periods. In this variation, the difference F is 10, and the third predicted exhaustion date D0-F calculated by the correction unit 27 is October 10.
According to this, since the end points of the second period and each of the plurality of first periods are the second time point p2, the resource usage at the latest second time point p2 can be reflected in each of the predicted exhaustion dates D0 to D4. Moreover, since the lengths of the plurality of first periods are different from each other, the correction unit 27 can calculate the third predicted exhaustion date D0-F (October 10) in consideration of both long-term and short-tem perspectives.
In this variation and subsequent variations, a screen presented by the presentation unit 28 will be described.
Further, the correction unit 27 calculates the third predicted exhaustion date D0-F and the fourth predicted exhaustion date D0+F using the maximum value Umax. After that, the presentation unit 28 presents the second predicted exhaustion date D0, the third predicted exhaustion date D0-F, and the fourth predicted exhaustion date D0+F on the screen 42.
When the maximum value Umax is used, each of the predicted exhaustion dates D0, D0-F and D0+F is earlier than that in a case where the average value Uave and the minimum value Umin in
Further, the correction unit 27 calculates the third predicted exhaustion date D0-F and the fourth predicted exhaustion date D0+F using the minimum value Umin. After that, the presentation unit 28 presents the second predicted exhaustion date D0, the third predicted exhaustion date D0-F, and the fourth predicted exhaustion date D0+F on the screen 43.
When the minimum value Umin is used, each of the predicted exhaustion dates D0, D0-F and D0+F is later than that in a case where the average value Uave and the maximum value Umax in
The storage 13a is a non-volatile storage such as an HDD (Hard Disk Drive) or an SSD (Solid State Drive), and stores a predicted exhaustion date calculating program 100 according to the present embodiment.
The predicted exhaustion date calculating program 100 may be recorded on a computer-readable recording medium 13h, and the processor 13c may read the predicted exhaustion date calculating program 100 from the recording medium 13h via the medium reading device 13g.
Examples of such a recording medium 13h include physically portable recording media such as a CD-ROM (Compact Disc-Read Only Memory), a DVD (Digital Versatile Disc), and a USB (Universal Serial Bus) memory. Further, a semiconductor memory such as a flash memory, or a hard disk drive may be used as the recording medium 13h. The recording medium 13h is not a temporary medium such as a carrier wave having no physical form.
Further, the predicted exhaustion date calculating program 100 may be stored in a device connected to a public line, the Internet, a LAN (Local Area Network), or the like. In this case, the processor 103 may read and execute the predicted exhaustion date calculating program 100.
Meanwhile, the memory 13b is hardware that temporarily stores data, such as a DRAM (Dynamic Random Access Memory), and the predicted exhaustion date calculating program 100 is deployed on the memory 13b.
The processor 13c is hardware such as a CPU (Central Processing Unit) or a GPU (Graphical Processing Unit) that controls each element of the information processing device 13. Further, the processor 13c executes the predicted exhaustion date calculating program 100 in cooperation with the memory 13b.
Thus, the processor 13c executes the predicted exhaustion date calculating program 100 in cooperation with the memory 13b, so that the control unit 23 of the information processing device 13 (see
The storage unit 22 (see
Further, the communication interface 13d is hardware such as a NIC (Network Interface Card) for connecting the information processing device 13 to the network 15 (see
The input device 13f is hardware such as a keyboard and a mouse for the administrator of the system 10 to input various data to the information processing device 13.
The medium reading device 13g is hardware such as a CD drive, a DVD drive, and a USB interface for reading the recording medium 13h.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present invention have been described in detail, it should be understood that the various change, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2021-018863 | Feb 2021 | JP | national |