The present technology pertains network analytics, and more specifically to the visualization of data flows between logical entities.
Datacenters can include a large number of servers and virtual machines. As such datacenters can have a large number of data flows between each server and virtual machine. Monitoring and managing the network of a datacenter can be cumbersome especially with a datacenter with a large number of servers, virtual machines and data flows. Visualizing the network of a datacenter can help network operators manage and monitor the network of a datacenter. However, because of the large number of data flows, visualizing these data flows can be very cumbersome.
In order to describe the manner in which the above-recited and other advantages and features of the disclosure can be obtained, a more particular description of the principles briefly described above will be rendered by reference to specific embodiments that are illustrated in the appended drawings. Understanding that these drawings depict only example embodiments of the disclosure and are not therefore to be considered to be limiting of its scope, the principles herein are described and explained with additional specificity and detail through the use of the accompanying drawings in which:
The present disclosure provides a mechanism for visualizing data flows within a datacenter in an interactive hierarchical network chord diagram. In some embodiments a dataflow monitoring system analyzes data describing data flows. Based on the analyzed data describing data flows, the dataflow monitoring system groups a portion of the data flows that originate at the same first endpoint and terminate at the same second endpoint. Subsequently, the dataflow monitoring system displays an interactive hierarchical network chord diagram to include a chord with a first endpoint and a second endpoint. The chord represents the grouped portion of data flows that originate at the same first endpoint and terminate at the same second endpoint. Upon receiving a selection of the chord or the first endpoint of the chord, the dataflow monitoring system expands the grouped portion of the data flows into sub-groupings of data flows and the first endpoint into a set of sub-endpoints. After which, the dataflow monitoring system updates the displayed interactive chord diagram to include the expanded chord and an expanded first endpoint.
Various embodiments of the disclosure are discussed in detail below. While specific implementations are discussed, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without parting from the spirit and scope of the disclosure.
The disclosed technology is directed to the visualization of data flows within a datacenter. Specifically, to the generation and presentation of an interactive hierarchical network chord diagram (or network chord diagram) to represent analyzed data describing data flows within a datacenter. Additionally, the network chord diagram can visualize the data flows of a datacenter at different levels of abstraction. For example, at the lowest level of abstraction, data flows can be visualized according to the dataflow's individual sending and receiving hosts. At a higher level of abstraction, the data flows can be further grouped by clusters of hosts. As such, the network chord diagram can visualize the grouped data flows by their sending and receiving clusters of hosts. At even higher level of abstraction, the data flows can be further grouped together by common subnets of each cluster of hosts. As such, the network chord diagram can visualize the grouped data flows by their sending and receiving subnets. By allowing the user to visualize the data flows of a data center at different levels of abstraction, the user can more easily consume visualization of the data flows.
Leaf routers 104 can be responsible for routing and/or bridging tenant or endpoint packets and applying network policies. Spine routers 102 can perform switching and routing within fabric 112. Thus, network connectivity in fabric 112 can flow from the spine routers 102 to leaf routers 104, and vice versa.
Leaf routers 104 can provide servers 1-5 (106A-E) (collectively “106”), hypervisors 1-4 (108A-108D) (collectively “108”), and virtual machines (VMs) 1-5 (110A-110E) (collectively “110”) access to fabric 112. For example, leaf routers 104 can encapsulate and decapsulate packets to and from servers 106 in order to enable communications throughout environment 100. Leaf routers 104 can also connect other devices, such as device 114, with fabric 112. Device 114 can be any network-capable device(s) or network(s), such as a firewall, a database, a server, a collector 118 (further described below), an engine 120 (further described below), etc. Leaf routers 104 can also provide any other servers, resources, endpoints, external networks, VMs, services, tenants, or workloads with access to fabric 112.
VMs 110 can be virtual machines hosted by hypervisors 108 running on servers 106. VMs 110 can include workloads running on a guest operating system on a respective server. Hypervisors 108 can provide a layer of software, firmware, and/or hardware that creates and runs the VMs 110. Hypervisors 108 can allow VMs 110 to share hardware resources on servers 106, and the hardware resources on servers 106 to appear as multiple, separate hardware platforms. Moreover, hypervisors 108 and servers 106 can host one or more VMs 110. For example, server 106A and hypervisor 108A can host VMs 110A-B.
In some cases, VMs 110 and/or hypervisors 108 can be migrated to other servers 106. For example, VM 110A can be migrated to server 106C and hypervisor 108B. Servers 106 can similarly be migrated to other locations in network environment 100. For example, a server connected to a specific leaf router can be changed to connect to a different or additional leaf router. In some cases, some or all of the servers 106, hypervisors 108, and/or VMs 110 can represent tenant space. Tenant space can include workloads, services, applications, devices, and/or resources that are associated with one or more clients or subscribers. Accordingly, traffic in the network environment 100 can be routed based on specific tenant policies, spaces, agreements, configurations, etc. Moreover, addressing can vary between one or more tenants. In some configurations, tenant spaces can be divided into logical segments and/or networks and separated from logical segments and/or networks associated with other tenants.
Any of leaf routers 104, servers 106, hypervisors 108, and VMs 110 can include a sensor 116 configured to capture network data, and report any portion of the captured data to collector 118. Sensors 116 can be processes, agents, modules, drivers, or components deployed on a respective system (e.g., a server, VM, hypervisor, leaf router, etc.), configured to capture network data for the respective system (e.g., data received or transmitted by the respective system), and report some or all of the captured data to collector 118.
For example, a VM sensor can run as a process, kernel module, or kernel driver on the guest operating system installed in a VM and configured to capture data (e.g., network and/or system data) processed (e.g., sent, received, generated, etc.) by the VM. A hypervisor sensor can run as a process, kernel module, or kernel driver on the host operating system installed at the hypervisor layer and configured to capture data (e.g., network and/or system data) processed (e.g., sent, received, generated, etc.) by the hypervisor. A server sensor can run as a process, kernel module, or kernel driver on the host operating system of a server and configured to capture data (e.g., network and/or system data) processed (e.g., sent, received, generated, etc.) by the server. And a network device sensor can run as a process or component in a network device, such as leaf routers 104, and configured to capture data (e.g., network and/or system data) processed (e.g., sent, received, generated, etc.) by the network device.
Sensors 116 can be configured to report data and/or metadata about one or more packets, flows, communications, processes, events, and/or activities observed to collector 118. For example, sensors 116 can capture network data as well as information about the system or host of the sensors 116 (e.g., where the sensors 116 are deployed). Such information can also include, for example, data or metadata of active or previously active processes of the system, metadata of files on the system, system alerts, networking information, etc. Reported data from sensors 116 can provide details or statistics particular to one or more tenants. For example, reported data from a subset of sensors 116 deployed throughout devices or elements in a tenant space can provide information about the performance, use, quality, events, processes, security status, characteristics, statistics, patterns, conditions, configurations, topology, and/or any other information for the particular tenant space.
Additionally, the reports of sensors 116 can include timestamps associated with captured network traffic received, transmitted or generated by the host/node (e.g. VM, hypervisor, server, and leaf router). Sensors 116 can also associate a timestamp indicating when sensors 116 send the reports to collectors 118. Regardless, the timestamps can be based on the clock of the host (e.g., server, switch, VM, hypervisor, etc.) of where the sensor resides. For example, timestamps associated with sensors 116 residing on hypervisor 2 108B can be based on the clock of hypervisor 2 108B. Furthermore, since multiple sensors 116 can reside on the same host, the reports of the multiple sensors 116 can be based on a same clock associated with the host or multiple clocks associated with the host. Collectors 118 can be one or more devices, modules, workloads and/or processes capable of receiving data from sensors 116. Collectors 118 can thus collect reports and data from sensors 116. Collectors 118 can be deployed anywhere in network environment 100 and/or even on remote networks capable of communicating with network environment 100. For example, one or more collectors can be deployed within fabric 112 or on one or more of the servers 106. One or more collectors can be deployed outside of fabric 112 but connected to one or more leaf routers 104. Collectors 118 can be part of servers 106 and/or separate servers or devices (e.g., device 114). Collectors 118 can also be implemented in a cluster of servers.
Collectors 118 can be configured to collect data from sensors 116. In addition, collectors 118 can be implemented in one or more servers. As previously noted, collectors 118 can include one or more collectors. Moreover, each collector can be configured to receive reported data from all sensors 116 or a subset of sensors 116. For example, a collector can be assigned to a subset of sensors 116 so the data received by that specific collector is limited to data from the subset of sensors.
Collectors 118 can be configured to aggregate data from all sensors 116 and/or a subset of sensors 116. Moreover, collectors 118 can be configured to analyze some or all of the data reported by sensors 116. For example, collectors 118 can include analytics engines (e.g., engines 120) for analyzing collected data. Environment 100 can also include separate analytics engines 120 configured to analyze the data reported to collectors 118. For example, engines 120 can be configured to receive collected data from collectors 118 and aggregate the data, analyze the data (individually and/or aggregated), generate reports, identify conditions, compute statistics, visualize reported data, troubleshoot conditions, visualize the network and/or portions of the network (e.g., a tenant space), generate alerts, identify patterns, calculate misconfigurations, identify errors, generate suggestions, generate testing, and/or any other analytics functions.
While collectors 118 and engines 120 are shown as separate entities, this is for illustration purposes as other configurations are also contemplated herein. For example, any of collectors 118 and engines 120 can be part of a same or separate entity. Moreover, any of the collector, aggregation, and analytics functions can be implemented by one entity (e.g., collectors 118) or separately implemented by multiple entities (e.g., engine 120 and/or collectors 118).
Each of the sensors 116 can use a respective address (e.g., internet protocol (IP) address, port number, etc.) of their host to send information to collectors 118 and/or any other destination. Moreover, sensors 116 can periodically send information about flows they observe to collectors 118. Sensors 116 can be configured to report each and every flow they observe. Sensors 116 can report a list of flows that were active during a period of time (e.g., between the current time and the time of the last report). The communication channel between a sensor and collector 118 can also create a flow in every reporting interval. Thus, the information transmitted or reported by sensors 116 can also include information about the flow created by the communication channel.
Hypervisor 208 can be a layer of software, firmware, and/or hardware that creates and runs VMs 202. The guest operating systems running on VMs 202 can share virtualized hardware resources created by hypervisor 208. The virtualized hardware resources can provide the illusion of separate hardware components. Moreover, the virtualized hardware resources can perform as physical hardware components (e.g., memory, storage, processor, network interface, etc.), and can be driven by hardware resources 212 on server 106A. Hypervisor 208 can have one or more network addresses, such as an internet protocol (IP) address, to communicate with other devices, components, or networks. For example, hypervisor 208 can have a dedicated IP address which it can use to communicate with VMs 202, server 106A, and/or any remote devices or networks.
Hardware resources 212 of server 106A can provide the underlying physical hardware driving operations and functionalities provided by server 106A, hypervisor 208, and VMs 202. Hardware resources 212 can include, for example, one or more memory resources, one or more storage resources, one or more communication interfaces, one or more processors, one or more circuit boards, one or more extension cards, one or more power supplies, one or more antennas, one or more peripheral components, etc. Additional examples of hardware resources are described below with reference to
Server 106A can also include one or more host operating systems. The number of host operating system can vary by configuration. For example, some configurations can include a dual boot configuration that allows server 106A to boot into one of multiple host operating systems. In other configurations, server 106A may run a single host operating system. Host operating systems can run on hardware resources 212. In some cases, hypervisor 208 can run on, or utilize, a host operating system on server 106A.
Server 106A can also have one or more network addresses, such as an internet protocol (IP) address, to communicate with other devices, components, or networks. For example, server 106A can have an IP address assigned to a communications interface from hardware resources 212, which it can use to communicate with VMs 202, hypervisor 208, leaf router 104A in
VM sensors 204 can be deployed on one or more of the VMs 202. VM sensors 204 can be data and packet inspection agents deployed on the VMs 202 to capture packets, flows, processes, events, traffic, and/or any data flowing through the VMs 202. VM sensors 204 can be configured to export or report any data collected or captured by the sensors 204 to a remote entity, such as collectors 118, for example. VM sensors 204 can communicate or report such data using a network address of the respective VMs 202 (e.g., VM IP address).
VM sensors 204 can capture and report any traffic (e.g., packets, flows, etc.) sent, received, generated, and/or processed by VMs 202. For example, sensors 204 can report every packet or flow of communication sent and received by VMs 202. Moreover, any communication sent or received by VMs 202, including data reported from sensors 204, can create a network flow. VM sensors 204 can report such flows to a remote device, such as collectors 118 illustrated in
VM sensors 204 can also report multiple flows as a set of flows. When reporting a set of flows, VM sensors 204 can include a flow identifier for the set of flows and/or a flow identifier for each flow in the set of flows. VM sensors 204 can also include one or more timestamps and other information as previously explained.
VM sensors 204 can run as a process, kernel module, or kernel driver on the guest operating systems 206 of VMs 202. VM sensors 204 can thus monitor any traffic sent and received by VMs 202, any processes running on the guest operating systems 206, any workloads on VMs 202, etc.
Hypervisor sensor 210 can be deployed on hypervisor 208. Hypervisor sensor 210 can be a data inspection agent deployed on hypervisor 208 to capture traffic (e.g., packets, flows, etc.) and/or data flowing through hypervisor 208. Hypervisor sensor 210 can be configured to export or report any data collected or captured by hypervisor sensor 210 to a remote entity, such as collectors 118, for example. Hypervisor sensor 210 can communicate or report such data using a network address of hypervisor 208, such as an IP address of hypervisor 208.
Because hypervisor 208 can see traffic and data from VMs 202, hypervisor sensor 210 can also capture and report any data (e.g., traffic data) associated with VMs 202. For example, hypervisor sensor 210 can report every packet or flow of communication sent or received by VMs 202 and/or VM sensors 204. Moreover, any communication sent or received by hypervisor 208, including data reported from hypervisor sensor 210, can create a network flow. Hypervisor sensor 210 can report such flows to a remote device, such as collectors 118 illustrated in
Hypervisor sensor 210 can also report multiple flows as a set of flows. When reporting a set of flows, hypervisor sensor 210 can include a flow identifier for the set of flows and/or a flow identifier for each flow in the set of flows. Hypervisor sensor 210 can also include one or more timestamps and other information as previously explained.
As previously explained, any communication captured or reported by VM sensors 204 can flow through hypervisor 208. Thus, hypervisor sensor 210 can observe and capture any flows or packets reported by VM sensors 204. Accordingly, hypervisor sensor 210 can also report any packets or flows reported by VM sensors 204. For example, VM sensor A on VM A captures flow 1 (F1) and reports F1 to collector 118 on
When reporting F1, hypervisor sensor 210 can report F1 as a message or a separate from the message or report of F1 transmitted by VM sensor A on VM A. However, hypervisor sensor 210 can also, or otherwise, report F1 as a message or report that includes or appends the message or report of F1 transmitted by VM sensor A on VM A. In other words, hypervisor sensor 210 can report F1 as a separate message or report from VM sensor A's message or report of F1, and/or a same message or report that includes both a report of F1 by hypervisor sensor 210 and the report of F1 by VM sensor A at VM A. In this way, VM sensors 204 at VMs 202 can report packets or flows received or sent by VMs 202, and hypervisor sensor 210 at hypervisor 208 can report packets or flows received or sent by hypervisor 208, including any flows or packets received or sent by VMs 202 and/or reported by VM sensors 204.
Hypervisor sensor 210 can run as a process, kernel module, or kernel driver on the host operating system associated with hypervisor 208. Hypervisor sensor 210 can thus monitor any traffic sent and received by hypervisor 208, any processes associated with hypervisor 208, etc.
Server 106A can also have a server sensor 214 running on it. Server sensor 214 can be a data inspection agent deployed on server 106A to capture data (e.g., packets, flows, traffic data, etc.) on server 106A. Server sensor 214 can be configured to export or report any data collected or captured by server sensor 214 to a remote entity, such as collector 118, for example. Server sensor 214 can communicate or report such data using a network address of server 106A, such as an IP address of server 106A.
Server sensor 214 can capture and report any packet or flow of communication associated with server 106A. For example, sensor 216 can report every packet or flow of communication sent or received by one or more communication interfaces of server 106A. Moreover, any communication sent or received by server 106A, including data reported from sensors 204 and 210, can create a network flow. Server sensor 214 can report such flows to a remote device, such as collector 118 illustrated in
Server sensor 214 can also report multiple flows as a set of flows. When reporting a set of flows, server sensor 214 can include a flow identifier for the set of flows and/or a flow identifier for each flow in the set of flows. Server sensor 214 can also include one or more timestamps and other information as previously explained.
Any communications capture or reported by sensors 204 and 210 can flow through server 106A. Thus, server sensor 214 can observe or capture any flows or packets reported by sensors 204 and 210. In other words, network data observed by sensors 204 and 210 inside VMs 202 and hypervisor 208 can be a subset of the data observed by server sensor 214 on server 106A. Accordingly, server sensor 214 can report any packets or flows reported by sensors 204 and 210. For example, sensor A on VM A captures flow 1 (F1) and reports F1 to collector 118 on
When reporting F1, server sensor 214 can report F1 as a message or report that is separate from any messages or reports of F1 transmitted by sensor A on VM A or sensor 210 on hypervisor 208. However, server sensor 214 can also, or otherwise, report F1 as a message or report that includes or appends the messages or reports or metadata of F1 transmitted by sensor A on VM A and sensor 210 on hypervisor 208. In other words, server sensor 214 can report F1 as a separate message or report from the messages or reports of F1 from sensor A and sensor 210, and/or a same message or report that includes a report of F1 by sensor A, sensor 210, and sensor 214. In this way, sensors 204 at VMs 202 can report packets or flows received or sent by VMs 202, sensor 210 at hypervisor 208 can report packets or flows received or sent by hypervisor 208, including any flows or packets received or sent by VMs 202 and reported by sensors 204, and sensor 214 at server 106A can report packets or flows received or sent by server 106A, including any flows or packets received or sent by VMs 202 and reported by sensors 204, and any flows or packets received or sent by hypervisor 208 and reported by sensor 210.
Server sensor 214 can run as a process, kernel module, or kernel driver on the host operating system or a component of server 106A. Server sensor 214 can thus monitor any traffic sent and received by server 106A, any processes associated with server 106A, etc.
In addition to network data, sensors 204, 210, and 214 can capture additional information about the system or environment in which they reside. For example, sensors 204, 210, and 214 can capture data or metadata of active or previously active processes of their respective system or environment, metadata of files on their respective system or environment, timestamps, network addressing information, flow identifiers, sensor identifiers, etc. Moreover, sensors 204, 210, 214 are not specific to any operating system environment, hypervisor environment, network environment, or hardware environment. Thus, sensors 204, 210, and 214 can operate in any environment.
As previously explained, sensors 204, 210, and 214 can send information about the network traffic they observe. This information can be sent to one or more remote devices, such as one or more servers, collectors, engines, etc. Each sensor can be configured to send respective information using a network address, such as an IP address, and any other communication details, such as port number, to one or more destination addresses or locations. Sensors 204, 210, and 214 can send metadata about one or more flows, packets, communications, processes, events, etc.
Sensors 204, 210, and 214 can periodically report information about each flow or packet they observe. The information reported can contain a list of flows or packets that were active during a period of time (e.g., between the current time and the time at which the last information was reported). The communication channel between the sensor and the destination can create a flow in every interval. For example, the communication channel between sensor 210 and collector 118 can create a control flow. Thus, the information reported by a sensor can also contain information about this control flow. For example, the information reported by sensor 210 to collector 118 can include a list of flows or packets that were active at hypervisor 208 during a period of time, as well as information about the communication channel between sensor 210 and collector 118 used to report the information by sensor 210.
The report(s) of sensors 204, 210, and 214 can include timestamps associated with captured network traffic received, transmitted or generated by the host/node (e.g. VM 3 202, hypervisor 208 and server 106A). Sensors 204, 210, and 214 can also associate a timestamp indicating when each respective sensor 204, 210, and 214 transmits its respective report(s) to the remote device, such as collectors 118 illustrated in
In this example, leaf router 104A can include network resources 222, such as memory, storage, communication, processing, input, output, and other types of resources. Leaf router 104A can also include an operating system environment 224. The operating system environment 224 can include any operating system, such as a network operating system. The operating system environment 224 can include processes, functions, and applications for performing networking, routing, switching, forwarding, policy implementation, messaging, monitoring, and other types of operations.
Leaf router 104A can also include sensor 226. Sensor 226 can be an agent configured to capture network data, such as flows or packets, sent and received by leaf router 104A. Sensor 226 can also be configured to capture other information, such as processes, statistics, alerts, status information, device information, etc. Moreover, sensor 226 can be configured to report captured data to a remote device or network, such as collector 118, for example. Sensor 226 can report information using one or more network addresses associated with leaf router 104A. For example, sensor 226 can be configured to report information using an IP assigned to an active communications interface on leaf router 104A.
Leaf router 104A can be configured to route traffic to and from other devices or networks, such as server 106A. Accordingly, sensor 226 can also report data reported by other sensors on other devices. For example, leaf router 104A can be configured to route traffic sent and received by server 106A to other devices. Thus, data reported from sensors deployed on server 106A, such as VM and hypervisor sensors on server 106A, would also be observed by sensor 226 and can thus be reported by sensor 226 as data observed at leaf router 104A. Data reported by the VM and hypervisor sensors on server 106A can therefore be a subset of the data reported by sensor 226.
The report(s) of sensors 226 can include timestamps associated with captured network traffic received, transmitted or generated by the host/node (e.g. operating system environment 224 and network resources 222). Sensors 226 can also associate a timestamp indicating when each respective sensor 226 transmits its respective report(s) to the remote device, such as collectors 118 illustrated in
Sensor 226 can run as a process or component (e.g., firmware, module, hardware device, etc.) in leaf router 104A. Moreover, sensor 226 can be installed on leaf router 104A as a software or firmware agent. In some configurations, leaf router 104A itself can act as sensor 226. Moreover, sensor 226 can run within the operating system 224 and/or separate from the operating system 224.
Moreover, VM sensor 116 at VM 110A, hypervisor sensor 116 at hypervisor 108A, network device sensor 116 at leaf router 104A, and any server sensor at server 106A (e.g., sensor running on host environment of server 106A), can send reports 244 to collector 118 based on the packets or traffic 242 captured at each respective sensor. Reports 244 from VM sensor 116 to collector 118 can flow through VM 110A, hypervisor 108A, server 106A, and leaf router 104A. Reports 244 from hypervisor sensor 116 to collector 118 can flow through hypervisor 108A, server 106A, and leaf router 104A. Reports 244 from any other server sensor at server 106A to collector 118 can flow through server 106A and leaf router 104A. Finally, reports 244 from network device sensor 116 to collector 118 can flow through leaf router 104A.
Reports 244 can include any portion of packets or traffic 242 captured at the respective sensors. Reports 244 can also include other information, such as timestamps, process information, sensor identifiers, flow identifiers, flow statistics, notifications, logs, user information, system information, etc. Moreover, reports 244 can be transmitted to collector 118 periodically as new packets or traffic 242 are captured by a sensor. Further, each sensor can send a single report or multiple reports to collector 118. For example, each of the sensors 116 can be configured to send a report to collector 118 for every flow, packet, message, communication, or network data received, transmitted, and/or generated by its respective host (e.g., VM 110A, hypervisor 108A, server 106A, and leaf router 104A). As such, collector 118 can receive a report of a same packet from multiple sensors.
The reports 224 of sensors 116 can include timestamps associated with captured network traffic received, transmitted or generated by the host/node (VM 110A, hypervisor 108A, server 106A, and leaf router 104A). Sensors 116 can also associate a timestamp indicating when each of the sensors 116 transmits reports 224 to the collector 118. Regardless, the timestamps associated by sensors 226 can be based on a clock of the host/node (e.g. VM 110A, hypervisor 108A, server 106A, and leaf router 104A) where each of the respective sensors 116 resides.
For example, a packet received by VM 110A from fabric 112 can be captured and reported by VM sensor 116. Since the packet received by VM 110A will also flow through leaf router 104A and hypervisor 108A, it can also be captured and reported by hypervisor sensor 116 and network device sensor 116. Thus, for a packet received by VM 110A from fabric 112, collector 118 can receive a report of the packet from VM sensor 116, hypervisor sensor 116, and network device sensor 116.
Similarly, a packet sent by VM 110A to fabric 112 can be captured and reported by VM sensor 116. Since the packet sent by VM 110A will also flow through leaf router 104A and hypervisor 108A, it can also be captured and reported by hypervisor sensor 116 and network device sensor 116. Thus, for a packet sent by VM 110A to fabric 112, collector 118 can receive a report of the packet from VM sensor 116, hypervisor sensor 116, and network device sensor 116.
On the other hand, a packet originating at, or destined to, hypervisor 108A, will can be captured and reported by hypervisor sensor 116 and network device sensor 116, but not VM sensor 116, as such packet would not flow through VM 110A. Moreover, a packet originating at, or destined to, leaf router 104A, will be captured and reported by network device sensor 116, but not VM sensor 116, hypervisor sensor 116, or any other sensor on server 106A, as such packet would not flow through VM 110A, hypervisor 108A, or server 106A.
Each of the sensors 116 can include a respective unique sensor identifier on each of the reports 244 it sends to collector 118, to allow collector 118 to determine which sensor sent the report. The reports 244 used to analyze network and/or system data and conditions for troubleshooting, security, visualization, configuration, planning, and management. Sensor identifiers in the reports 244 can also be used to determine which sensors reported what flows. This information can then be used to determine sensor placement and topology, as further described below. Sensor placement and topology information can be useful for analyzing the data in the reports 244, as well as troubleshooting, security, visualization, configuration, planning, and management.
The visualization of the data collected from sensors 116 can be useful in the management and monitoring of a datacenter in which sensors 116 reside. However, with the large number of hosts within the datacenter, visualization of the data flows within the datacenter can be difficult to consume. As such, the data collected from sensors 116 that describe the data flows within the datacenter can be abstracted and displayed on an interactive hierarchical network chord diagram (or network chord diagram).
The data describing the data flows can describe the data flows between logical entities or endpoints of a data enter. A logical entity or endpoint can represent a host (e.g. server, switch, VM, hypervisor, router, etc.), cluster of hosts or one or more subnets. Furthermore data describing the data flows can also describe the attributes of each dataflow (e.g. a sending or originating host, a receiving or terminating host, a sending host subnet, a receiving host subnet and the one or more policies that correspond to the dataflow, etc.).
At step 306, the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) can group portions of data flows that originate at the same first endpoint and terminate the same second endpoint. The dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) can identify the originating endpoint and terminating endpoint of each data flow from the identified attributes of each data flow. For example, analytics engine 120 can identify the sending and receiving hosts of each dataflow and group of the data flows according to the same sending host and/or the same receiving host. In another example, analytics engine 120 can group portions of the data flows by the subnet of the sending host and/or the subnet of the receiving host.
Sub-groups can also be identified within each grouped portion of data flows. The dataflow monitor (e.g. collector 118 or analytics engine 120) can identify or determine sub-groups within each grouped portion. For example analytics engine 120 groups portions of data flows that all originate at a subnet and all terminate at another different subnet. Analytics engine 120 can also identify one or more subgroups within each subnet group. For example, analytics engine 120 can identify one or more clusters of hosts within each subnet group. Additionally, analytics engine 120 can identify the portions of data flows within the grouped portion of data flows that originate and/or terminate at the same cluster of hosts within each subnet group. The dataflow monitor system can identify as many different levels of abstraction as needed. For instance, continuing from the example above, analytics engine 120 can identify or group one or more sub-groups within each sub-group (e.g. on a host basis).
At step 308, the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) can then display a network chord diagram of the analyzed data describing the data flows on a user interface of a computing device (smart phone, laptop, desktop, etc.). Each cord displayed in the network chord diagram represents a grouped portion of bi-directional data flows that originate at the same first endpoint and terminate at the same second endpoint. Each chord in the network chord diagram can also represent one or more policies that are similarly enforced over each represented grouped portion of data flows. Each endpoint or any abstraction thereof visualized in the network chord diagram represents an endpoint that a grouped portion of data flows or an individual dataflow originates from or terminates at. In some embodiments each endpoint visualized in the network cord diagram represents one or more subnets. In some embodiments each endpoint visualized in the network cord diagram represents one or more clusters of hosts. In some embodiments each endpoint visualized in the network chord diagram represents an individual host.
An example of a network chord diagram is shown in
At step 310, the dataflow monitoring system determines whether a chord or either endpoint of a chord has been selected in the network chord diagram. If the dataflow monitoring system determines a chord or an endpoint of the chord have not been selected, then the dataflow monitoring system continues to display the interactive hierarchical network chord diagram. However, if the dataflow monitoring system determines a chord or either endpoint of the chord has been selected, then the method proceeds to step 312.
At step 312, the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) expands the grouped portion of data flows and corresponding endpoints. In some embodiments, selection of the chord causes the dataflow monitoring system to expand the grouped portion of data flows and/or either or both endpoints of the grouped portion of data flows. For example, selection of the chord causes analytics engine 120 to expand the represented grouped portion of data flows into sub-groupings of data flows. In another example, selection of the chord causes analytics engine 120 to expand one or both of the endpoints of the selected chord into sets of sub-endpoints. In another example, selection of the chord causes analytics engine 120 to expand the grouped portion of data flows into sub-groupings of data flows and one or both endpoints of the chords into sets of sub-endpoints.
In some embodiments, selection of an endpoint expands the network topology constructed using the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) to expand the represented endpoint or the corresponding grouped portion of data flows. The expansion of the represented endpoint is based on the identified attributes of each corresponding grouped portions of data flows. As such, selection of an endpoint can cause analytics engine 120 to expand the represented endpoint into a more granular representation of the network topology. Furthermore, in some embodiments, selection of an endpoint also causes analytics engine 120 to expand the corresponding grouped portion of data flows (either originating from or terminating at the represented endpoint) into sub-groupings of data flows. For example, the selected endpoint represents a subnet. As such the dataflow monitoring system identifies clusters of hosts within the subnet (from the attributes of the corresponding grouped portion of data flows) and expands the subnet into said clusters of hosts. In another example, the selected endpoint represents a cluster of hosts. As such, the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) identifies the individual hosts within the clusters of hosts (from the attributes of the corresponding grouped portion of data flows) and can expand the cluster of hosts into individual hosts.
In some embodiments, using the above described techniques, the selection of an endpoint causes the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) to expand the grouped portion of data flows that terminate at or originate from the represented endpoint.
In some embodiments, using the above described techniques, selection of any endpoint of a chord or the chord itself causes the dataflow monitoring system (e.g. analytics engine 120, collector 118, etc.) to expand the represented endpoint, the corresponding grouped portion of data flows and the corresponding chord(s) other endpoint(s).
At step 314, the dataflow monitoring system (analytics engine 120, collector 118, etc.) updates the displayed network chord diagram to include a set of sub-chords and the set of sub-endpoints. The sub-chords represent the sub-groupings of data flows that originate and/or terminate at the set of sub-endpoints. An example of the updated display of the network chord diagram is illustrated in
In some circumstances, the user (e.g. network operator) may want be informed of the previous level of abstraction while the current endpoint is expanded. For example, a representation of the previous level of abstraction can be included in the network chord diagram.
It should be noted that for sake of simplicity,
The network chord diagram can be further drilled down to as many levels of abstraction as needed. For example, using the above described techniques, the sub-endpoints can be further expanded into sub-sub-endpoints. The expansion of the sub-endpoints can be based on the identified attributes of the sub-groupings of data flows. For example, following
The interactive hierarchical network chord diagram (e.g. network chord diagram 402) can visualize the expansion of sub-endpoints. Following the previous example,
Again, the user (e.g. network operator) can be informed of the previous level of abstraction while the current level of abstraction is expanded (e.g. the expanded endpoint, sub-endpoint, sub-sub endpoint, sub-sub-sub endpoint, etc.). In fact a notifying representation can be displayed for any displayed level of abstraction. For example, a representation of the previous level of abstraction can be included in the network chord diagram.
The user-interface (UI) displaying the network chord diagram can also include navigation tools and other graphical representations that display additional information related to network chord diagram.
Display bar 456 can include multiple graphical representations to display additional information about the network overall or the network chord diagram itself (e.g. network chord diagram 402). For example, display bar 456 can display information about the different network zones (e.g. number and names of the different network zones within the network or network chord diagram 402), the policies enforced for each dataflow within the network or network chord diagram 402 (e.g. the number of policies, the name of each policy, details about what each policy is enforcing, etc.), the number of applications within the network, the clusters within the network or network chord diagram 402 (e.g. the names of each cluster, the number of clusters within the network, the logical entities that are within each cluster, etc.), the number of dataflows or conversations that are occurring between each endpoint within the network or network chord diagram 402, the number of endpoints within the network or network chord diagram 402, etc.).
Navigation bar (458A, 458B, 458C, 458D and 458E or collectively as 458) can include a number of tools to navigate the displayed network chord diagram (e.g. network chord diagram 402). For example, navigation bar 458 can include magnification tool 458A to zoom in and out of the network chord diagram. Navigation bar 458 can include a manual navigation tool 458B to filter down the chord chart by only showing selected subnets/hosts. Navigation bar 458 can include a remove filter tool 458C to undo a selection of a selected subnet/host by toll 458B. Navigation bar 458 can include a remove unselected host tool 458D which filters out all unselected subnets/hosts. Navigation bar 458 can also include a search bar button 458E that, if selected, can trigger the display of a search bar. Other tools are also possible, such as centering tools, chord selection tools, remove all filters tool, etc.
Example UI 456 can also include a search bar. In some circumstances, the user (e.g. a network operator) may know and specifically want to search for a particular logical entity within the network as represented by the displayed network chord diagram. In some embodiments, as illustrated in
In some embodiments table 462 is dynamically linked to chord chart 402. When an endpoints or clusters found in the search in table 462 is clicked on the chord chart 402 can dynamically highlight or expand such endpoints or clusters to call out the element being selected. This feature is very helpful to dig up a node or cluster from a chord chart filled with thousands of elements.
In some embodiments, selection of the chord or endpoint can trigger display of additional information, similar to table 462. For example, assume, as
In some embodiments, selection of a chord (including sub-chords, sub-sub chords or any level of abstraction of these chords) can also display a table similar to that of table 462. In such an embodiment, the selection of the chord triggers the display of information related to all corresponding endpoints. In some embodiments, the user can select a specific endpoint to only view additional data about the selected endpoint.
In other embodiments selection of an endpoint or chord (including all other iterations of abstracted levels of endpoints and chords) can collapse a previously selected and expanded endpoint and/or cord. Furthermore, selection of an endpoint and/or chord displays additional information for only the currently selected chord and/or endpoint. In other embodiments, the UI can display additional information for all the endpoints and/or chords selected by the user. The displayed additional information for all the endpoints and/or chords are removed only when specifically closed by the user.
The interfaces 568 are typically provided as interface cards (sometimes referred to as “line cards”). Generally, they control the sending and receiving of data packets over the network and sometimes support other peripherals used with the router 510. Among the interfaces that may be provided are Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, and the like. In addition, various very high-speed interfaces may be provided such as fast token ring interfaces, wireless interfaces, Ethernet interfaces, Gigabit Ethernet interfaces, ATM interfaces, HSSI interfaces, POS interfaces, FDDI interfaces and the like. Generally, these interfaces may include ports appropriate for communication with the appropriate media. In some cases, they may also include an independent processor and, in some instances, volatile RAM. The independent processors may control such communications intensive tasks as packet switching, media control and management. By providing separate processors for the communications intensive tasks, these interfaces allow the master microprocessor 562 to efficiently perform routing computations, network diagnostics, security functions, etc.
Although the system shown in
Regardless of the network device's configuration, it may employ one or more memories or memory modules (including memory 561) configured to store program instructions for the general-purpose network operations and mechanisms for roaming, route optimization and routing functions described herein. The program instructions may control the operation of an operating system and/or one or more applications, for example. The memory or memories may also be configured to store tables such as mobility binding, registration, and association tables, etc.
To enable user interaction with the computing device 600, an input device 645 can represent any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 635 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems can enable a user to provide multiple types of input to communicate with the computing device 600. The communications interface 640 can generally govern and manage the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed.
Storage device 630 is a non-volatile memory and can be a hard disk or other types of computer readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, solid state memory devices, digital versatile disks, cartridges, random access memories (RAMs) 675, read only memory (ROM) 680, and hybrids thereof.
The storage device 630 can include software modules 638, 634, 636 for controlling the processor 610. Other hardware or software modules are contemplated. The storage device 630 can be connected to the system bus 605. In one aspect, a hardware module that performs a particular function can include the software component stored in a computer-readable medium in connection with the necessary hardware components, such as the processor 610, bus 605, display 635, and so forth, to carry out the function.
Chipset 660 can also interface with one or more communication interfaces 690 that can have different physical interfaces. Such communication interfaces can include interfaces for wired and wireless local area networks, for broadband wireless networks, as well as personal area networks. Some applications of the methods for generating, displaying, and using the GUI disclosed herein can include receiving ordered datasets over the physical interface or be generated by the machine itself by processor 655 analyzing data stored in storage 670 or 675. Further, the machine can receive inputs from a user via user interface components 685 and execute appropriate functions, such as browsing functions by interpreting these inputs using processor 655. It can be appreciated that example systems 600 and 650 can have more than one processor 610 or be part of a group or cluster of computing devices networked together to provide greater processing capability.
For clarity of explanation, in some instances the present technology may be presented as including individual functional blocks including functional blocks comprising devices, device components, steps or routines in a method embodied in software, or combinations of hardware and software.
In some embodiments the computer-readable storage devices, mediums, and memories can include a cable or wireless signal containing a bit stream and the like. However, when mentioned, non-transitory computer-readable storage media expressly exclude media such as energy, carrier signals, electromagnetic waves, and signals per se.
Methods according to the above-described examples can be implemented using computer-executable instructions that are stored or otherwise available from computer readable media. Such instructions can comprise, for example, instructions and data which cause or otherwise configure a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Portions of computer resources used can be accessible over a network. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, firmware, or source code. Examples of computer-readable media that may be used to store instructions, information used, and/or information created during methods according to described examples include magnetic or optical disks, flash memory, USB devices provided with non-volatile memory, networked storage devices, and so on.
Devices implementing methods according to these disclosures can comprise hardware, firmware and/or software, and can take any of a variety of form factors. Typical examples of such form factors include laptops, smart phones, small form factor personal computers, personal digital assistants, rackmount devices, standalone devices, and so on. Functionality described herein also can be embodied in peripherals or add-in cards. Such functionality can also be implemented on a circuit board among different chips or different processes executing in a single device, by way of further example.
The instructions, media for conveying such instructions, computing resources for executing them, and other structures for supporting such computing resources are means for providing the functions described in these disclosures.
Although a variety of examples and other information was used to explain aspects within the scope of the appended claims, no limitation of the claims should be implied based on particular features or arrangements in such examples, as one of ordinary skill would be able to use these examples to derive a wide variety of implementations. Further and although some subject matter may have been described in language specific to examples of structural features and/or method steps, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to these described features or acts. For example, such functionality can be distributed differently or performed in components other than those identified herein. Rather, the described features and steps are disclosed as examples of components of systems and methods within the scope of the appended claims. Moreover, claim language reciting “at least one of” a set indicates that one member of the set or multiple members of the set satisfy the claim.
This application claims priority to U.S. Provisional Application No. 62/171,899, entitled “SYSTEM FOR MONITORING AND MANAGING DATACENTERS,” filed Jun. 5, 2015, which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5742829 | Davis et al. | Apr 1998 | A |
5903545 | Sabourin et al. | May 1999 | A |
6012096 | Link et al. | Jan 2000 | A |
6144962 | Weinberg et al. | Nov 2000 | A |
6247058 | Miller et al. | Jun 2001 | B1 |
6330562 | Boden et al. | Dec 2001 | B1 |
6525658 | Streetman et al. | Feb 2003 | B2 |
6611896 | Mason, Jr. et al. | Aug 2003 | B1 |
6728779 | Griffin et al. | Apr 2004 | B1 |
6801878 | Hintz et al. | Oct 2004 | B1 |
6847993 | Novaes et al. | Jan 2005 | B1 |
6925490 | Novaes et al. | Aug 2005 | B1 |
6958998 | Shorey | Oct 2005 | B2 |
6983323 | Cantrell et al. | Jan 2006 | B2 |
6996817 | Birum et al. | Feb 2006 | B2 |
7002464 | Bruemmer et al. | Feb 2006 | B2 |
7120934 | Ishikawa | Oct 2006 | B2 |
7181769 | Keanini et al. | Feb 2007 | B1 |
7185103 | Jain | Feb 2007 | B1 |
7337206 | Wen et al. | Feb 2008 | B1 |
7353511 | Ziese | Apr 2008 | B1 |
7370092 | Aderton et al. | May 2008 | B2 |
7395195 | Suenbuel et al. | Jul 2008 | B2 |
7444404 | Wetherall et al. | Oct 2008 | B2 |
7466681 | Ashwood-Smith et al. | Dec 2008 | B2 |
7467205 | Dempster et al. | Dec 2008 | B1 |
7496040 | Seo | Feb 2009 | B2 |
7496575 | Buccella et al. | Feb 2009 | B2 |
7530105 | Gilbert et al. | May 2009 | B2 |
7610330 | Quinn et al. | Oct 2009 | B1 |
7633942 | Bearden et al. | Dec 2009 | B2 |
7676570 | Levy et al. | Mar 2010 | B2 |
7681131 | Quarterman et al. | Mar 2010 | B1 |
7693947 | Judge et al. | Apr 2010 | B2 |
7752307 | Takara | Jul 2010 | B2 |
7783457 | Cunningham | Aug 2010 | B2 |
7844696 | Labovitz et al. | Nov 2010 | B2 |
7844744 | Abercrombie et al. | Nov 2010 | B2 |
7864707 | Dimitropoulos et al. | Jan 2011 | B2 |
7873025 | Patel et al. | Jan 2011 | B2 |
7874001 | Beck et al. | Jan 2011 | B2 |
7885197 | Metzler | Feb 2011 | B2 |
7895649 | Brook et al. | Feb 2011 | B1 |
7904420 | Ianni | Mar 2011 | B2 |
7930752 | Hertzog et al. | Apr 2011 | B2 |
7934248 | Yehuda et al. | Apr 2011 | B1 |
7957934 | Greifeneder | Jun 2011 | B2 |
7961637 | McBeath | Jun 2011 | B2 |
7970946 | Djabarov et al. | Jun 2011 | B1 |
7975035 | Popescu et al. | Jul 2011 | B2 |
8005935 | Pradhan et al. | Aug 2011 | B2 |
8040232 | Oh et al. | Oct 2011 | B2 |
8040822 | Proulx et al. | Oct 2011 | B2 |
8135657 | Kapoor et al. | Mar 2012 | B2 |
8156430 | Newman | Apr 2012 | B2 |
8185824 | Mitchell et al. | May 2012 | B1 |
8250657 | Nachenberg et al. | Aug 2012 | B1 |
8255972 | Azagury et al. | Aug 2012 | B2 |
8266697 | Coffman | Sep 2012 | B2 |
8281397 | Vaidyanathan et al. | Oct 2012 | B2 |
8291495 | Burns et al. | Oct 2012 | B1 |
8296847 | Mendonca et al. | Oct 2012 | B2 |
8370407 | Devarajan et al. | Feb 2013 | B1 |
8381289 | Pereira et al. | Feb 2013 | B1 |
8391270 | Van Der Stok et al. | Mar 2013 | B2 |
8407164 | Malik et al. | Mar 2013 | B2 |
8442073 | Skubacz et al. | May 2013 | B2 |
8451731 | Lee et al. | May 2013 | B1 |
8462212 | Kundu et al. | Jun 2013 | B1 |
8489765 | Vasseur et al. | Jul 2013 | B2 |
8516590 | Ranadive et al. | Aug 2013 | B1 |
8527977 | Cheng et al. | Sep 2013 | B1 |
8570861 | Brandwine et al. | Oct 2013 | B1 |
8572600 | Chung et al. | Oct 2013 | B2 |
8572734 | McConnell et al. | Oct 2013 | B2 |
8572735 | Ghosh et al. | Oct 2013 | B2 |
8588081 | Salam et al. | Nov 2013 | B2 |
8600726 | Varshney et al. | Dec 2013 | B1 |
8630316 | Haba | Jan 2014 | B2 |
8640086 | Bonev et al. | Jan 2014 | B2 |
8661544 | Yen et al. | Feb 2014 | B2 |
8677487 | Balupari et al. | Mar 2014 | B2 |
8683389 | Bar-Yam et al. | Mar 2014 | B1 |
8706914 | Duchesneau | Apr 2014 | B2 |
8719452 | Ding et al. | May 2014 | B1 |
8719835 | Kanso et al. | May 2014 | B2 |
8752042 | Ratica | Jun 2014 | B2 |
8755396 | Sindhu et al. | Jun 2014 | B2 |
8762951 | Kosche et al. | Jun 2014 | B1 |
8769084 | Westerfeld et al. | Jul 2014 | B2 |
8776180 | Kumar et al. | Jul 2014 | B2 |
8812725 | Kulkarni | Aug 2014 | B2 |
8813236 | Saha et al. | Aug 2014 | B1 |
8825848 | Dotan et al. | Sep 2014 | B1 |
8832013 | Adams et al. | Sep 2014 | B1 |
8832461 | Saroiu et al. | Sep 2014 | B2 |
8849926 | Marzencki et al. | Sep 2014 | B2 |
8881258 | Paul et al. | Nov 2014 | B2 |
8887238 | Howard et al. | Nov 2014 | B2 |
8904520 | Nachenberg et al. | Dec 2014 | B1 |
8931043 | Cooper et al. | Jan 2015 | B2 |
8954610 | Berke et al. | Feb 2015 | B2 |
8973147 | Pearcy et al. | Mar 2015 | B2 |
8990386 | He et al. | Mar 2015 | B2 |
8996695 | Anderson et al. | Mar 2015 | B2 |
8997227 | Mhatre et al. | Mar 2015 | B1 |
9015716 | Fletcher et al. | Apr 2015 | B2 |
9071575 | Lemaster et al. | Jun 2015 | B2 |
9088598 | Zhang et al. | Jul 2015 | B1 |
9110905 | Polley et al. | Aug 2015 | B2 |
9160764 | Stiansen et al. | Oct 2015 | B2 |
9178906 | Chen et al. | Nov 2015 | B1 |
9197654 | Ben-Shalom et al. | Nov 2015 | B2 |
9225793 | Dutta et al. | Dec 2015 | B2 |
9237111 | Banavalikar et al. | Jan 2016 | B2 |
9246773 | Degioanni | Jan 2016 | B2 |
9258217 | Duffield et al. | Feb 2016 | B2 |
9281940 | Matsuda et al. | Mar 2016 | B2 |
9317574 | Brisebois | Apr 2016 | B1 |
9319384 | Yan et al. | Apr 2016 | B2 |
9405903 | Xie et al. | Aug 2016 | B1 |
9418222 | Rivera et al. | Aug 2016 | B1 |
9454324 | Madhavapeddi | Sep 2016 | B1 |
9501744 | Brisebois | Nov 2016 | B1 |
9634915 | Bley | Apr 2017 | B2 |
9645892 | Patwardhan | May 2017 | B1 |
9733973 | Prasad et al. | Aug 2017 | B2 |
20020053033 | Cooper et al. | May 2002 | A1 |
20020103793 | Koller et al. | Aug 2002 | A1 |
20020141343 | Bays | Oct 2002 | A1 |
20020184393 | Leddy et al. | Dec 2002 | A1 |
20030097439 | Strayer et al. | May 2003 | A1 |
20030145232 | Poletto et al. | Jul 2003 | A1 |
20030154399 | Zuk et al. | Aug 2003 | A1 |
20040030776 | Cantrell et al. | Feb 2004 | A1 |
20040268149 | Aaron | Dec 2004 | A1 |
20050039104 | Shah et al. | Feb 2005 | A1 |
20050166066 | Ahuja et al. | Jul 2005 | A1 |
20050207376 | Ashwood-Smith et al. | Sep 2005 | A1 |
20050257244 | Joly et al. | Nov 2005 | A1 |
20050289244 | Sahu et al. | Dec 2005 | A1 |
20060048218 | Lingafelt et al. | Mar 2006 | A1 |
20060080733 | Khosmood et al. | Apr 2006 | A1 |
20060095968 | Portolani et al. | May 2006 | A1 |
20060156408 | Himberger et al. | Jul 2006 | A1 |
20060195448 | Newport | Aug 2006 | A1 |
20060272018 | Fouant | Nov 2006 | A1 |
20060274659 | Ouderkirk | Dec 2006 | A1 |
20060294219 | Ogawa et al. | Dec 2006 | A1 |
20070044147 | Choi et al. | Feb 2007 | A1 |
20070097976 | Wood et al. | May 2007 | A1 |
20070169179 | Narad | Jul 2007 | A1 |
20070195729 | Li et al. | Aug 2007 | A1 |
20070195797 | Patel et al. | Aug 2007 | A1 |
20070211637 | Mitchell | Sep 2007 | A1 |
20070300061 | Kim et al. | Dec 2007 | A1 |
20080022385 | Crowell et al. | Jan 2008 | A1 |
20080082662 | Danliker et al. | Apr 2008 | A1 |
20080101234 | Nakil et al. | May 2008 | A1 |
20080126534 | Mueller | May 2008 | A1 |
20080250122 | Zsigmond et al. | Oct 2008 | A1 |
20080270199 | Chess et al. | Oct 2008 | A1 |
20080301765 | Nicol et al. | Dec 2008 | A1 |
20090064332 | Porras et al. | Mar 2009 | A1 |
20090241170 | Kumar, Sr. et al. | Sep 2009 | A1 |
20090307753 | Dupont et al. | Dec 2009 | A1 |
20090313373 | Hanna et al. | Dec 2009 | A1 |
20090313698 | Wahl | Dec 2009 | A1 |
20090328219 | Narayanaswamy | Dec 2009 | A1 |
20100005288 | Rao et al. | Jan 2010 | A1 |
20100077445 | Schneider et al. | Mar 2010 | A1 |
20100095293 | O'Neill et al. | Apr 2010 | A1 |
20100095367 | Narayanaswamy | Apr 2010 | A1 |
20100138810 | Komatsu et al. | Jun 2010 | A1 |
20100148940 | Gelvin et al. | Jun 2010 | A1 |
20100153316 | Duffield et al. | Jun 2010 | A1 |
20100153696 | Beachem et al. | Jun 2010 | A1 |
20100220584 | DeHaan et al. | Sep 2010 | A1 |
20100235514 | Beachem | Sep 2010 | A1 |
20100235915 | Memon et al. | Sep 2010 | A1 |
20100303240 | Beachem | Dec 2010 | A1 |
20100319060 | Aiken et al. | Dec 2010 | A1 |
20110010585 | Bugenhagen et al. | Jan 2011 | A1 |
20110055381 | Narasimhan et al. | Mar 2011 | A1 |
20110055388 | Yumerefendi et al. | Mar 2011 | A1 |
20110066719 | Miryanov et al. | Mar 2011 | A1 |
20110069685 | Tofighbakhsh | Mar 2011 | A1 |
20110083125 | Komatsu et al. | Apr 2011 | A1 |
20110126275 | Anderson et al. | May 2011 | A1 |
20110145885 | Rivers et al. | Jun 2011 | A1 |
20110170860 | Smith et al. | Jul 2011 | A1 |
20110173490 | Narayanaswamy et al. | Jul 2011 | A1 |
20110185423 | Sallam | Jul 2011 | A1 |
20110196957 | Ayachitula et al. | Aug 2011 | A1 |
20110202655 | Sharma et al. | Aug 2011 | A1 |
20110225207 | Subramanian et al. | Sep 2011 | A1 |
20110228696 | Agarwal et al. | Sep 2011 | A1 |
20110302652 | Westerfeld | Dec 2011 | A1 |
20110314148 | Petersen et al. | Dec 2011 | A1 |
20120005542 | Petersen et al. | Jan 2012 | A1 |
20120079592 | Pandrangi | Mar 2012 | A1 |
20120102361 | Sass et al. | Apr 2012 | A1 |
20120102543 | Kohli et al. | Apr 2012 | A1 |
20120117226 | Tanaka et al. | May 2012 | A1 |
20120136996 | Seo et al. | May 2012 | A1 |
20120137278 | Draper et al. | May 2012 | A1 |
20120140626 | Anand et al. | Jun 2012 | A1 |
20120197856 | Banka et al. | Aug 2012 | A1 |
20120198541 | Reeves | Aug 2012 | A1 |
20120216271 | Cooper et al. | Aug 2012 | A1 |
20120233473 | Vasseur et al. | Sep 2012 | A1 |
20120240232 | Azuma | Sep 2012 | A1 |
20120246303 | Petersen et al. | Sep 2012 | A1 |
20120278021 | Lin et al. | Nov 2012 | A1 |
20130003538 | Greenburg et al. | Jan 2013 | A1 |
20130006935 | Grisby | Jan 2013 | A1 |
20130038358 | Cook et al. | Feb 2013 | A1 |
20130086272 | Chen et al. | Apr 2013 | A1 |
20130103827 | Dunlap et al. | Apr 2013 | A1 |
20130145099 | Liu et al. | Jun 2013 | A1 |
20130159999 | Chiueh et al. | Jun 2013 | A1 |
20130179487 | Lubetzky et al. | Jul 2013 | A1 |
20130179879 | Zhang et al. | Jul 2013 | A1 |
20130198839 | Wei et al. | Aug 2013 | A1 |
20130246925 | Ahuja et al. | Sep 2013 | A1 |
20130247201 | Alperovitch et al. | Sep 2013 | A1 |
20130254879 | Chesla et al. | Sep 2013 | A1 |
20130268994 | Cooper et al. | Oct 2013 | A1 |
20130275579 | Hernandez et al. | Oct 2013 | A1 |
20130283374 | Zisapel et al. | Oct 2013 | A1 |
20130290521 | Labovitz | Oct 2013 | A1 |
20130297771 | Osterloh et al. | Nov 2013 | A1 |
20130304900 | Trabelsi et al. | Nov 2013 | A1 |
20130305369 | Karta et al. | Nov 2013 | A1 |
20130318357 | Abraham et al. | Nov 2013 | A1 |
20130326623 | Kruglick | Dec 2013 | A1 |
20130333029 | Chesla et al. | Dec 2013 | A1 |
20130347103 | Veteikis et al. | Dec 2013 | A1 |
20140006610 | Formby et al. | Jan 2014 | A1 |
20140006871 | Lakshmanan et al. | Jan 2014 | A1 |
20140012814 | Bercovici et al. | Jan 2014 | A1 |
20140033193 | Palaniappan | Jan 2014 | A1 |
20140047185 | Peterson et al. | Feb 2014 | A1 |
20140047372 | Gnezdov et al. | Feb 2014 | A1 |
20140059200 | Nguyen et al. | Feb 2014 | A1 |
20140089494 | Dasari et al. | Mar 2014 | A1 |
20140096058 | Molesky et al. | Apr 2014 | A1 |
20140115219 | Ajanovic et al. | Apr 2014 | A1 |
20140143825 | Behrendt et al. | May 2014 | A1 |
20140149490 | Luxenberg et al. | May 2014 | A1 |
20140156814 | Barabash et al. | Jun 2014 | A1 |
20140164607 | Bai et al. | Jun 2014 | A1 |
20140173623 | Chang et al. | Jun 2014 | A1 |
20140192639 | Smirnov | Jul 2014 | A1 |
20140201717 | Mascaro | Jul 2014 | A1 |
20140215573 | Cepuran | Jul 2014 | A1 |
20140215621 | Xaypanya et al. | Jul 2014 | A1 |
20140281030 | Cui et al. | Sep 2014 | A1 |
20140289854 | Mahvi | Sep 2014 | A1 |
20140298461 | Hohndel et al. | Oct 2014 | A1 |
20140317737 | Shin et al. | Oct 2014 | A1 |
20140331276 | Frascadore et al. | Nov 2014 | A1 |
20140331280 | Porras et al. | Nov 2014 | A1 |
20140331304 | Wong | Nov 2014 | A1 |
20140351203 | Kunnatur et al. | Nov 2014 | A1 |
20140351415 | Harrigan et al. | Nov 2014 | A1 |
20140359695 | Chari et al. | Dec 2014 | A1 |
20150009840 | Pruthi et al. | Jan 2015 | A1 |
20150033305 | Shear et al. | Jan 2015 | A1 |
20150036533 | Sodhi et al. | Feb 2015 | A1 |
20150039751 | Harrigan et al. | Feb 2015 | A1 |
20150046882 | Menyhart et al. | Feb 2015 | A1 |
20150058976 | Carney et al. | Feb 2015 | A1 |
20150067143 | Babakhan et al. | Mar 2015 | A1 |
20150082151 | Liang et al. | Mar 2015 | A1 |
20150085665 | Kompella et al. | Mar 2015 | A1 |
20150095332 | Beisiegel et al. | Apr 2015 | A1 |
20150112933 | Satapathy | Apr 2015 | A1 |
20150113133 | Srinivas et al. | Apr 2015 | A1 |
20150124608 | Agarwal et al. | May 2015 | A1 |
20150138993 | Forster et al. | May 2015 | A1 |
20150142962 | Srinivas et al. | May 2015 | A1 |
20150195291 | Zuk et al. | Jul 2015 | A1 |
20150249622 | Phillips et al. | Sep 2015 | A1 |
20150256555 | Choi et al. | Sep 2015 | A1 |
20150261842 | Huang et al. | Sep 2015 | A1 |
20150261886 | Wu et al. | Sep 2015 | A1 |
20150271255 | Mackay et al. | Sep 2015 | A1 |
20150295945 | Canzanese, Jr. et al. | Oct 2015 | A1 |
20150347554 | Vasantham et al. | Dec 2015 | A1 |
20150358352 | Chasin et al. | Dec 2015 | A1 |
20160006753 | McDaid et al. | Jan 2016 | A1 |
20160021131 | Heilig | Jan 2016 | A1 |
20160026552 | Holden et al. | Jan 2016 | A1 |
20160036837 | Jain et al. | Feb 2016 | A1 |
20160050132 | Zhang et al. | Feb 2016 | A1 |
20160072815 | Rieke et al. | Mar 2016 | A1 |
20160103692 | Guntaka et al. | Apr 2016 | A1 |
20160105350 | Greifeneder et al. | Apr 2016 | A1 |
20160119234 | Valencia Lopez et al. | Apr 2016 | A1 |
20160127395 | Underwood et al. | May 2016 | A1 |
20160147585 | Konig et al. | May 2016 | A1 |
20160162308 | Chen et al. | Jun 2016 | A1 |
20160162312 | Doherty et al. | Jun 2016 | A1 |
20160205002 | Rieke et al. | Jul 2016 | A1 |
20160216994 | Sefidcon et al. | Jul 2016 | A1 |
20160294691 | Joshi | Oct 2016 | A1 |
20160308908 | Kirby et al. | Oct 2016 | A1 |
20160357424 | Pang et al. | Dec 2016 | A1 |
20160357546 | Chang et al. | Dec 2016 | A1 |
20160357587 | Yadav et al. | Dec 2016 | A1 |
20160357957 | Deen et al. | Dec 2016 | A1 |
20160359592 | Kulshreshtha et al. | Dec 2016 | A1 |
20160359628 | Singh et al. | Dec 2016 | A1 |
20160359658 | Yadav et al. | Dec 2016 | A1 |
20160359673 | Gupta et al. | Dec 2016 | A1 |
20160359677 | Kulshreshtha et al. | Dec 2016 | A1 |
20160359678 | Madani et al. | Dec 2016 | A1 |
20160359679 | Parasdehgheibi et al. | Dec 2016 | A1 |
20160359680 | Parasdehgheibi et al. | Dec 2016 | A1 |
20160359686 | Parasdehgheibi et al. | Dec 2016 | A1 |
20160359696 | Yadav et al. | Dec 2016 | A1 |
20160359697 | Scheib et al. | Dec 2016 | A1 |
20160359698 | Deen et al. | Dec 2016 | A1 |
20160359699 | Gandham et al. | Dec 2016 | A1 |
20160359701 | Pang et al. | Dec 2016 | A1 |
20160359703 | Gandham et al. | Dec 2016 | A1 |
20160359704 | Gandham et al. | Dec 2016 | A1 |
20160359705 | Parasdehgheibi et al. | Dec 2016 | A1 |
20160359708 | Gandham et al. | Dec 2016 | A1 |
20160359709 | Deen et al. | Dec 2016 | A1 |
20160359711 | Deen et al. | Dec 2016 | A1 |
20160359712 | Alizadeh Attar et al. | Dec 2016 | A1 |
20160359740 | Parasdehgheibi et al. | Dec 2016 | A1 |
20160359759 | Singh et al. | Dec 2016 | A1 |
20160359872 | Yadav et al. | Dec 2016 | A1 |
20160359877 | Kulshreshtha et al. | Dec 2016 | A1 |
20160359878 | Prasad et al. | Dec 2016 | A1 |
20160359879 | Deen et al. | Dec 2016 | A1 |
20160359880 | Pang et al. | Dec 2016 | A1 |
20160359881 | Yadav et al. | Dec 2016 | A1 |
20160359888 | Gupta et al. | Dec 2016 | A1 |
20160359889 | Yadav et al. | Dec 2016 | A1 |
20160359890 | Deen et al. | Dec 2016 | A1 |
20160359891 | Pang et al. | Dec 2016 | A1 |
20160359897 | Yadav et al. | Dec 2016 | A1 |
20160359912 | Gupta et al. | Dec 2016 | A1 |
20160359913 | Gupta et al. | Dec 2016 | A1 |
20160359914 | Deen et al. | Dec 2016 | A1 |
20160359915 | Gupta et al. | Dec 2016 | A1 |
20160359917 | Rao et al. | Dec 2016 | A1 |
20160373481 | Sultan et al. | Dec 2016 | A1 |
20170034018 | Parasdehgheibi et al. | Feb 2017 | A1 |
20180006911 | Dickey | Jan 2018 | A1 |
Number | Date | Country |
---|---|---|
101093452 | Dec 2007 | CN |
101770551 | Jul 2010 | CN |
102521537 | Jun 2012 | CN |
103023970 | Apr 2013 | CN |
103716137 | Apr 2014 | CN |
104065518 | Sep 2014 | CN |
0811942 | Dec 1997 | EP |
1383261 | Jan 2004 | EP |
1450511 | Aug 2004 | EP |
2045974 | Apr 2008 | EP |
2887595 | Jun 2015 | EP |
2009-016906 | Jan 2009 | JP |
1394338 | May 2014 | KR |
WO 2007014314 | Feb 2007 | WO |
2007070711 | Jun 2007 | WO |
WO 2008069439 | Jun 2008 | WO |
WO 2013030830 | Mar 2013 | WO |
2007042171 | Mar 2015 | WO |
WO 2016004075 | Jan 2016 | WO |
WO 2016019523 | Feb 2016 | WO |
Entry |
---|
International Search Report and Written Opinion dated Aug. 17, 2016 for corresponding PCT Application No. PCT/US2016/035350. |
Australian Government Department of Defence, Intelligence and Security, “Top 4 Strategies to Mitigate Targeted Cyber Intrusions,” Cyber Security Operations Centre Jul. 2013, http://www.asd.gov.au/infosec/top-mitigations/top-4-strategies-explained.htm. |
Author Unknown, “Blacklists & Dynamic Reputation: Understanding Why the Evolving Threat Eludes Blacklists,” www.dambala.com, 9 pages, Dambala, Atlanta, GA, USA. |
Aydin, Galip, et al., “Architecture and Implementation of a Scalable Sensor Data Storage and Analysis Using Cloud Computing and Big Data Technologies,” Journal of Sensors, vol. 2015, Article ID 834217, Feb. 2015, 11 pages. |
Backes, Michael, et al., “Data Lineage in Malicious Environments,” IEEE 2015, pp. 1-13. |
Bayati, Mohsen, et al., “Message-Passing Algorithms for Sparse Network Alignment,” Mar. 2013, 31 pages. |
Berezinski, Przemyslaw, et al., “An Entropy-Based Network Anomaly Detection Method,” Entropy, 2015, vol. 17, www.mdpi.com/joumal/entropy, pp. 2367-2408. |
Berthier, Robin, et al. “Nfsight: Netflow-based Network Awareness Tool,” 2010, 16 pages. |
Bhuyan, Dhiraj, “Fighting Bots and Botnets,” 2006, pp. 23-28. |
Blair, Dana, et al., U.S. Appl. No. 62/106,006, tiled Jan. 21, 2015, entitled “Monitoring Network Policy Compliance.” |
Chandran, Midhun, et al., “Monitoring in a Virtualized Environment,” GSTF International Journal on Computing, vol. 1, No. 1, Aug. 2010. |
Chari, Suresh, et al., “Ensuring continuous compliance through reconciling policy with usage,” Proceedings of the 18th ACM symposium on Access control models and technologies (SACMAT '13). ACM, New York, NY, USA, 49-60. |
Chen, Xu, et al., “Automating network application dependency discovery: experiences, limitations, and new solutions,” 8th USENIX conference on Operating systems design and implementation (OSDI'08), USENIX Association, Berkeley, CA, USA, 117-130. |
Cisco Systems, “Cisco Network Analysis Modules (NAM) Tutorial,” Cisco Systems, Inc., Version 3.5. |
Cisco Systems, Inc., “Addressing Compliance from One Infrastructure: Cisco Unified Compliance Solution Framework,” 2014. |
Cisco Systems, Inc., “Cisco Application Dependency Mapping Service,” 2009. |
Cisco Systems, Inc., “White Paper—New Cisco Technologies Help Customers Achieve Regulatory Compliance,” 1992-2008. |
Cisco Systems, Inc., “A Cisco Guide to Defending Against Distributed Denial of Service Attacks,” May 3, 2016, 34 pages. |
Cisco Technology, Inc., “Cisco Lock-and-Key:Dynamic Access Lists,” http://www/cisco.com/c/en/us/support/docs/security-vpn/lock-key/7604-13.html; Updated Jul. 12, 2006, 16 pages. |
Feinstein, Laura, et al., “Statistical Approaches to DDoS Attack Detection and Response,” Proceedings of the DARPA Information Survivability Conference and Exposition (DISCEX '03), Apr. 2003, 12 pages. |
George, Ashley, et al., “NetPal: A Dynamic Network Administration Knowledge Base,” 2008, pp. 1-14. |
Goldsteen, Abigail, et al., “A Tool for Monitoring and Maintaining System Trustworthiness at Run Time,” REFSQ (2015), pp. 142-147. |
Hamadi, S., et al., “Fast Path Acceleration for Open vSwitch in Overlay Networks,” Global Information Infrastructure and Networking Symposium (GIIS), Montreal, QC, pp. 1-5, Sep. 15-19, 2014. |
Hewlett-Packard, “Effective use of reputation intelligence in a security operations center,” Jul. 2013, 6 pages. |
Hideshima, Yusuke, et al., “STARMINE: A Visualization System for Cyber Attacks,” https://www.researchgate.net/publication/221536306, Feb. 2006, 9 pages. |
InternetPerils, Inc., “Control Your Internet Business Risk,” 2003-2015, https://www.internetperils.com. |
Janoff, Christian, et al., “Cisco Compliance Solution for HIPAA Security Rule Design and Implementation Guide,” Cisco Systems, Inc., Updated Nov. 14, 2015, part 1 of 2, 350 pages. |
Janoff, Christian, et al., “Cisco Compliance Solution for HIPAA Security Rule Design and Implementation Guide,” Cisco Systems, Inc., Updated Nov. 14, 2015, part 2 of 2, 588 pages. |
Kerrison, Adam, et al., “Four Steps to Faster, Better Application Dependency Mapping—Laying the Foundation for Effective Business Service Models,” BMCSoftware, 2011. |
Kraemer, Brian, “Get to know your data center with CMDB,” TechTarget, Apr. 5, 2006, http://searchdatacenter.techtarget.com/news/118820/Get-to-know-your-data-center-with-CMDB. |
Lab SKU, “VMware Hands-on Labs—HOL-SDC-1301” Version: 20140321-160709, 2013; http://docs.hol.vmware.com/HOL-2013/holsdc-1301_html_en/ (part 1 of 2). |
Lab SKU, “VMware Hands-on Labs—HOL-SDC-1301” Version: 20140321-160709, 2013; http://docs.hol.vmware.com/HOL-2013/holsdc-1301_html_en/ (part 2 of 2). |
Lachance, Michael, “Dirty Little Secrets of Application Dependency Mapping,” Dec. 26, 2007. |
Lee, Sihyung, “Reducing Complexity of Large-Scale Network Configuration Management,” Ph.D. Dissertation, Carniege Mellon University, 2010. |
Li, Ang, et al., “Fast Anomaly Detection for Large Data Centers,” Global Telecommunications Conference (GLOBECOM 2010, Dec. 2010, 6 pages. |
Li, Bingbong, et al, “A Supervised Machine Learning Approach to Classify Host Roles on Line Using sFlow,” in Proceedings of the first edition workshop on High performance and programmable networking, 2013, ACM, New York, NY, USA, 53-60. |
Liu, Ting, et al., “Impala: A Middleware System for Managing Autonomic, Parallel Sensor Systems,” In Proceedings of the Ninth ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming(PPoPP '03), ACM, New York, NY, USA, Jun. 11-13, 2003, pp. 107-118. |
Lu, Zhonghai, et al., “Cluster-based Simulated Annealing for Mapping Cores onto 2D Mesh Networks on Chip,” Design and Diagnostics of Electronic Circuits and Systems, pp. 1, 6, Apr. 16-18, 2008. |
Matteson, Ryan, “Depmap: Dependency Mapping of Applications Using Operating System Events: a Thesis,” Master's Thesis, California Polytechnic State University, Dec. 2010. |
Natarajan, Arun, et al., “NSDMiner: Automated Discovery of Network Service Dependencies,” Institute of Electrical and Electronics Engineers INFOCOM, Feb. 2012, 9 pages. |
Navaz, A.S. Syed, et al., “Entropy based Anomaly Detection System to Prevent DDoS Attacks in Cloud,” International Journal of computer Applications (0975-8887), vol. 62, No. 15, Jan. 2013, pp. 42-47. |
Nilsson, Dennis K., et al., “Key Management and Secure Software Updates in Wireless Process Control Environments,” In Proceedings of the First ACM Conference on Wireless Network Security (WiSec '08), ACM, New York, NY, USA, Mar. 31-Apr. 2, 2008, pp. 100-108. |
Nunnally, Troy, et al., “P3D: A Parallel 3D Coordinate Visualization for Advanced Network Scans,” IEEE 2013, Jun. 9-13, 2013, 6 pages. |
O'Donnell, Glenn, et al., “The CMDB Imperative: How to Realize the Dream and Avoid the Nightmares,” Prentice Hall, Feb. 19, 2009. |
Ohta, Kohei, et al., “Detection, Defense, and Tracking of Internet-Wide Illegal Access in a Distributed Manner,” 2000, pp. 1-16. |
Pathway Systems International Inc., “How Blueprints does Integration,” Apr. 15, 2014, 9 pages, http://pathwaysystems.com/company-blog/. |
Pathway Systems International Inc., “What is Blueprints?” 2010-2016, http://pathwaysystems.com/blueprints-about/. |
Popa, Lucian, et al., “Macroscope: End-Point Approach to Networked Application Dependency Discovery,” CoNEXT'09, Dec. 1-4, 2009, Rome, Italy, 12 pages. |
Prasad, K. Munivara, et al., “An Efficient Detection of Flooding Attacks to Internet Threat Monitors (ITM) using Entropy Variations under Low Traffic,” Computing Communication & Networking Technologies (ICCCNT '12), Jul. 26-28, 2012, 11 pages. |
Sachan, Mrinmaya, et al., “Solving Electrical Networks to incorporate Supervision in Random Walks,” May 13-17, 2013, pp. 109-110. |
Sammarco, Matteo, et al., “Trace Selection for Improved WLAN Monitoring,” Aug. 16, 2013, pp. 9-14. |
Shneiderman, Ben, et al., “Network Visualization by Semantic Substrates,” Visualization and Computer Graphics, vol. 12, No. 5, pp. 733,740, Sep.-Oct. 2006. |
Wang, Ru, et al., “Learning directed acyclic graphs via bootstarp aggregating,” 2014, 47 pages, http://arxiv.org/abs/1406.2098. |
Wang, Yongjun, et al., “A Network Gene-Based Framework for Detecting Advanced Persistent Threats,” Nov. 2014, 7 pages. |
Woodberg, Brad, “Snippet from Juniper SRX Series” Jun. 17, 2013, 1 page, O'Reilly Media, Inc. |
Zhang, Yue, et al., “CANTINA: A Content-Based Approach to Detecting Phishing Web Sites,” May 8-12, 2007, pp. 639-648. |
Bosch, Greg, “Virtualization,” 2010, 33 pages. |
Breen, Christopher, “MAC 911, How to dismiss Mac App Store Notifications,” Macworld.com, Mar. 24, 2014, 3 pages. |
Chou, C.W., et al., “Optical Clocks and Relativity,” Science vol. 329, Sep. 24, 2010, pp. 1630-1633. |
Huang, Hing-Jie, et al., “Clock Skew Based Node Identification in Wireless Sensor Networks,” IEEE, 2008, 5 pages. |
Ives, Herbert, E., et al., “An Experimental Study of the Rate of a Moving Atomic Clock,” Journal of the Optical Society of America, vol. 28, No. 7, Jul. 1938, pp. 215-226. |
Witze, Alexandra, “Special relativity aces time trial, ‘Time dilation’ predicted by Einstein confirmed by lithium ion experiment,” Nature, Sep. 19, 2014, 3 pages. |
Zatrochova, Zuzana, “Analysis and Testing of Distributed NoSQL Datastore Riak,” Spring, 2015, 76 pages. |
JFrog, “Dependency Analyzer,” Feb. 14, 2008, http://www.jfrog.com/confluence/display/DA/Home. |
Neverfail, “Neverfail IT Continuity Architect,” 2015, https://web.archive.org/web/20150908090456/http://www.neverfailgroup.com/products/it-continuity-architect. |
Di Lorenzo, G. et al., “EXSED: An Intelligent Tool for Exploration of Social Events Dynamics from Augmented Trajectories,” Mobile Data Management (MDM), 2013 IEEE 14th International Conference on , vol. 1, No., pp. 323,330, Jun. 3-6, 2013. |
Bauch, Petr, “Reader's Report of Master's Thesis, Analysis and Testing of Distributed NoSQL Datastore Riak,” May 28, 2015, Brno. 2 pages. |
Heckman, Sarah, et al., “On Establishing a Benchmark for Evaluating Static Analysis Alert Prioritization and Classification Techniques,” IEEE, 2008; 10 pages. |
Kim, Myung-Sup, et al. “A Flow-based Method for Abnormal Network Traffic Detection, ” IEEE, 2004, pp. 599-612. |
Thomas, R., “Bogon Dotted Decimal List,” Version 7.0, Team Cymru NOC, Apr. 27, 2012, 5 pages. |
Number | Date | Country | |
---|---|---|---|
20160359700 A1 | Dec 2016 | US |
Number | Date | Country | |
---|---|---|---|
62171899 | Jun 2015 | US |