1. Field of the Invention
The present invention generally relates to resource load measuring methods, network control apparatuses, communication nodes and storage media, and more particularly to a resource load measuring method for measuring loads of resources in a network environment, a network control apparatus for performing a network management based on measured loads of resources, a communication node for measuring a load thereof by itself, and a computer-readable storage medium which stores a computer program for causing a computer to function as the network control apparatus or the communication node.
2. Description of the Related Art
In a network environment, main functions of a network control apparatus include monitoring and managing communication nodes within a working network. The communication nodes include routers, switches and servers. The managing functions include managing a network structure, managing faults generated in the communication nodes, and managing load information of resources within the network. A system which monitors and manages the communication nodes within the network is often referred to as the Network Management System (NMS).
Other functions of the network control apparatus include dynamically controlling the network depending on the loads of the resources. For example, a network load balancing function distributes and balances the load within the network so as to avoid congestion, and a server load balancing function distributes and balances the load on the servers by sorting traffic of requests with respect to the servers.
In order to monitor and control the network, it is necessary to measure the load information of the resources. The load information may include the bandwidth of a link between two communication nodes, the amount of traffic, the activity ratio of a CPU within the communication node, the amount of memory space used in the communication node, and the like. The network load balancing function regards a link with a high utilization as a congestion, and carries out a control by moving a portion of the traffic to a detour route having more available bandwidth. The server load balancing function carries out a control to sort the traffic of the requests to the server having a CPU with a low activity ratio.
Conventionally, the load information of the resources is usually collected by the network control apparatus at predetermined measuring intervals which are defined in advance by the, operator, by using a protocol such as the Simple Network Management Protocol (SNMP) and an interface such as the Command Line Interface (CLI). In other words, the measuring intervals are fixed.
On the other hand, a first type of load measurement has been proposed, which automatically shortens the measuring intervals when the measured load information exceeds a threshold value, so as to improve the monitoring accuracy. A Japanese Laid-Open Patent Application No.2000-49940 proposes a traffic measuring apparatus which employs a technique similar to this first type of load measurement. However, in this proposed traffic measuring apparatus, a switching system notifies the load information to the traffic measuring apparatus when the threshold value is exceeded.
In addition, a second type of load measurement has been proposed in a Japanese Laid-Open Patent Application No.7-152706. According to this second type of load measurement, a communication node measures and notifies the load information to the network control apparatus, and the measuring and notifying intervals are dynamically shortened when the load information exceeds a threshold value, so as to reduce the load of the communication node itself.
Furthermore, a third type of load measurement has been proposed in a Japanese Laid-Open Patent Application No.2002-140313. According to this third type of load measurement, the measured load information of a plurality of communication nodes are analyzed so as to predict the load in response to a request.
In order to effectively manage and stably control the network by the network control apparatus, it is desirable that the load measurement is carried out frequently so as to improve the accuracy of the measurement. However, when the measuring frequency is increased, the processing load on the network control apparatus which carries out the load measurement and/or the processing load on the communication node which is the target of the load measurement increase, and moreover, signals used for the load measurement use up a large portion of the bandwidth of the network, to thereby increase the overhead of the measurement (hereinafter simply referred to as a measurement overhead). Therefore, if the measuring intervals are constant, there was a problem in that it is difficult to find optimum measuring intervals which take into consideration a tradeoff between the accuracy of the measurement and the measurement overhead.
The accuracy of the measurement and the measurement overhead may be balanced to a certain extent by dynamically controlling the measuring intervals depending on a relationship between the measured load information and the threshold value. However, there is a limit in suitably controlling the measuring intervals based solely on whether or not the measured load information exceeds the threshold value.
For example, the measured load information may deviate greatly but not exceed the threshold value, but in such a case, although desirable to improve the accuracy of the measurement, the prior art does not shorten the measuring intervals since the threshold value is not exceeded.
Further, the measured load information may be approximately constant and not exceed the threshold value, but in such a case, although desirable to reduce the measurement overhead, the prior art does not lengthen the measuring intervals because the threshold value is not exceeded.
Moreover, when the load information is simply predicted, the measurement overhead can be reduced, but it is difficult to obtain accurate load information which closely approximates the actual load information. For this reason, it is difficult to effectively manage and stably control the network based solely on the predicted load information.
Accordingly, it is a general object of the present invention to provide a novel and useful resource load measuring method, network control apparatus, communication node and computer-readable storage medium, in which the problems described above are eliminated.
Another and more specific object of the present invention is to provide a resource load measuring method, a network control apparatus, a communication node and a computer-readable storage medium, which effectively manage and stably control a network while maintaining a high accuracy for measurement of load information of resources, and simultaneously enable reduced measurement overhead.
Still another object of the present invention is to provide a resource load measuring method for measuring load information of resources within a network, comprising measuring the load information of the resources at measuring intervals' and storing measured load information in a storage section; predicting load information of the resources according to a prediction algorithm and storing predicted load information in the storage section; and adjusting the measuring intervals based on the measured load information and the predicted load information stored in the storage section. According to the resource load measuring method of the present invention, it is possible to effectively manage and stably control a network while maintaining a high accuracy for measurement of load information of resources, and simultaneously enable reduced measurement overhead.
A further object of the present invention is to provide a network control apparatus coupled within a network having resources and controlling the network, comprising a storage section; a measuring section to measure load information of the resources at measuring intervals and to store measured load information in the storage section; a predicting section to predict load information of the resources according to a prediction algorithm and to store predicted load information in the storage section; and an adjusting section to adjust the measuring intervals based on the measured load information and the predicted load information stored in the storage section. According to the network control apparatus of the present invention, it is possible to effectively manage and stably control a network while maintaining a high accuracy for measurement of load information of resources, and simultaneously enable reduced measurement overhead.
Another object of the present invention is to provide a communication node coupled within a network having a network control apparatus, comprising a plurality of resources; a storage section; a measuring section to measure load information of the resources at measuring intervals and to store measured load information in the storage section; a predicting section to predict load information of the resources according to a prediction algorithm and to store predicted load information in the storage section; and an adjusting section to adjust the measuring intervals based on the measured load information and the predicted load information stored in the storage section, in response to an instruction from the network control apparatus. According to the communication node of the present invention, it is possible to effectively manage and stably control a network while maintaining a high accuracy for measurement of load information of resources, and simultaneously enable reduced measurement overhead.
Still another object of the present invention is to provide a computer-readable storage medium which stores a computer program for causing a computer to measure load information of resources within a network, the computer program comprising a procedure to cause the computer to measure the load information of the resources at measuring intervals and to store measured load information in a storage section; a procedure to cause the computer to predict load information of the resources according to a prediction algorithm and to store predicted load information in the storage section; and a procedure to cause the computer to adjust the measuring intervals based on the measured load information and the predicted load information stored in the storage section. According to the computer-readable storage medium of the present invention, it is possible to effectively manage and stably control a network while maintaining a high accuracy for measurement of load information of resources, and simultaneously enable reduced measurement overhead.
Other objects and further features of the present invention will be apparent from the following detailed description when read in conjunction with the accompanying drawings.
The network control apparatus 12 may be formed by a general purpose computer or the like. Main functions of the network control apparatus 12 include monitoring and managing the communication nodes within the network 11. The monitoring functions include measuring the load of the communication nodes and obtaining load information of the communication nodes. The managing functions include managing the network structure of the network 11, managing faults generated in the communication nodes, and managing the load information of resources within the network 11. In this embodiment, the communication nodes connected within the network 11 or, parts of the communication nodes, form the resources within the network 11.
Other functions of the network control apparatus 12 include dynamically controlling the network 11 depending on the loads of the resources. For example, a network load balancing function distributes and balances the load within the network 11 so as to avoid congestion, and a server load balancing function distributes and balances the load on the servers 13 by sorting traffic of requests with respect to the servers 13.
Each of the servers 13 has known server functions, and may be formed by a general purpose computer. Similarly, each of the routers 14 has known router functions for switching routes for communication. The network 11 may be formed by a cable network, an optical network, a wireless network, or any combination of such networks. Each of the sub-networks 21 and 22 may formed by a cable network, an optical network, a wireless network, or any combination of such networks. Of course, the network 11 may be isolated, in which case the sub-networks 21 and 22 are omitted or, the network 11 may be connected to more than two sub-networks (or networks).
The database 30 stores the load information of the resources within the network 11, and a measuring interval with which the load information of the resources is to be measured. As will be described later, the load information stored in the database 30 includes measured load information and predicted load information.
The resource measuring section 31 is connected to the network 11, and measures the load information of the resources from the communication nodes within in the network 11, using an interface such as the Simple Network Management Protocol (SNMP) and an interface such as the Command Line Interface (CLI), in response to a resource measure instruction from the measuring interval controller 33. The resource measuring section 31 stores the measured load information (or measured value) in the database 30.
The load information may be any information defined by the standard MIB of the SNMP. For example, the load information may be any one or combination of the bandwidth of each interface (corresponding to a link) of the communication node (router 14), a total-number of bytes transmitted via each interface of the communication node (router 14), a number of packets discarded at each interface of the communication node (router 14), an activity ratio of a CPU within the communication node (server 13), an amount of memory space used in the communication node (server 13), a number of connections of the communication node (server 13), and the like. The total number of bytes transmitted via each interface of the communication node may be used to obtain the utilization of each link.
The resource predicting section 32 refers to time-varying information of the measured load information stored in the database 30, and predicts load information which will be obtained for the selected resources when the load information is measured the next time, in response to a resource predict instruction from the measuring interval controller 33. The resource predicting section 32 stores the predicted load information (or predicted value) in the database 30. The method of prediction will be described later.
When the EWMA is used for the prediction method, an nth predicted value pn can be obtained from pn=mn−1+w×en−1, where en−1=mn−1−pn−1 is an error between an (n−1)th measured value and an (n−1)th predicted value, and w denotes a weighting parameter which indicates the degree of weight placed on the immediately preceding measured value when making the prediction. Of course, other suitable prediction methods may be employed, such as the Least Square Method (LSM). The LSM computes the predicted value with an even higher accuracy based on time-sequential data of past measured values. In this case, however, it is necessary to store the time-sequential data of the measured values in the database 30.
The measuring interval controller 33 adjusts the next measuring interval based on the measured load information, the predicted load information and the present measuring interval stored in the database 30, in response to an adjust instruction from the network control information computing section 34. The next measuring interval which is adjusted by the measuring interval controller 33 is stored in the database 30. The measuring interval controller 33 also controls the resource measuring section 31 so as to measure the load information of the resources at the adjusted measuring interval.
In
On the other hand, if a time greater than or equal to the present measuring interval In elapses from the previous measuring time tn−1 and the decision result in the step S22 is YES, a step S23 measures the load information of the selected resource by instructing the resource measuring section 31 by issuing the resource measure instruction. A step S24 computes a difference dn(=mn−mn−1) between the present (nth measurement) measured load information (measured value) mn and the previous measured load information (measured value) mn−1, and stores this difference dn in the database 30.
A step S25 predicts the load information (predicted value) of the selected resource by instructing the resource predicting section 32 by issuing the resource predict information, and a step S26 computes the error between the measured load information (measured value) and the predicted load information (predicted value). As described above, the predicted value pn is obtained from Pn=mn−1+w×en−1, where the error en-1 between the (n−1)th measured value and the (n−1)th predicted value is described by en−1=mn−1−pn−1. Hence, the step S25 computes and stores the predicted value pn in the database 30, and the step S26 computes and stores the error en(=mn−pn) in the database 30.
A step S27 decides whether or not an absolute value of the error en is greater than or equal to a threshold value The. If the decision result of the step S27 is NO, a step S28 decides whether or not an absolute value of the difference dn is greater than or equal to a threshold value Thd.
If the decision result in the step S21 is YES, a step S31 decides whether or not the adjust instruction from the network control information computing section 34 instructs shortening the measuring interval. If the decision result in one of the steps S27, S28 and 31 is YES, the process advances to a step S30. On the other hand, if the decision result in the step S28 or S31 is NO, the process advances to a step S29. The step S29 starts a process of lengthening the measuring interval, and the step S30 starts a process of shortening the measuring interval. Hence, the measuring interval is shortened if the relationship |en|≧The or |dn|≧Thd stands, and the measuring interval is otherwise lengthened.
The step S29 sets the measuring interval In to I=αf×In−1 based on a constant αf satisfying αf>1. Alternatively, the measuring interval In is set to In=In−1+αi based on a positive constant ai. Then, a step S32 decides whether or not the measuring interval In is longer than an upper limit value Imax. If the decision result in the step S32 is YES, a step S33 sets the measuring interval In to the upper limit value Imax. In other words, if In>Imax, In is set to In=Imax.
The step S30 sets the measuring interval In to In=βf×In−1 based on a constant βf satisfying 0<βf<1. Alternatively, the measuring interval In is set to In=I−1−βi based on a positive constant βi. Then, a step S34 decides whether or not the measuring interval In is shorter than a lower limit value Imin. If the decision result in the step S34 is YES, a step S35 sets the measuring interval In to the lower limit value Imin. In other words, if In<Imin, In is set to In=Imin.
If the decision result in the step S32 or S34 is NO, the process returns to the step S21. Furthermore, the process returns to the step S21 after the step S33 or S35.
The network control information computing section 34 refers to the load information and the like stored in the database 30, and computes various control information (parameters) for use in suitably controlling the network load balancing and the server load balancing. The network control information computing section 34 notifies the computed control information to the network equipment controller 35. In addition, based on the computed control information, the network control information computing section 34 sends the adjust instruction to the measuring interval controller 33 so as to adjust the measuring interval of the selected resource which is the target of control.
In
The network equipment controller 35 controls the equipments within the network 11 based on the control information received from the network control information computing section 34, in response to the control instruction received from the network control information computing section 34.
Next, a description will be given of first, second and third measuring interval controls which dynamically control the measuring interval in accordance with this embodiment. For the sake of convenience, it is assumed to be the network load balancing is performed by the network control. In the case of the network load balancing, the load (utilization) of each link within the network 11 is constantly monitored, and it is regarded that a congestion occurred in the link if the load reaches a predetermined value. The network control apparatus 12 sets a route having a large amount of available bandwidth as a detour route with respect to the traffic passing through the congestion link, and avoids the congestion by moving a portion of the traffic to the detour route.
In
In
In
In the embodiment described above, the operation of the measuring interval controller 33, shown in
Accordingly, in order to avoid the load of the resource measuring section 31 from becoming too high and considerably increasing the load of the network control apparatus 12 as a whole, the network control apparatus 12 may carry out a process of adjusting the measuring interval by taking into consideration the load of the network control apparatus 12 as a whole. Hence, in a modification of this embodiment, the measuring interval controller 33 periodically adjusts the measuring interval, for example, depending on the load of the network control apparatus 12 as a whole.
In
On the other hand, if the decision result in the step S61 is YES, a step S62 sends the adjust instruction to the resource measuring section 31 to lengthen the measuring interval with respect to at least some of the resources. For example, the adjusting interval may be lengthened by adding or multiplying a constant to the measuring interval of each of the resources which are the measuring targets or, with respect to one or more resources having the shortest measuring interval or, with respect to one or more resources having a measuring interval smaller than or equal to a predetermined value or, with respect to predetermined resources which are determined in advance.
Of course, the measuring interval is lengthened so as not to exceed the upper limit of the measuring interval. Hence, a step S63 decides whether or not the lengthened measuring interval or intervals exceed the upper limit of the measuring interval. The process returns to the step S61 if the decision result in the step S63 is NO. On the other hand, if the decision result in the step S63 is YES, a step S64 reduces each lengthened measuring interval which exceeds the upper limit of the measuring interval, to the upper limit, and the process returns to the step S61.
Therefore, this modification of the first embodiment can prevent the load of the resource measuring process from becoming too large, by suitably adjusting the measuring interval depending on the load of the network control apparatus 12 as a whole.
In the embodiment described above, the measuring interval is adjusted by the network control apparatus 12. However, it is possible to self-adjust the measuring interval in each communication node, as will be described hereunder. In other words, each communication node measures the load of the resource thereof, and notifies the measured load information to the network control apparatus at the self-adjusted measuring interval (or notifying interval). In this case, the network control apparatus carries out the network control based on'the load information received from the communication node.
As shown in
On the other hand, a communication node 212 may be a server or a router, for example. The communication node 212 includes a database 230, a resource predicting section 232, a resource measuring section 231, a measuring interval controller 233, a communication controller 237, and a node process controller 238.
In the communication node 212 shown in
In
On the other hand, if a time greater than or equal to the present measuring interval elapses from the previous measuring time and the decision result in the step S122 is YES, a step S123 measures the load information of the selected resource by instructing the resource measuring section 231 by issuing the resource measure instruction. A step S124 computes a difference between the present measured load information and the previous measured load information, and stores this difference in the database 230.
A step S125 predicts the load information (predicted value) of the selected resource by instructing the resource predicting section 232 by issuing the resource predict information, and a step S126 computes the error between the measured load information (measured value) and the predicted load information (predicted value). Hence, the step S125 computes and stores the predicted value in the database 230, and the step S126 computes and stores the error in the database 30.
A step S127 decides whether or not an absolute value of the error is greater than or equal to a threshold value. If the decision result of the step S127 is NO, a step S128 decides whether or not an absolute value of the difference is greater than or equal to a threshold value.
If the decision result in the step S121 is YES, a step S131 decides whether or not the adjust instruction from the communication controller 237 instructs shortening the measuring interval. If the decision result in one of the steps S127, S128 and 131 is YES, the process advances to a step S130. On the other hand, if the decision result in the step S128 or S131 is NO, the process advances to a step S129. The step S129 starts a process of lengthening the measuring interval, and the step S130 starts a process of shortening the measuring interval.
After the step S129, a step S132 decides whether or not the measuring interval is longer than an upper limit value. If the decision result in the step S132 is YES, a step S133 sets the next measuring interval to the upper limit value. After the step S130, a step S134 decides whether or not the measuring interval is shorter than a lower limit value. If the decision result in the step S134 is YES, a step S135 sets the next measuring interval to the lower limit value. If the decision result in the step S132 or S134 is NO or, after the step S133 or S135, a step S136 notifies the resource load information to the communication controller 237, and sends a send instruction to the communication controller 237 to send the resource load information to the network control apparatus 112.
The steps S122 through S135 of the measuring interval controller 233 shown in
As shown in
On the other hand, if the decision result in the step S141 is YES, a step S144 decides whether or not an adjust instruction instructing adjustment of the measuring interval is received from the network control apparatus 112. If the decision result in the step S144 is NO, a step S145 notifies the information received from the network control apparatus 112 to the node process controller 238, and the process ends. If the decision result in the step S144 is YES, a step S146 notifies the instructed adjustment of the measuring interval to the measuring interval controller 233, and the process ends.
If the decision result in the step S142 is YES, a step S147 notifies the load information stored in the database 230 to the network control apparatus 112, and the process ends. For example, the load information may be notified to the network control apparatus 112 using a trap message of the SNMP.
If the decision result in the step S143 is YES, a step S148 carries out an information transmitting process such as sending the data packets, and the process ends.
As shown in
In the embodiment described above, the operation of the measuring interval controller 233 shown in
In order to avoid the load of the resource measuring section 231 from becoming too high and considerably increasing the load of the communication node 212 as a whole, the communication node 212 may carry out a process of adjusting the measuring interval by taking into consideration the load of the communication node 212 as a whole. Hence, in a modification of this embodiment, the measuring interval controller 233 may periodically adjust the measuring interval, for example, depending on the load of the communication node 212 as a whole, similarly as in the case of the network control apparatus 12 shown in
The input device 701 is formed by a keyboard, a mouse or the like and is used by the operator to input various instructions and data to the computer 700. The output device 702 is formed by a display unit, for example, to display various information such as messages. The CPU 703 controls the general operation of the computer 700. The storage 704 stores programs to be executed by the CPU 703, and data including intermediate data obtained during program execution by the CPU 703. The medium drum 705 is designed to at least read information from the recording medium 705-1, and is preferably designed to also write information on the recording medium 705-1. The recording medium 705 may be selected from any kind of media capable of storing programs and data. For example, the recording medium 705-1 is selected from magnetic recording media such as magnetic disks, optical recording media such as optical disk, and magneto-optical recording media such as magneto-optical disks. The interface 706 connects the computer 700 to the network 11. The basic structure itself of the computer 700 is known, and any other suitable basic structures may be employed for the computer 700.
An embodiment of a computer-readable storage medium according to the present invention is formed by the recording medium 705-1 which stores a computer program for causing the CPU 703 of the computer 700 to carry out the resource load measuring process described above, that is, a computer program for causing the computer 700 to function as the network control apparatus 12 or 112 or, the communication node 212. The computer program stored in the recording medium 705-1 is read by the medium drive 705 and installed in the storage 704. Of course, the computer program may be downloaded from another computer (not shown) via the network 11 and installed in the storage 704 via the interface 706.
Further, the present invention is not limited to these embodiments, but various variations and modifications may be made without departing from the scope of the present invention.