Embodiments generally relate to monitoring network operation.
A communication network may, for example, provide a network connection that allows data to be transferred between two geographically remote locations. A network may include network elements connected by links. The network elements may be any type of managed device on the network, including routers, access servers, switches, bridges, hubs, IP telephones, IP video cameras, computer hosts, and printers. Network elements can be physical or logical and can communicate with one another via interconnected links.
Network operation may be impaired for different reasons. For example, component failure, including link failures or network element failure, may cause operational flaws in the network. Network operational flaws may also be caused by misconfiguration or malfunction of network elements or congestion in the network.
Networks may provide clients with statistics, reports, and other information related to their elements and their performance. For example, clients may wish to see how much their traffic is delayed by the network, whether the service is meeting service level agreements, whether the network elements are functioning as intended, etc. Such performance information helps to discover operational flaws in the network.
Network management servers may use performance metrics that provide information about network performance. To collect metrics, a standard protocol, such as Simple Network Management Protocol (SNMP), may be used. SNMP is part of the Internet Protocol Suite as defined by the Internet Engineering Task Force (IETF). It includes of a set of standards for network management, including an application layer protocol, a database schema, and a set of data objects.
The database schema SNMP uses a management information base (MIB). The MIB describes network objects. The objects can be specified by object identifiers (OID). An object can include one or more object instances.
SNMP may support a query providing for discovery of the instances available for an object. The instances may be identified by suffixes to the object identifiers. The instance identifier may be used to retrieve metric values for the instance. Performance metric values stored in a database may be used to determine if there is an operational flaw with the corresponding object instance.
In an embodiment, a computer-implemented method detects operational flaws in a network. The method includes receiving, by a network management server, metrics corresponding to object instances of objects associated with network elements. The network management server generates a stream of tuples, wherein a tuple includes a network element identifier, a metric, and an object instance identifier. A metric is either a performance metric or a control metric corresponding to the object instance, and wherein the control metric appears periodically in the stream. A monitoring server monitors the stream of tuples and sets a flag when a first performance metric corresponding to the object instance is received. When detecting a control metric corresponding to the object instance the monitoring server determines whether the first flag is set. The monitoring server creates an alert if the first flag is not set.
Method and computer-readable medium embodiments are also disclosed.
Further embodiments and features, as well as the structure and operation of the various embodiments, are described in detail below with reference to accompanying drawings.
The accompanying drawings are incorporated herein and form a part of the specification.
In the drawings, like reference numbers generally indicate identical or similar elements. Generally, the left-most digit(s) of a reference number identifies the drawing in which the reference number first appears.
A network management server may receive performance metrics corresponding to instances of network objects associated with network elements. Network objects may include network services, applications or processes for a client. A network management server may collect metrics from network elements by sending request messages. Alternatively, network elements may send the metrics to the network management server. After receiving the metrics, network management server generates a stream of tuples. Each tuple corresponds to an object instance and may include an identification of the corresponding network element, a performance metric value from the object instance, and an identification of the object instance.
The performance metrics may be used to determine operation status of their corresponding object instances. A performance metric value may for example describe operational status of its corresponding object instance. The performance metrics may be stored in a database.
According to embodiments, a monitoring server monitors the stream of tuples that the network management server generates. The monitoring server may receive the stream in parallel with a database or before the stream is sent to the database. The monitoring server may therefore monitor the performance metrics in the stream in real time to detect any possible operational flaws without a need to access the database.
In embodiments, by monitoring the frequency or value of specific performance metrics in the stream of tuples, the monitoring server is able to detect any flaws in operation of the instances of network objects associated with the performance metrics. By monitoring of the tuple stream in real time using the monitoring server, as opposed to using a database, embodiments can reduce the time to detect any flaws in operation of object instances.
In the description that follows, a system where the monitoring server monitors the stream is first described with respect to
Network management server 106, using performance metrics received from network elements in network 102, creates a stream of tuples. Each tuple in the stream corresponds to an instance of an object associated with a network element and may include an identifier of the network element, a metric corresponding to the object instance, and an identifier of the object instance.
Network element identifier may for example be an IP or MAC address of a network device. As mentioned above, the objects may be specified using OIDs. Each OID may be a sequence of integers separated by decimal points. An example of an OID is 1.3.6.1.2.1.4.6. Each OID may have a textual description as well. For example the textual description of 1.3.6.1.2.1.4.6 may be iso.org.dod.intermet.mgmt.mib-2.ip.ipForwDatagrams. In that example, the ipForwDatagrams object may be an integer counter that stores the number of forwarded datagrams at a router. As mentioned above, the specification may include a list of specific objects, for example, 1.3.6.1.2.1.4.4, 1.3.6.1.2.1.4.5, and 1.3.6.1.2.1.4.6. Or the specification may designate an entire portion of the object hierarchy, for example, 1.3.6.1.2.1.4.*. Objects can be have instances. When the objects are stored in a treelike hierarchy, the instances may be all of the object's children. They may, for example, be an entire subtree with the object specified by an object identifier as its root. The requests and response may be formatted according to SNMP. The object instances may also have an object ID. For example, the object instances may have the object's ID, appended with a new suffix.
Examples for performance metrics may include passive metrics such as InOctets or OutOctets provided by a network switch. Other examples of performance metrics may include active metrics such as round trip time (RTT), latency, or jitter of traffic on a service provided by the network. For example, a tuple may be {Switch Port MAC address, Performance Metric, Instance Identifier}. In an embodiment, network management server 106 uses the method illustrated in
Network management server 106 may be connected to a database 110. Performance metrics generated by network management server 106 may be stored in database 110 and accessible to users through user interface 112.
In an embodiment, monitoring server 114 receives the stream of tuples from network management server 106. Monitoring server 114 monitors performance metrics received in the stream of tuples 120 to detect any flaw with operation of object instances corresponding to the performance metrics. Monitoring server 114 monitors the stream of tuples 120 as it is generated by the network management server 106 without a need to query database 110. Monitoring server 114 may therefore monitor the performance stream of tuples in real time to detect any operational flaws in the network 102. In this way, monitoring server 114 detects an operational flaw in the network much quicker than a user accessing database 110 may realize the same operational flaw.
In an embodiment, monitoring server 114 uses the method illustrated in
When monitoring server 114 detects an operational flaw in an object instance, it may inform alert server 118 of operational flaw in the object instance, the corresponding performance metric indicating the flaw, and identification of associated network element and object instance. Alerts server 118, using this information, alerts a network operator of the operational flaw. Alert server 118 may send the network operator information in the tuple that contains the metric indicating of the flaw. Alert server 118 may inform the network operator of the operational flaw through email, or any other messaging system using wired or wireless networks, for example cellular network.
At step 220A, network management server 106 generates control metrics for each object instance. Control metrics are generated periodically. The frequency of the control metrics may be determined according to a business rule set in policy module 108 and communicated to the network management server 106. Policy module 108 may set the frequency of the control metric for an object instance. In embodiments, policy module 108 may set the frequency of the control metric for an object instance less that the frequency of any performance metric associated with the object instance.
The control metrics act as a heartbeat for a network element. They set a pace for arrival of the performance metrics. Control metrics may notify the monitoring server of arrival expectancy of performance metrics for a corresponding network instance. Control metrics may not have a value describing performance or functionality of a network instance, but their arrival frequency sets a pace for receiving and evaluating performance metrics. Control metrics of a network instance arrive less frequently than any performance metrics for the network instance. Therefore when a control metric corresponding to a network instance is arrived, network monitoring server expects that all the performance metrics for the network instance to have been arrived.
At step 230A, network management server 106 may generate the stream of tuples using performance metrics and control metric for each object instance. In an embodiment, network management server 106 generates and sends a tuple for each performance metric that it receives in step 210A. Network management server 106 may generate tuples including the control metric of an object instance according to the frequency of the control metric for the object instance as specified by policy server 108.
After receiving a performance metric, network management server 106 may generate a tuple that includes the performance metric, identification of the corresponding object instance, and identification of the corresponding network elements. When a control metric is generated according to a business rule set by policy server 108 for an object instance, network management server 106 generates and sends a tuple that includes the control metric, identification of the corresponding object instance, and identification of the corresponding network element. Therefore tuples that include control metrics appear periodically for each object instance, according to the business rule set by policy server 108 for each object instance. Network management server 106 may also format the tuple according to an instruction set by policy module 108.
At step 230B, network management server 106 may generate the stream of tuples using performance metrics and control metrics for each object instance. In an embodiment, network management server 106 generates and sends a tuple for each performance or control metric that it receives. After receiving a performance metric, network management server 106 may generate a tuple that includes the performance metric, identification of the corresponding object instance, and identification of the corresponding network element. After receiving a control metric, network management server 106 generates and sends a tuple that includes the control metric, identification of the corresponding object instance, and identification of the corresponding network element. Therefore tuples that include control metrics appear periodically for each object instance, according to the frequency they are received by network management server 106.
In embodiments, network management server 106 receives performance metrics from network 102 and monitoring server 114 uses a least frequent performance metric corresponding to a network instance as a control metric for the instance. Policy server 108 may configure network management server 106 and monitoring server 114 to use the least frequent metric of a network instance as the control metric. The least frequent performance metric may function as both a performance and the control metric for the network instance. Thus, control metric role can be assumed by a regular “performance” metric, for example ifAlias (1.3.6.1.2.1.31.1.1.1.18). In that case, the control metric injection/generation described in step 220A may be unnecessary.
At step 330, monitoring server 114 may detect a metric in the received tuple. Monitoring server 114 may gain information about formatting of the tuple, including location of the metric or other information in the tuple, from policy server 116.
At step 340, monitoring server 114 determines whether the metric in the received tuple is a performance metric or a control metric. If it is a performance metric, at step 360, monitoring server 114 will set a flag in memory 116 corresponding to the performance metric. In an embodiment, monitoring server 114 sets the flag in a portion of memory 116 allocated to the object instance. An example embodiment of allocating portions of memory 116 to object instances is shown in
In normal operation of an object instance, all tuples including performance metrics for the object instance are generated between two consecutive tuples including control metrics for the object instance. Monitoring server 114 therefore expects certain performance metrics for an object instance before the control metric for the object instance arrives. Monitoring server 114 may track what performance metrics to expect for an object instance from policy server 116. If monitoring server 114 does not receive all the performance metrics expected for the object instance by the time it receives the corresponding control metric, there is a flaw in operation of the object instance.
If at step 340, network management server 106 determines that the metric in the received tuple is a control metric, at step 350 monitoring server 114 determines whether all the flags indicating receipt of all the performance metrics expected for the object instance are set. If not all the flags are set, at step 370, monitoring server 114 informs alert server 118 to generate an alert. Monitoring server 114, at step 380, erases all the flags in the portion of memory 116 corresponding to the object instance and then continues to monitor the incoming tuples in method 300A.
If at step 350, monitoring server 114 determines that the flags corresponding to all the performance metrics are set, monitoring server 114, at step 380, erases all the flags in the portion of memory 116 corresponding to the object instance. Monitoring server 114 then continues to monitor the incoming tuples in method 300A.
In another embodiment, shown in
If monitoring server 114, at step 362 determined that the performance metric does not have a correct value, it will inform alert server 118 to generate an alert at step 364. The alert may include information indicating the received value of the performance metric, and the corresponding identification of the object instance and the network element. Other steps of method 330B in
After a control metric arrives for an object instance, all the memory locations in the columns of the object instance are reset to “0.” Any time a performance metric corresponding to a flag is arrived, the corresponding row in the object instance columns is set to “1.” When next control metric arrives, monitoring server 114 by examining the column assigned to the object instance determines if all the locations corresponding to the performance metrics that should have arrived for the object instance have value “1.”
Monitoring server 114, at step 520, reads the third field instanceID in the received tuple. Monitoring server 114, at step 530 reads the second field which is the metric, from the tuple.
If monitoring server 114 at step 540 determines that the metric in the received tuple is a metricIN or metricOUT, it will write value “1” in the corresponding memory location to the metric and the instanceID. For example referring to
If monitoring server 114 at step 540 determines that the metric in the received tuple is a control metric, at step 550 it verifies whether metricIN and metricOUT bits in the memory column corresponding to instanceID have value “1.” If they both have value “1,” monitoring server 114 writes “0” on metricIN and metricOUT bits of instanceID column and continues to receive tuples on the tuple stream. If one or both of the values corresponding to instanceID in memory 600 is “0,” monitoring server 114 informs alert server 118 to create an alert. Monitoring server 114 then resets both bits corresponding to instanceID and continues to receive tuples on the tuple stream.
Each of the blocks and modules in
Each of the blocks and modules in
Identifiers, such as “(a),” “(b),” “(i),” “(ii),” etc., are sometimes used for different elements or steps. These identifiers are used for clarity and do not necessarily designate an order for the elements or steps.
The present invention has been described above with the aid of functional building blocks illustrating the implementation of specified functions and relationships thereof. The boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries can be defined so long as the specified functions and relationships thereof are appropriately performed.
The foregoing description of the specific embodiments will so fully reveal the general nature of the invention that others can, by applying knowledge within the skill of the art readily modify and/or adapt for various applications such specific embodiments, without undue experimentation, without departing from the general concept of the present invention. Therefore, such adaptations and modifications are intended to be within the meaning and range of equivalents of the disclosed embodiments, based on the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by the skilled artisan in light of the teachings and guidance.
The breadth and scope of the present embodiments should not be limited by any of the above-described examples, but should be defined only in accordance with the following claims and their equivalents.
This application claims the benefit under 35 U.S.C. § 120 as a continuation of U.S. patent application Ser. No. 15/918,775, filed Mar. 12, 2018, now U.S. Pat. No. 10,404,561, which is a continuation of U.S. patent application Ser. No. 14/738,380, filed Jun. 12, 2015, now U.S. Pat. No. 9,917,753, the entire contents of each of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6343320 | Fairchild | Jan 2002 | B1 |
6708137 | Carley | Mar 2004 | B2 |
7076547 | Black | Jul 2006 | B1 |
7860960 | Knight et al. | Dec 2010 | B1 |
9396157 | Cradick | Jul 2016 | B2 |
9800489 | Polyanskiy | Oct 2017 | B1 |
10263868 | Baldi | Apr 2019 | B1 |
20030105976 | Copeland | Jun 2003 | A1 |
20060072583 | Sanda | Apr 2006 | A1 |
20060268933 | Kellerer | Nov 2006 | A1 |
20090016335 | Bays | Jan 2009 | A1 |
20090094195 | Black | Apr 2009 | A1 |
20090138549 | Huang | May 2009 | A1 |
20090138945 | Savchuk | May 2009 | A1 |
20090217291 | Errickson | Aug 2009 | A1 |
20100064039 | Ginter | Mar 2010 | A9 |
20110149969 | Beecroft | Jun 2011 | A1 |
20120072575 | King | Mar 2012 | A1 |
20120239793 | Gangalapur | Sep 2012 | A1 |
20130080600 | Santosuosso | Mar 2013 | A1 |
20130080654 | Branson | Mar 2013 | A1 |
20130103832 | Cradick | Apr 2013 | A1 |
20130117847 | Friedman et al. | May 2013 | A1 |
20130262500 | Bratspiess | Oct 2013 | A1 |
20130290966 | Branson | Oct 2013 | A1 |
20130343213 | Reynolds | Dec 2013 | A1 |
20140019609 | Williams | Jan 2014 | A1 |
20140059200 | Nguyen | Feb 2014 | A1 |
20140122557 | Branson | May 2014 | A1 |
20140280895 | Branson | Sep 2014 | A1 |
20150074108 | Branson | Mar 2015 | A1 |
20150074258 | Ferreira | Mar 2015 | A1 |
20150236959 | Cai | Aug 2015 | A1 |
20150333992 | Vasseur | Nov 2015 | A1 |
20160036663 | Bley | Feb 2016 | A1 |
20160065438 | Bird | Mar 2016 | A1 |
20160080230 | Anand | Mar 2016 | A1 |
20160092247 | Branson | Mar 2016 | A1 |
20160246846 | Barsness | Aug 2016 | A1 |
20160364283 | Baron | Dec 2016 | A1 |
20160366035 | Ortega | Dec 2016 | A1 |
20160366039 | Caputo, II et al. | Dec 2016 | A1 |
20170116059 | Wolf | Apr 2017 | A1 |
20170195383 | Branson | Jul 2017 | A1 |
20170339203 | Kekre | Nov 2017 | A1 |
20180167292 | Cao | Jun 2018 | A1 |
20180205622 | Caputo, II et al. | Jul 2018 | A1 |
20180297402 | Hsiao | Oct 2018 | A1 |
20190098076 | Moon | Mar 2019 | A1 |
20190182118 | Manning | Jun 2019 | A1 |
20190286509 | Baron | Sep 2019 | A1 |
20190391893 | Baron | Dec 2019 | A1 |
20200044921 | Srinivas | Feb 2020 | A1 |
20200117530 | Baron | Apr 2020 | A1 |
20200136940 | Gandham | Apr 2020 | A1 |
Entry |
---|
Extended European Search Report, dated Oct. 5, 2018, Application No. 16808088.5, filed Jun. 6, 2016; 10 pgs. |
International Preliminary Report on Patentability dated Dec. 12, 2017, Int'l Appl. No. PCT/US16/036025, Int'l Filing Date Jun. 6, 2016; 12 pgs. |
International Search Report dated Aug. 26, 2016, Int'l Appl. No. PCT/US16/036025, Int'l Filing Date Jun. 6, 2016; 3 pgs. |
Written Opinion of the International Searching Authority dated Aug. 26, 2016, Int'l Appl. No. PCT/US16/036025, Int'l Filing Date Jun. 6, 2016; 10 pgs. |
Number | Date | Country | |
---|---|---|---|
20190386903 A1 | Dec 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15918775 | Mar 2018 | US |
Child | 16554556 | US | |
Parent | 14738380 | Jun 2015 | US |
Child | 15918775 | US |