Network topology plays an important part in understanding network performance. Network Performance Monitoring (PM) data is used in combination to the topology to derive actionable insights to improve performance. PM data is almost always associated with some form of topology—either capturing metrics on data as it flows through a particular point in the network (i.e. flowmeter or passive capture or SNMP data from a router) or via a synthetic test session that generates metrics on packet flow between two points.
There is a need to leverage correlation of information to gain a broader understanding of how a network is behaving and where the devices affecting the performance are located.
In one embodiment of the invention, a method is disclosed for locating performance problems in a network comprising associating one or more metadata to a plurality of monitored objects, collecting one or more performance data from said plurality monitored objects, creating a correlation of said one or more performance data across two or more monitored objects matching predetermined set of metadata, displaying said correlation on a map representing a plurality of devices, wherein said correlation can be used to isolate one or more devices impacting said performance data.
In another embodiment, the devices are a conceptual device.
In another embodiment, a topology network analysis method is disclosed, comprising: monitoring one or more performance data of a plurality of monitored objects, analyzing said performance of said network using graph analytics of said performance data of said monitored object, visualizing on a graphical user interface a relative performance of a network device as compared to other of said network device.
In another embodiment, topology network analysis method further comprises showing the available paths between two network devices.
To easily identify the discussion of any particular element or act, the most significant digit or digits in a reference number refer to the figure number in which that element is first introduced.
The term monitored objects used herein refers to, but not limited to, a test session, an SNMP router interface or any point in the network that performance data can be collected. In this example, the monitored object is the test session between the first and second device.
In this embodiment, a bottom up investigative workflow is implemented based on the ability to start with a singular object that is experiencing a problem and step back to see if it's part of a bigger issue. The goal of logical event maps is to use an object's topology metadata to correlate across of all the objects reporting into analytics with the same metadata tags, and point towards hot spots. For example, the logical even map can display the number of violations counts for each hops (512, 514, 516, 518, 520, 522). Users take a sampling of objects experiencing issues with a given topology point and investigate at a higher level to confirm whether the problems are truly correlated.
Analytics looks at all of the other monitored objects in the network that pass through a hop, it evaluates the total number of performance threshold breaches from those sessions, and plots concentric circles based on that volume of events and severity.
In another embodiment, the size and/or color of the violation count circles can vary to indicate the severity of the violations.
Once in the system, administrators can decide which metadata categories represent the flow of data.
The network 106 comprises three hops (1012, 1014 and 1016). The system uses correlation to indicate which segment of a path might be encountering issues. Assuming, for example, three performance tests (using test packets) are running across the network 106, on each of the above three paths and two paths, A and C, reporting bad performance results, while B is experiencing normal measurements. Statistically the system establishes that hop 1 1012 is an area of concern as more sessions with poor results pass through there. A total count of threshold breaches experienced by each node can be used to determine the significance.
The next mode 1104 is ongoing while each monitored object is repeatedly reporting performance monitoring data to the system.
When issues arise 1106 (e.g. performance threshold violation), the logical event map is updated to reflect the violation. The system extracts other monitored objects that share common hops. The system evaluates the performance of each monitored objects that share this hop to determine the number of threshold violation that have occurred and to update the logical event map.
When investigating a performance issue, the user may be looking at a set of correlated objects (as per
As another embodiment, the size and/or color of the circles can vary to identify the importance of the problem.
Based on these analytics, the user can visualize (
The statistical impact on the performance of each hop may optionally be displayed when one or more path segments is selected by the user.
A computer program (which may also be referred to or described as a software application, code, a program, a script, software, a module or a software module) can be written in any form of programming language. This includes compiled or interpreted languages, or declarative or procedural languages. A computer program can be deployed in many forms, including as a module, a subroutine, a stand-alone program, a component, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or can be deployed on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
As used herein, a “software engine” or an “engine,” refers to a software implemented system that provides an output that is different from the input. An engine can be an encoded block of functionality, such as a platform, a library, an object or a software development kit (“SDK”). Each engine can be implemented on any type of computing device that includes one or more processors and computer readable media. Furthermore, two or more of the engines may be implemented on the same computing device, or on different computing devices. Non-limiting examples of a computing device include tablet computers, servers, laptop or desktop computers, music players, mobile phones, e-book readers, notebook computers, PDAs, smart phones, or other stationary or portable devices.
The processes and logic flows described herein can be performed by one or more programmable computers executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit). For example, the processes and logic flows can be performed by and apparatus can also be implemented as a graphics processing unit (GPU).
Computers suitable for the execution of a computer program include, by way of example, general or special purpose microprocessors or both, or any other kind of central processing unit. Generally, a central processing unit receives instructions and data from a read-only memory or a random-access memory or both. A computer can also include, or be operatively coupled to receive data from, or transfer data to, or both, one or more mass storage devices for storing data, e.g., optical disks, magnetic, or magneto optical disks. It should be noted that a computer does not require these devices. Furthermore, a computer can be embedded in another device. Non-limiting examples of the latter include a game console, a mobile telephone a mobile audio player, a personal digital assistant (PDA), a video player, a Global Positioning System (GPS) receiver, or a portable storage device. A non-limiting example of a storage device include a universal serial bus (USB) flash drive.
Computer readable media suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices; non-limiting examples include magneto optical disks; semiconductor memory devices (e.g., EPROM, EEPROM, and flash memory devices); CD ROM disks; magnetic disks (e.g., internal hard disks or removable disks); and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
To provide for interaction with a user, embodiments of the subject matter described herein can be implemented on a computer having a display device for displaying information to the user and input devices by which the user can provide input to the computer (e.g., a keyboard, a pointing device such as a mouse or a trackball, etc.). Other kinds of devices can be used to provide for interaction with a user. Feedback provided to the user can include sensory feedback (e.g., visual feedback, auditory feedback, or tactile feedback). Input from the user can be received in any form, including acoustic, speech, or tactile input. Furthermore, there can be interaction between a user and a computer by way of exchange of documents between the computer and a device used by the user. As an example, a computer can send web pages to a web browser on a user's client device in response to requests received from the web browser.
Embodiments of the subject matter described in this specification can be implemented in a computing system that includes: a front end component (e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described herein); or a middleware component (e.g., an application server); or a back end component (e.g. a data server); or any combination of one or more such back end, middleware, or front end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Non-limiting examples of communication networks include a local area network (“LAN”) and a wide area network (“WAN”).
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
While this specification contains many specific implementation details, these should not be construed as limitations on the scope of what may be claimed, but rather as descriptions of features that may be specific to particular embodiments. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable sub-combination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a sub-combination or variation of a sub-combination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system modules and components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
Particular embodiments of the subject matter have been described. Other embodiments are within the scope of the following claims. For example, the actions recited in the claims can be performed in a different order and still achieve desirable results. As one example, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In certain implementations, multitasking and parallel processing may be advantageous.
This application is a continuation of U.S. patent application Ser. No. 16/794,447, filed Feb. 19, 2020, now allowed, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6570867 | Robinson | May 2003 | B1 |
8289845 | Baldonado | Oct 2012 | B1 |
9712381 | Emanuel | Jul 2017 | B1 |
10791421 | Rothschild | Sep 2020 | B1 |
10848402 | Haddow et al. | Nov 2020 | B1 |
20050091356 | Izzo | Apr 2005 | A1 |
20130223218 | Vasseur | Aug 2013 | A1 |
20140211636 | Robitaille | Jul 2014 | A1 |
20140280810 | Gabrielson | Sep 2014 | A1 |
20140379895 | Jain | Dec 2014 | A1 |
20150326457 | Wu | Nov 2015 | A1 |
20160020940 | Maltz et al. | Jan 2016 | A1 |
20180048666 | Alderson | Feb 2018 | A1 |
20180121032 | Naous | May 2018 | A1 |
20180309637 | Gill et al. | Oct 2018 | A1 |
20210095971 | Mao et al. | Apr 2021 | A1 |
Number | Date | Country |
---|---|---|
20190088343 | Jul 2019 | KR |
2014144520 | Jan 2015 | WO |
2015042171 | Mar 2015 | WO |
2015113036 | Jul 2015 | WO |
2018200756 | Nov 2018 | WO |
Number | Date | Country | |
---|---|---|---|
20220393948 A1 | Dec 2022 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16794447 | Feb 2020 | US |
Child | 17846342 | US |