Software-defined data centers (SDDCs) in theory provide large amounts of data that can be used for many different applications. However, in practice, the data is fragmented and difficult for users to analyze. A solution is required to provide an infrastructure for providing a platform that can be accessed to perform analytics and to visualize the security posture of a SDDC.
Some embodiments provide a novel method for collecting and reporting attributes of data flows associated with machines executing on a plurality of host computers. In some embodiments, the machines are associated with a logical network implemented by a virtualization manager (e.g., VMware™ NSX manager). The logical network, in some embodiments, is implemented as an overlay network over a physical network and uses managed forwarding elements executing on host computers associated with the logical network. The collected data is reported to a policy, analytics, and correlation engine appliance (an analysis appliance). The analysis appliance is a server (or cluster of servers) that receives reports from each host computer and configuration data from a network manager computer, processes the data to be stored in a time series data storage, and performs analysis on the stored data. In some embodiments, the analysis appliance also provides access to the stored data to additional elements of the system for visualization and alternative analysis.
Each host computer, in some embodiments, is responsible for collecting and reporting attributes of data flows associated with machines executing on the host computer. In some embodiments, the host computer includes: a flow exporter that processes and publishes flow data to the analysis appliance, a set of guest introspection (GI) agents for collecting context data relating to the flows from machines (e.g., data compute nodes [DCNs], virtual machines, containers, etc.) executing on the host, a set of third-party programs or processes that provide additional context data, an anomaly detection engine and a machine learning engine that analyze flow data and context data and provide additional context data, and a context exporter for processing and publishing context data to the analysis appliance. Additional details of the hosts and the analysis appliance are discussed in U.S. patent application Ser. No. 16/554,370, filed Aug. 28, 2019, now issued as U.S. Pat. No. 11,340,931, which is hereby incorporated by reference.
Some embodiments collect, each time a request for a new data message flow is initiated, a set of contextual attributes (i.e., context data) associated with the requested new data message flow. The contextual attributes, in some embodiments, include attributes at layer 7 (L7) of the Open Systems Interconnection (OSI) model. The attributes collected, in some embodiments, include one or more of a user identifier (ID), a virtual machine ID, a security ID (SID), a process ID, and a command line associated with the request along with additional contextual attributes at other layers (e.g., layer 3 and layer 4) of the OSI model.
Once the contextual attributes are collected, some embodiments provide sets of collected attributes to a service engine or service engines executing on the host computer that provide services for data messages of data message flows. The set of collected attributes sent to a particular service engine will depend on the service to be performed and the information necessary to perform the service. In some embodiments, a set of correlation data is generated based on the collected attributes that is meant to be appended or inserted into flow data (i.e., a record associated with the requested flow) that is collected by, for example, a flow exporter. The generated correlation data set, in some embodiments, includes a first value based on a user ID and a second value based on the identity of a process (or application) requesting the new data message flow. In some embodiments, the first and second values are the user ID and a process hash associated with the requested flow. In some embodiments, the value based on the process identity is also based on a command line interface (CLI) parameter (e.g., is a process instance identifier) associated with the requested flow. The process instance identifier (e.g., a process key), in some embodiments, is used to identify the process and CLI parameter associated with the flow to provide fine-grained analysis at an analysis appliance that receives the flow data and contextual data from each host computer.
The generated correlation data set, in some embodiments, is provided to the flow exporter along with a set of header values that identify the requested flow. The flow exporter, in such embodiments, identifies the generated correlation data set to append to the flow data by matching header values of a received data message in the flow with the header values associated with the generated correlation data set. In other embodiments, the flow exporter makes a request to a context engine of a context exporter to collect the generated correlation data set for each data message in a new data message flow (i.e., upon receiving a SYN packet of a flow) and appends the collected correlation data to each subsequent data message of the data message flow. In either embodiment, the flow exporter processes the data message with the appended generated correlation data set (or appends them after processing) and exports the flow data, including the generated correlation data set, to the analysis appliance.
The analysis appliance, in some embodiments, receives context data and flow data from multiple host computers and performs initial processing to aggregate flow data received from the multiple hosts into aggregated flow group records. In some embodiments, an initial processing to aggregate context data received from multiple hosts into aggregated context data is performed independently. The aggregation operations performed on the flow and context data, in some embodiments, deduplicate (e.g., combine) records for a same flow that are received from a source and destination host computer.
The aggregated flow group records and the context data are stored by the analysis appliance to be used in providing a set of functions (e.g., responding to user queries and generating visualizations in response to the user queries, providing anomaly detection, providing vulnerability analysis, generating recommendations, etc.). The stored flow group records and context data are correlated, in some embodiments, periodically to provide data for an anomaly detection engine or other analysis components of the analysis device. Additionally, or alternatively, some embodiments, correlate stored flow group records and context data upon receiving a request by a user for specific data.
The data correlation, in some embodiments, is performed using at least a portion of the correlation data (e.g., the user ID, the process hash, the process instance identifier, or a user ID/process hash pair) stored in the flow data and the corresponding data stored in the context data. The data correlation, in some embodiments, identifies a client-server pair at the application level using a combination of at least one of the user ID, the process ID, the CLI parameter data, and an n-tuple (e.g., a 5-tuple) that identifies ports used for a specific data message flow that are found in the correlated data (e.g., data in either of a flow group record or the context data that is identified using the generated correlation data stored in the flow group record). Additional details of the analysis appliance are discussed in U.S. patent application Ser. No. 16/554,370.
The preceding Summary is intended to serve as a brief introduction to some embodiments of the invention. It is not meant to be an introduction or overview of all inventive subject matter disclosed in this document. The Detailed Description that follows and the Drawings that are referred to in the Detailed Description will further describe the embodiments described in the Summary as well as other embodiments. Accordingly, to understand all the embodiments described by this document, a full review of the Summary, Detailed Description, the Drawings, and the Claims is needed. Moreover, the claimed subject matters are not to be limited by the illustrative details in the Summary, Detailed Description, and the Drawings.
The novel features of the invention are set forth in the appended claims. However, for purposes of explanation, several embodiments of the invention are set forth in the following figures.
In the following detailed description of the invention, numerous details, examples, and embodiments of the invention are set forth and described. However, it will be clear and apparent to one skilled in the art that the invention is not limited to the embodiments set forth and that the invention may be practiced without some of the specific details and examples discussed.
Some embodiments provide a novel method for collecting and reporting attributes of data flows associated with machines executing on a plurality of host computers. In some embodiments, the machines are associated with a logical network implemented by a virtualization manager (e.g., VMware™ NSX manager). The logical network, in some embodiments, is implemented as an overlay network over a physical network and uses managed forwarding elements executing on host computers associated with the logical network. The collected data is reported to a policy, analytics, and correlation engine appliance (an analysis appliance). The analysis appliance is a server (or cluster of servers) that receives reports from each host computer and configuration data from a network manager computer, processes the data to be stored in a time series data storage, and performs analysis on the stored data. In some embodiments, the analysis appliance also provides access to the stored data to additional elements of the system for visualization and alternative analysis.
As used in this document, data messages refer to a collection of bits in a particular format sent across a network. Also, as used in this document, a data flow refers to a set of data messages sharing a set of attributes (e.g. a five-tuple) even if the shared set of attributes has the source and destination values switched for different directions of communication (i.e., from a first machine to a second machine and from the second machine back to the first machine). Data flows (or flows) as used in this document, in some instances, refer to one half of a communication between two machines (i.e., a flow refers, in some cases, to the communication from one machine to another machine in one direction). One of ordinary skill in the art will recognize that the term data message may be used herein to refer to various formatted collections of bits that may be sent across a network, such as Ethernet frames, IP packets, TCP segments, UDP datagrams, etc. Also, as used in this document, references to L2, L3, L4, and L7 layers (or layer 2, layer 3, layer 4, layer 7) are references, respectively, to the second data link layer, the third network layer, the fourth transport layer, and the seventh application layer of the OSI (Open System Interconnection) layer model.
Each host computer, in some embodiments, is responsible for collecting and reporting attributes of data flows associated with machines executing on a host computer. In some embodiments, the host computer includes: a flow exporter that provides flow data to an analysis appliance, a set of guest introspection (GI) agents for collecting context data relating to the flows from machines (e.g., data compute nodes [DCNs], virtual machines, containers, etc.) executing on the host, a set of third-party programs that provide additional context data, an anomaly detection engine that analyzes flow data and context data and provides additional context data, a machine learning engine that analyzes flow data and context data to make recommendations or perform preliminary processing to offload some of the processing at an upstream analysis appliance, a context engine for correlating the different sets of context data, and a set of publishers that communicate the context data and flow data to the appliance cluster for further processing. Additional details of the hosts and the analysis appliance are discussed in U.S. patent application Ser. No. 16/554,370, filed Aug. 28, 2019, which is hereby incorporated by reference.
The guest introspection agents 150 execute on the DCNs 105 and extract context data from the DCNs 105. For example, a guest introspection agent 150, in some embodiments, detects that a new data flow has been initiated (e.g., by sending a SYN packet in a data flow using TCP) and collects introspection data (e.g., a set of attributes of the data flow and DCN). The introspection data, in some embodiments, includes any, or all, of data regarding (i) guest metadata, (ii) guest events, and (iii) guest DCN metrics. In some embodiments, the guest metadata includes any, or all, of data regarding DCN 105 (a universally unique identifier [UUID], a bios UUID, and a vmxpath), operating system data (type of OS and version information), and process data (e.g., process ID, creation time, hash, name, command line, security ID [SID], user ID [UID], loaded library or module information, process metrics [e.g., memory usage and CPU usage], process version, parent process ID, etc.). Guest events, in some embodiments, include DCN 105 events (e.g., power on and power off), user login events (e.g., login, logoff, connect, and disconnect events, a session ID, a timestamp, a DCN IP, and a connected client IP), and service process events (e.g., event type [e.g., listen start, listen stop], timestamp, destination DCN IP, destination port number, and process details). Guest DCN metrics, in some embodiments, include memory usage and CPU usage. One of ordinary skill in the art will appreciate that much of the context data, in some embodiments, is not included in the L2-L7 headers of a flow and that many additional pieces of information may be collected by guest introspection agent 150. The partial list above serves only as an example of the types of information that can be gathered by guest introspection agent 150.
The collected context information is sent, in some embodiments, to context engine 110 through MUX 127 to be provided to other elements of the host and for correlation with context data received from other sources. In some embodiments, the other sources include a set of service engines 115, threat detector/DPI module 132, third-party software (processes) 133, anomaly detector 122, and ML engine 124. Context data received from third-party software, in some embodiments, is collected using a library (e.g., a set of APIs provided by the third-party software) or a third-party agent executing on the host computer 100 for communicating with the third-party software. Context engine 110, in some embodiments, correlates the context data from the multiple sources for providing the correlated context data (e.g., sets of correlated contextual attributes) to the context publisher 147 (e.g., through context attribute storage 145).
Once a request has been detected (at 210), the process 200 collects (at 220) context data from at least one source of context data. The sources of context data, in different embodiments, are different combinations of any or all of a set of guest introspection agents (e.g., through a multiplexer), a set of service engines, a threat detector/DPI module, a third-party software (or processes), an anomaly detector, and an ML engine. The contextual data includes at least a user ID, a process hash, and a command line associated with the detected request. The user ID is any one of a Windows™ security ID (i.e., a globally unique ID generated for every user), or a modified Linux™ user ID (e.g., a user ID generated by appending the Linux user ID to a virtual machine (VM) universally unique ID (e.g., a VM VC UUID)), or some other universally unique ID (UUID). In some embodiments, the collection includes the correlation and aggregation of different sets of context data received from at least one source of context data. In some embodiments, the correlation is based on common attributes (e.g., context data from multiple sources include at least one of a UUID (e.g., a security ID (SID) or any of the other UUIDs described above), an IP address, a machine identifier, a process hash, etc.) with different context data sets having different common attributes that allow a complete set of context data to be stitched together.
Once related sets of context data are identified, some embodiments aggregate related contextual attributes into a single aggregated contextual attribute set. As process 200 is an ongoing process, the correlation and aggregation, in some embodiments, correlates and aggregates received data to previously stored correlated and aggregated context data. In some embodiments, the context data for each contextual attribute (e.g., source IP address, source port, destination IP address, destination port, protocol, SID, process hash, machine ID, version tag, service rules hit, CPU usage, memory usage, guest events, machine events, etc.) included in the sets of context data is concatenated in a corresponding field for the attribute. In other embodiments, only unique attribute values are added to the aggregated contextual attributes, or some combination of the two methods for aggregating data is used in conjunction with other methods that are appropriate for different attributes. Contextual attribute sets, in different embodiments, are aggregated for any or all of each machine executing on the host (e.g., by machine identifier or IP address), each process hash, each process hash/CLI parameter combination, each user, each of a set of flow tuples used to identify individual flows, or other groupings as might be desired by a user. In some embodiments, the aggregation criteria are dynamically adjustable by a user to be used for additional or alternative analysis.
After the context data has been collected (at 220), the process 200 continues by generating (at 230) a correlation data set (e.g., a correlation key). In some embodiments, the correlation data set includes a user ID and a process identifier. The process identifier, in some embodiments, is a process hash (e.g., an SHA-256 hash). In some embodiments, instead of or in addition to a process hash, the generated correlation data set includes a process instance identifier that is generated based on the process hash and a CLI parameter associated with the requested new data message flow. The process hash may be modified by appending a hash of the CLI parameter or by modifying a set of bits in the process hash based on the CLI parameter. For example, a number of possible unique CLI parameters can be determined for each process (or for a process that has the most possible unique CLI parameters) and a number of bits that can accommodate that many possibilities (e.g., 5 bits for 17-31 possible command lines) can be set aside in the process hash to be modified based on an equivalent number of bits in a hash of the CLI parameter. By generating the modified hash, a particular process (e.g., application) and CLI parameter combination can be identified using the process instance identifier by other system elements that have access to the process hash and CLI parameter information. One of ordinary skill in the art would appreciate that other identifiers of a user or process may be used in place of the user ID and process hash in a correlation data set (e.g., an SID and a process ID).
The process then provides (at 240) the generated correlation data set to the flow exporter for inclusion in exported flow records. The generated correlation data set is sent to the flow exporter, in some embodiments, in response to a request made to the context exporter (e.g., a context engine of the context exporter) upon receiving a first data message in a data message flow (e.g., a SYN packet). In some embodiments, the generated correlation data set are provided to the flow exporter along with an associated set of flow identifiers (e.g., an n-tuple) for every new flow independent of a request from the flow exporter to allow the flow exporter to append the generated correlation data to received data messages before exporting them to the analysis appliance.
In some embodiments, contextual attribute data is provided to additional system elements including any, or all, of: a service engine, an anomaly detection engine, an ML engine, and a threat detection module for the recipient element to provide a service or perform analysis based on the contextual attributes (along with data received from other sources, in some embodiments). The additional system elements, in some embodiments, provide additional context data that is included in the context data exported by the context exporter. In some embodiments, the attributes are provided to the other elements based on requests or queries from the other elements. The additional system elements (e.g., a service engine implementing a distributed firewall or other service) are responsible for providing the correlation data to the flow exporter after receiving it from the context exporter. Providing (at 240) the generated correlation data set to the flow exporter for inclusion in exported flow records, in some embodiments, is accomplished by providing the generated correlation data set to the service engine (e.g., the distributed firewall or other service).
In addition to providing (at 240) the generated correlation data set to the flow exporter, the process 200 includes (at 250) the generated correlation data in the context data to be exported to the analysis appliance. One of ordinary skill in the art will appreciate that after the correlation data set is generated (at 230), including (at 250) the generated correlation data in the context data to be exported to the analysis appliance and providing (at 240) the generated correlation data set to the flow exporter may be performed in any order as the two operations are independent.
After collecting the context data, the process 200 publishes (at 260) contextual attribute data, including the correlation data set, stored in the contextual attribute storage to an analysis appliance that performs further processing of the contextual attribute data. As discussed above, in some embodiments, the contextual attribute data that is published is organized into contextual attribute data sets based on machine identifiers, a set of key values, or a set of flow tuples. In some embodiments, publishing the contextual attribute data includes receiving a confirmation that the published data has been received at the analysis appliance. Additional details of the context data collection and publishing process can be found in U.S. patent application Ser. No. 16/554,370.
Going back to
In some embodiments, the SFE 112 maintains a single port (e.g. port 160) for each VNIC 155 of each DCN 105. The SFE 112 connects to the host PNIC (through a NIC driver [not shown]) to send outgoing messages and to receive incoming messages. In some embodiments, the SFE 112 is defined to include a port 165 that connects to the PNIC's driver to send and receive messages to and from the PNIC. The SFE 112 performs message-processing operations to forward messages that it receives on one of its ports to another one of its ports. For example, in some embodiments, the SFE 112 tries to use data in the message (e.g., data in the message header) to match a message to flow-based rules, and upon finding a match, to perform the action specified by the matching rule (e.g., to hand the message to one of its ports 160-165, which directs the message to be supplied to a destination DCN 105 or to the PNIC).
In some embodiments, the SFE 112 is a software switch, while in other embodiments, it is a software router or a combined software switch/router. The SFE 112, in some embodiments, implements one or more logical forwarding elements (e.g., logical switches or logical routers) with SFEs 112 executing on other hosts in a multi-host environment. A logical forwarding element, in some embodiments, can span multiple hosts to connect DCNs that execute on different hosts but belong to one logical network.
Different logical forwarding elements can be defined to specify different logical networks for different users, and each logical forwarding element can be implemented by multiple software forwarding elements on multiple hosts. Each logical forwarding element isolates the traffic of the DCNs of one logical network from the DCNs of another logical network that is serviced by another logical forwarding element. A logical forwarding element can connect DCNs executing on the same host and/or different hosts, both within a datacenter and across datacenters. In some embodiments, the SFE 112 extracts from a data message a logical network identifier (e.g., a VNI) and a MAC address. The SFE 112, in these embodiments, uses the extracted VNI to identify a logical port group, and then uses the MAC address to identify a port within the port group.
Software switches (e.g., software switches of hypervisors) are sometimes referred to as virtual switches because they operate in software and they provide the DCNs with shared access to the PNIC(s) of the host. However, in this document, software switches are referred to as physical switches because they are items in the physical world. This terminology also differentiates software switches from logical switches, which are abstractions of the types of connections that are provided by the software switches. There are various mechanisms for creating logical switches from software switches. VXLAN provides one manner for creating such logical switches. The VXLAN standard is described in Mahalingam, Mallik; Dutt, Dinesh G.; et al. (2013-05-08), VXLAN: A Framework for Overlaying Virtualized Layer 2 Networks over Layer 3 Networks, IETF.
The ports 160-165 of the SFE 112, in some embodiments, include one or more function calls to one or more modules that implement special input/output (I/O) operations on incoming and outgoing messages that are received at the ports 160-165. Examples of I/O operations that are implemented by the ports 160-165 include ARP broadcast suppression operations and DHCP broadcast suppression operations, as described in U.S. Pat. No. 9,548,965. Other I/O operations (such as firewall operations, load-balancing operations, network address translation operations, etc.) can be so implemented in some embodiments of the invention. By implementing a stack of such function calls, the ports 160-165 can implement a chain of I/O operations on incoming and/or outgoing messages, in some embodiments. Also, in some embodiments, other modules in the data path (such as the VNICs 155 and the ports 160-165, etc.) implement the I/O function call operations instead of, or in conjunction with, the ports 160-165.
In some embodiments, one or more of function calls of the SFE ports 160-165 can be to service engines 115 that query context engine 110 for context information that service engines 115 use, in some embodiments, to generate context headers (e.g., headers including context data) that include context data used in providing a service at the service engines 115 and, in some embodiments, identify service rules applied to provide the service. Context data, in some embodiments, is stored by a component of a service engine 115 executing in a kernel space for retrieval by the flow exporter 170. In some embodiments, the generated context headers are then provided through one of the ports 160-165 of SFE 112 to flow exporter 170 (e.g., flow identifier and statistics collector 171). The generated context headers, in some embodiments, also include at least one of a first value based on a user ID (e.g., the user ID), and a second value based on a process hash and command line associated with the data message flow (sometimes referred to as a modified process hash or process instance identifier in this disclosure). In some embodiments, the at least one of the first and second values are included even when not used in providing the service. In other embodiments, at least one of the first and second values are provided upon receiving a request from a flow exporter 170.
Flow exporter 170 monitors flows, collects flow data and statistics, aggregates flow data into flow group records, and publishes flow group records for consumption by the analysis appliance. In some embodiments, flow exporter 170 generally aggregates statistics for individual flows identified during multiple time periods, and for each time period identifies multiple groups of flows with each group including one or more individual flows. For each identified group, flow exporter 170 identifies a set of attributes by aggregating one or more subsets of attributes of one or more individual flows in the group as described below in greater detail. In some embodiments, the subset of attributes of each individual flow in each group is the aggregated statistics of the individual flow. After the multiple time periods, flow exporter 170 provides the set of attributes for each group identified in the multiple time periods to a server (e.g., an analysis appliance) for further analysis of the data flows identified.
As shown, the flow exporter 170 includes flow identifier/statistics collector 171, flow identifier and statistics storage 172, flow collector timer 173, flow collector 174, first-in first-out (FIFO) storage 175, configuration data storage 176, flow aggregator 177, flow group record storage 178, flow publisher timer 179, and flow group record publisher 180 for collecting and processing flow data to produce aggregated flow group records and publishing the set of flow aggregated records.
Flow exporter 170 receives flow information, including flow identifiers and statistics, at flow identifier/statistics collector 171. In some embodiments, the received flow information is derived from individual data messages that make up the flow and includes context data used in making service decisions at service engines 115. In some embodiments, the flow exporter 170 receives the context data (i.e., the values based on the user ID and the process hash/command line associated with data message flows) generated by the context exporter 140 to append to data messages. In some embodiments, the flow exporter 170 stores the received information associated with particular flows in flow identifier and statistics storage 172. The statistics, in some embodiments, are summarized (accumulated) over the life of the particular flow (e.g., bytes exchanged, number of packets, start time, and duration of the flow).
After receiving (at 510) the data message (e.g., data message 321), the process 500 receives (at 520) correlation data (e.g., correlation data 323). In some embodiments, the correlation data 323 is received from context engine 110 (as in
After receiving the data message (at 510) and the correlation data set (at 520), the process 500 records (at 530) the flow identifiers, statistics, and correlation data. In some embodiments, this recording is performed by flow identifier/statistics collector 171. After recording (at 530) the flow identifiers, statistics, and correlation data, the recorded data is provided (at 540) to a flow aggregator 177 of the flow exporter 170. Additional details of the operations between flow identifier/statistics collector 171 and flow aggregator 177 are discussed below and in U.S. patent application Ser. No. 16/554,370.
The process 500 then aggregates (at 550) the recorded data, including the correlation data set, into an aggregated set of flow data. Additional recorded data, in some embodiments, from previously and subsequently received data messages is aggregated into the aggregated set of flow data and the process 500 publishes (at 560) the aggregated flow data, including at least the correlation data set received (at 520) from the context engine, to the analysis appliance. The analysis appliance uses the correlation data included in the context data and the aggregated flow data to correlate the data sets as will be described below in relation to
Returning to the description of
Additionally, the flow collector 174, in some embodiments, collects data for long-lived active flows (e.g., flows lasting longer than half a publishing period) from flow identifier and statistics storage 172 before the end of a publishing period provided by flow publisher timer 179. In some embodiments, the data collected for a long-lived active flow is different from the data collected for terminated flows. For example, active flows are reported using a start time, but without a duration in some embodiments. Only flows meeting certain criteria are collected by flow collector 174 in some embodiments. For example, only information for flows using a set of particular protocols (e.g., TCP, UDP, ESP, GRE, SCTP) are collected, while others are dropped or ignored. In some embodiments, additional types of traffic, such as broadcast and multicast, safety check (e.g., having ruleID=0 or 0 rx and tx byte/packet counts), L2 flows, flows which are not classified as one of (1) inactive, (2) drop, or (3) reject, are dropped (i.e., not collected or not placed into FIFO storage 175). The process for collecting data into flow identifier and statistics storage 172 and pulling it into FIFO storage 175 is described in more detail in U.S. patent application Ser. No. 16/554,370.
In some embodiments, FIFO storage 175 is a circular or ring buffer such that only a certain number of sets of flow identifiers and flow statistics can be stored before old sets are overwritten. In order to collect all the data placed into FIFO storage 175, or at least to not miss a significant amount (e.g., miss less than 5% of the data flows), flow aggregator 177 pulls data stored in FIFO storage 175 based on a flow collector timer 173 and aggregates the pulled data into aggregated flow group records (“buckets”). Some embodiments pull data from FIFO storage 175 based on a configurable periodicity (e.g., every 10 seconds), while other embodiments, alternatively or in addition to the periodic collection, dynamically determine when to collect data from FIFO storage 175 based on a detected number of data flows (e.g. terminated data flows, a total number of active data flows, etc.) and the size of FIFO storage 175. Each set of flow data pulled from FIFO storage 175 for a particular flow, in some embodiments, represents a unidirectional flow from a first endpoint (e.g., machine or DCN) to a second endpoint. If the first and second endpoints execute on the same host computer, in some embodiments, a same unidirectional flow is captured at different ports 160-165 of host 100. To avoid double counting a same data message provided to flow identifier 171 from the two ports 160-165, flow identifier 171 uses a sequence number or other unique identifier to determine if the data message has been accounted for in the statistics collected for the flow. Even if duplicate data messages for a single unidirectional flow have been accounted for, the flow aggregator 177 additionally, in some embodiments, combines sets of flow data received for the separate unidirectional flows into a single set of flow data. In some embodiments, this deduplication (deduping) of flow data occurs before further aggregation, while in other embodiments occurs after an aggregation operation.
Flow aggregator 177, in some embodiments, receives a set of keys from the analysis appliance through the network manager computer (as described above) that specify how the flow data sets are aggregated.
Some embodiments provide an analysis appliance that receives the collected data (e.g., as separate flow group records and contextual attribute data) from the hosts, as well as configuration data from a network manager computer. The analysis appliance, in some embodiments, is a server (or cluster of servers) that based on the received reports from each host computer and configuration data from the network manager computer, processes the data to be stored in a time-series-data storage, and performs analysis on the stored data. In some embodiments, the analysis appliance also provides access to the stored data to additional elements of the system for visualization and alternative analysis.
Interfaces 701-03, in some embodiments, are separate interfaces (e.g., ports, IP addresses, etc.) for interacting with the host computers 706, network manager computers 707, and user interfaces 708. In some embodiments, interfaces 701-03 are combined into a single interface through which the different elements of the system interact with the appliance. Interface 701, in some embodiments, is used to receive both flow data and context data from the host computers 706. In some embodiments, interface 701 is not used by the analysis appliance 700 for communicating to the host computers 706. Instead, in some embodiments, the analysis appliance 700 communicates control messages (e.g., updates to service rule policies, updated keys, updated group memberships validated by a user, etc.) through network manager computers 707. Interface 702 receives configuration data from the network manager 707, in some embodiments. Interface 702, in some embodiments, is used to receive both management plane configuration data and policy configuration data. In some embodiments, interface 702 is also used to communicate with the hosts 706 through the network management computer 707. Interface 703, in some embodiments, is used to receive key definitions, and commands for the visualization engine 731 received from a user (e.g., through the GUI). Processing pipeline 710, in some embodiments, processes flow data (e.g., flow group records) received from the host computers 706 in the system for analysis by other elements of the analysis appliance 700.
Returning to the discussion of
The contextual attribute data storage 722, in some embodiments, receives contextual attribute data sets including any, or all, of: data regarding guest metadata, guest events, and guest DCN metrics. In some embodiments, the guest metadata includes any or all of DCN details (a universally unique identifier [UUID], a bios uuid, and a vmxpath), operating system details (type of OS and version information), and process details (e.g., process ID, creation time, hash, name, command line, security ID [SID], user ID [UID], loaded library or module information, process metrics [e.g., memory usage and CPU usage], process version, parent process ID, etc.). Guest events, in some embodiments, include DCN events (e.g., power on and power off), user login events (e.g., login, logoff, connect, and disconnect events, a session ID, a timestamp, a DCN IP, and a connected client IP), and service process events (e.g., event type [e.g., listen start, listen stop], timestamp, destination DCN IP, destination port number, and process details). Guest DCN metrics, in some embodiments, include memory usage and CPU usage. One of ordinary skill in the art will appreciate that many additional pieces of information may be provided to a contextual attribute data storage and that the partial list above serves only as an example.
In some embodiments, the set of data storages 720 includes a correlated flow group record data storage 721. The correlated flow group record data storage 721, in some embodiments, stores flow group records after aggregation and correlation with configuration data stored in a configuration data storage 723. The correlated flow group record data storage 721, in some embodiments, also stores learned pairings of IP addresses and machine identifiers. In some embodiments, the learning is based on previously processed flow record groups. The correlated flow group record data storage 721, in some embodiments, provides processed (e.g., aggregated and correlated) flow group records to the time-series-data storage.
The configuration data storage 723, in some embodiments, receives configuration data from a network manager controller. In some embodiments, the configuration data includes configuration data sets sent from a management plane (MP) configuration storage and a policy configuration storage on a network manager computer 707 that are merged before or after being sent from the network manager computer 707. The management plane configuration data sets include information relating to group membership (in terms of machines), and the policy configuration data sets include information about service rules (e.g., firewall rules), in some embodiments. The service rules, in some embodiments, are expressed in terms of any of IP addresses, ports, protocols, groups, etc., in any combination. In some embodiments, an initial set of configuration data is sent at startup or reboot of either the network manager computer or the analysis appliance, while subsequent configuration data sets include only changes to the last configuration data set.
The time-series-data storage 724, in some embodiments, stores flow group records, configuration data, and context data. In some embodiments, the time-series-data storage 724 is organized by topic with each different type of data stored in a different topic. Additionally, in some embodiments, each topic is organized in a time-series fashion by use of an index that is appended to each set of data and is coordinated among all the producers of data for the topic. The time-series-data storage 724 is organized at a plurality of levels of temporal granularity, in some embodiments. In some embodiments, the different levels of granularity include some combination of hourly, daily, weekly, and monthly. The different levels of temporal granularity are used, in some embodiments, for data collected for a previous 24 hours (e.g., organized on an hourly basis), data for a previous 6 days (e.g., organized on a daily basis), data for a previous 70 days (e.g., organized on a daily or weekly basis), and data received more than 30 days earlier (e.g., organized on a monthly basis). The data organized based on the various levels of temporal granularity are, in some embodiments, periodically (e.g., daily) rolled up into the next level of granularity.
Some embodiments provide contextual attribute data correlation that is used in multiple analysis engines discussed below.
After retrieving (at 810) the data sets for correlation, the process 800 identifies (at 820) correlation data sets in the stored flow data and context data. In some embodiments, the correlation data includes a combination of at least one of a user ID, a process hash, and a process instance identifier. Some embodiments using a process instance identifier, derive a process instance identifier for context data based on a process hash and CLI parameter stored in the context data. The context data and flow data are then correlated (at 830) based on the identified correlation data sets in the flow and context data. In some embodiments, the correlation includes merging the context and flow data records sharing a same correlation data set (i.e., a correlation data set having the same values) into a single correlated record. In some embodiments, the correlation includes adding selected (e.g., configurable) attributes from the contextual attribute data set to the flow group records. One of ordinary skill in the art will understand that the ultimate form of the correlated records, in some embodiments, depends on the purpose of the correlated records (e.g., a first data processing engine will request data in a certain format, while another processing engine will request data in a different format).
The correlation operation, in some embodiments, includes a disambiguation operation if multiple flow group records and contextual attribute data sets include a same set of values in their correlation data sets. The disambiguation is performed, in some embodiments, using the flow data and contextual data included in the correlated data sets. In other embodiments, the contextual attribute data sets and flow data records are aggregated based on corresponding attributes such that there is an unambiguous relationship between contextual attribute data sets and flow data records. For example, if contextual attribute data sets are generated for every flow, then every flow data record that includes flow data for a particular flow will be correlated with the contextual attribute data set associated with the particular flow. In some embodiments, each record in the different sets of data is tagged by an index to ease future analysis operations that require correlated data. In other embodiments, the correlation is performed each time an analysis operation is performed because the analysis is generally performed only once per related data sets (e.g., data sets associated with a single time period in the time-series-data storage 724).
The correlated data is then provided (at 840) to a set of data processing engines (e.g., processing engines 731-34 in the set of data processing engines 730). The correlated data, in some embodiments, only includes a requested/selected portion of the correlated flow data and context data records (e.g., a selected set of header fields (at L2 and L3) and context data (at L7)). The correlated data, in some embodiments, allows a user to identify particular client-server communications based on the context data (e.g., context data regarding L7 parameters, such as a CLI parameter) and the flow data (e.g., a source/destination port used in flows associated with the client-server communication) received from the hosts of the client and server.
The correlated data, for some data processing engines, is provided based on a request from the data processing engine. For example, a process running periodically, requests correlated data relating to specific time periods at particular intervals. For other data processing engines, the correlated data is provided automatically or based on a user request. For example, if a user query regarding all activity by a set of users associated with a user ID, or a set of processes with a set of process hashes is received, a correlation operation occurs and the correlated data is sent to a visualization engine (e.g., 731) to be presented to the user as the result of the query. Different correlation operations and correlated data sets provided to data processing engines are illustrated in
The process 800, in some embodiments, is initiated by a user request for information relating to a set of particular processes, users, process/command line combinations, or any other context or flow attributes collected by the analysis appliance as would be understood by one of ordinary skill in the art. In other embodiments, the process 800 is performed periodically to provide correlated data to a set of analysis engines described below and in more detail in U.S. patent application Ser. No. 16/554,370.
The set of flow statistics fields 913, in some embodiments, includes a flow start time, a flow end time, a flow duration, a number of bytes exchanged during the lifetime of the flow, a number of packets exchanged during the lifetime of the flow, or any other statistics of interest to a user. The set of flow metadata fields 914 includes, in some embodiments, information regarding a configuration version used (e.g., a version tag), a service rule applied to the data messages of the flow, a process ID associated with the flow, a VM ID associated with a flow, and a user ID associated with the flow (e.g., a Linux™ user ID, or SID). For flow group records that aggregate multiple distinct flows, the sets of statistics and flow metadata, in some embodiments, include single values for each field, while in other embodiments, each field includes a value or set of values based on multiple flows (e.g., an average value, or a concatenated set of values) based on an administrator's configuration of the aggregation method for the flow group data (i.e., a specification of the flow group record or “bucket”).
The set of correlation data fields 917 stores the correlation data (i.e., in this embodiment, a process key 915 and a user key 916). As shown, the process key 915 and the user key 916 are, respectively, used to identify corresponding sets of user metadata 930 and process metadata 920. In some embodiments, the process key 915 is any of a process hash, a modified process hash, or process instance identifier (identifying a process and CLI parameter), and the user key 916 is any UUID (e.g., a Windows™ SID, a modified Linux™ UID, etc.). Additional correlation data may be included in correlation data 917 to correlate the context and flow data sets according to the requirements of the system or an administrator. One of ordinary skill in the art will understand that the separation of fields in the flow data does not place any restrictions on the arrangement of the different fields and that the flow data, in some embodiments, is merely a set of data arranged to include all desired information in a particular format that is established by a user.
The sets of context data 920-940, in some embodiments, include a set of process metadata 920, a set of user metadata 930, and a set of VM metadata 940. The set of process metadata 920 includes, in some embodiments, any or all of an n-tuple 921 (e.g., a 5-tuple) of a flow associated with the process, a process hash 922, a process name 923, a CLI parameter 924, a process key 925 (e.g., a modified process hash or process instance identifier), and any other process metadata 926 desired by an administrator that can be collected at the host computer. The process keys 915 and 925 stored in the flow group data 910 and process metadata 920, respectively, are shown as being used to correlate the set of flow group data 910 (i.e., a flow group record) and the process metadata 920. The set of user metadata fields 930 includes, in some embodiments, any or all of a user ID (e.g., a Linux™ UID) 931, a user name 932, a domain name 933, a group ID 934, a group name 935, a user key 936 (e.g., a UUID), and any other user metadata (not shown) desired by an administrator that can be collected at the host computer. As shown, the user keys 916 and 936 included in correlation data 917 and user metadata 930, respectively, are used to correlate the set of flow group data 910 to the user metadata 930.
The set of VM (or DCN) metadata 940 includes any or all of a VM identifier (VM ID) 941, a VM name 942, a domain name 943 of a domain to which the VM belongs, a set of IP addresses 944 associated with the VM, a set of interfaces 945 associated with the VM, and any other VM metadata 946 desired by an administrator that can be collected at the host computer. As shown, the flow group data 910 does not include correlation data in the set of correlation data fields 917 to correlate the flow group data 910 directly to the VM metadata 940, but, in some embodiments, information (e.g., a user key 936 and user ID 931) stored in the user metadata 930 (or in the process data 920) is used to correlate the VM metadata 940 with the user metadata 930 and, in turn, with the flow group data 910. For example, a user key 936, in some embodiments, is a VM VC UUID generated by appending a user ID corresponding to user ID 931 to a VM ID corresponding to VM ID 941, and by removing the user ID 931 from the user key 936, the remaining portion of the user key 936 can be, and is, correlated to the VM ID 941. In other embodiments, other information stored in the flow group data 910 is used to correlate flow group data 910 with VM metadata 940. For example, flow group metadata 914, in some embodiments, includes at least one VM ID associated with at least one flow aggregated into the flow group data 910, the VM ID can be used to correlate the flow group data 910 with at least one set of VM metadata 940. One of ordinary skill in the art will appreciate that the sets of context data 920-940, in some embodiments, are sent as a single set of context data by a context exporter, while in other embodiments, the context data sets 920-940 are sent to an analysis appliance as different context data sets (as shown).
Returning to the discussion of
In some embodiments, a set of flow group records include an indication of anomalous behavior that is used to select flow group records for further anomalous behavior analysis. In some embodiments, the anomalous behavior indication is a flag bit that indicates anomalous behavior detection at a host computer. The anomalous behavior indication, in other embodiments, is provided as a value that indicates a type of anomalous behavior detected. The various types of anomalous behavior include, in some embodiments, one of: (1) an indication that a newly added service rule was not used to process at least one flow in the particular group of flows to which the newly added service rule applies, (2) that a default service rule was used to process at least one flow in the particular group of flows, (3) that at least one source machine of a flow in a particular group of flows has not been microsegmented, (4) that no service rule has been specified for communications between a source and destination machine of at least one flow in the particular group of flows, (5) that a port associated with at least one flow in the particular group of flows does not match a port expected based on an application associated with the at least one flow, (6) that a previously blocked flow has been allowed, (7) that an insecure version of an application has been used, (8) that an application or URL related to a flow group record has a bad reputation score, and (9) that an irregularity was detected with a protocol (e.g., TCP) header. Additional types of anomalous behavior that are provided, in some embodiments, will be appreciated by one of ordinary skill in the art.
The analysis, in some embodiments, is also performed based on other received data sets (e.g., contextual attribute data sets and configuration data sets that, in some embodiments, have already been correlated with the flow group records), stored flow group records from the time-series-data storage, or any combination of the above. The contextual attribute data sets, in some embodiments, include attributes that are not found in headers (e.g., layer 2-layer 4 headers) of data messages. For example, process identifiers, process hashes, CPU and memory usage, and other contextual attributes discussed above. In some embodiments, the configuration data is used to identify service rules in effect at the time the flows were collected. The analysis, in some embodiments, includes at least one of identifying flows that appear to break service rules identified from the configuration data and identifying large amounts of data exchanged between two machines (e.g., as an FTP put or an HTTP POST). The result of the analysis, in some embodiments, is an alert regarding the anomalous behavior to an administrator.
Some embodiments also provide a recommendation engine to produce recommendations for an administrator. The recommendation engine, in some embodiments, provides data for machine learning and uses machine-trained networks to make recommendations. In some embodiments, the recommendations include a group to which a particular machine should be added, a new group that should be created for a particular set of machines, or a set of service rules (e.g., firewall rules) based on existing groups and data messages detected (e.g., unmicrosegmented data flows). In some embodiments, the recommendation engine identifies unmicrosegmented machines and suggests specific service rules for microsegmentation or makes a general recommendation that microsegmentation may be desirable to an administrator among a set of machines.
In some embodiments, a visualization engine is provided to present a visual representation of machines as members of groups and to represent communications between machines. The visualization processing, in some embodiments, also includes generating a graphical user interface that can be used to select groups of machines, domains, or individual machines and display contextual attributes relevant to the selected group, domain, or machine. In some embodiments, the context data is displayed based on a mouse-over (e.g., hover) operation in which a mouse (e.g., pointer) is moved over a machine, domain, or group to select it for display of contextual attributes which triggers a window to appear over the previous graphical representation with the contextual attributes displayed in the window. In some embodiments, flows between machines are also presented visually and can be selected or a mouse-over can be used to display additional contextual attributes of a selected flow. Other display options (e.g., lists, tables, etc.) are used in addition to, or in place of, the described mouse over. Some visualizations provide insight into particular process and command line combinations that are related to flows between the visualized machines based on the correlated data sets, including the process instance identifier.
Many of the above-described features and applications are implemented as software processes that are specified as a set of instructions recorded on a computer readable storage medium (also referred to as computer readable medium). When these instructions are executed by one or more processing unit(s) (e.g., one or more processors, cores of processors, or other processing units), they cause the processing unit(s) to perform the actions indicated in the instructions. Examples of computer readable media include, but are not limited to, CD-ROMs, flash drives, RAM chips, hard drives, EPROMs, etc. The computer readable media does not include carrier waves and electronic signals passing wirelessly or over wired connections.
In this specification, the term “software” is meant to include firmware residing in read-only memory or applications stored in magnetic storage, which can be read into memory for processing by a processor. Also, in some embodiments, multiple software inventions can be implemented as sub-parts of a larger program while remaining distinct software inventions. In some embodiments, multiple software inventions can also be implemented as separate programs. Finally, any combination of separate programs that together implement a software invention described here is within the scope of the invention. In some embodiments, the software programs, when installed to operate on one or more electronic systems, define one or more specific machine implementations that execute and perform the operations of the software programs.
The bus 1405 collectively represents all system, peripheral, and chipset buses that communicatively connect the numerous internal devices of the computer system 1400. For instance, the bus 1405 communicatively connects the processing unit(s) 1410 with the read-only memory 1430, the system memory 1425, and the permanent storage device 1435.
From these various memory units, the processing unit(s) 1410 retrieve instructions to execute and data to process in order to execute the processes of the invention. The processing unit(s) may be a single processor or a multi-core processor in different embodiments. The read-only-memory (ROM) 1430 stores static data and instructions that are needed by the processing unit(s) 1410 and other modules of the computer system. The permanent storage device 1435, on the other hand, is a read-and-write memory device. This device is a non-volatile memory unit that stores instructions and data even when the computer system 1400 is off. Some embodiments of the invention use a mass-storage device (such as a magnetic or optical disk and its corresponding disk drive) as the permanent storage device 1435.
Other embodiments use a removable storage device (such as a floppy disk, flash drive, etc.) as the permanent storage device. Like the permanent storage device 1435, the system memory 1425 is a read-and-write memory device. However, unlike storage device 1435, the system memory 1425 is a volatile read-and-write memory, such as a random access memory. The system memory 1425 stores some of the instructions and data that the processor needs at runtime. In some embodiments, the invention's processes are stored in the system memory 1425, the permanent storage device 1435, and/or the read-only memory 1430. From these various memory units, the processing unit(s) 1410 retrieve instructions to execute and data to process in order to execute the processes of some embodiments.
The bus 1405 also connects to the input and output devices 1440 and 1445. The input devices 1440 enable the user to communicate information and select commands to the computer system 1400. The input devices 1440 include alphanumeric keyboards and pointing devices (also called “cursor control devices”). The output devices 1445 display images generated by the computer system 1400. The output devices 1445 include printers and display devices, such as cathode ray tubes (CRT) or liquid crystal displays (LCD). Some embodiments include devices such as a touchscreen, which function as both input and output devices.
Finally, as shown in
Some embodiments include electronic components, such as microprocessors, storage and memory that store computer program instructions in a machine-readable or computer-readable medium (alternatively referred to as computer-readable storage media, machine-readable media, or machine-readable storage media). Some examples of such computer-readable media include RAM, ROM, read-only compact discs (CD-ROM), recordable compact discs (CD-R), rewritable compact discs (CD-RW), read-only digital versatile discs (e.g., DVD-ROM, dual-layer DVD-ROM), a variety of recordable/rewritable DVDs (e.g., DVD-RAM, DVD-RW, DVD+RW, etc.), flash memory (e.g., SD cards, mini-SD cards, micro-SD cards, etc.), magnetic and/or solid state hard drives, read-only and recordable Blu-Ray® discs, ultra density optical discs, any other optical or magnetic media, and floppy disks. The computer-readable media may store a computer program that is executable by at least one processing unit and includes sets of instructions for performing various operations. Examples of computer programs or computer code include machine code, such as is produced by a compiler, and files including higher-level code that are executed by a computer, an electronic component, or a microprocessor using an interpreter.
While the above discussion primarily refers to microprocessor or multi-core processors that execute software, some embodiments are performed by one or more integrated circuits, such as application specific integrated circuits (ASICs) or field programmable gate arrays (FPGAs). In some embodiments, such integrated circuits execute instructions that are stored on the circuit itself.
As used in this specification, the terms “computer”, “server”, “processor”, and “memory” all refer to electronic or other technological devices. These terms exclude people or groups of people. For the purposes of the specification, the terms “display” or “displaying” mean displaying on an electronic device. As used in this specification, the terms “computer readable medium,” “computer readable media,” and “machine readable medium” are entirely restricted to tangible, physical objects that store information in a form that is readable by a computer. These terms exclude any wireless signals, wired download signals, and any other ephemeral or transitory signals.
While the invention has been described with reference to numerous specific details, one of ordinary skill in the art will recognize that the invention can be embodied in other specific forms without departing from the spirit of the invention. For instance, several figures conceptually illustrate processes. The specific operations of these processes may not be performed in the exact order shown and described. The specific operations may not be performed in one continuous series of operations, and different specific operations may be performed in different embodiments. Furthermore, the process could be implemented using several sub-processes, or as part of a larger macro process. Thus, one of ordinary skill in the art would understand that the invention is not to be limited by the foregoing illustrative details, but rather is to be defined by the appended claims.
This application is a continuation application of U.S. patent application Ser. No. 16/745,248, filed Jan. 16, 2020, now published as U.S. Patent Publication 2021/0224179. U.S. patent application Ser. No. 16/745,248, now published as U.S. Patent Publication 2021/0224179, is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5636128 | Sugimoto et al. | Jun 1997 | A |
7027411 | Pulsipher et al. | Apr 2006 | B1 |
7065079 | Patra et al. | Jun 2006 | B1 |
7352280 | Rockwood | Apr 2008 | B1 |
7580356 | Mishra et al. | Aug 2009 | B1 |
7739211 | Coffman et al. | Jun 2010 | B2 |
7908655 | Bhattacharyya et al. | Mar 2011 | B1 |
8005945 | Cohen et al. | Aug 2011 | B2 |
8359652 | Bhagwan et al. | Jan 2013 | B2 |
8495429 | Fu et al. | Jul 2013 | B2 |
8499348 | Rubin | Jul 2013 | B1 |
8605655 | Sahai et al. | Dec 2013 | B1 |
8762957 | Cobb et al. | Jun 2014 | B2 |
9166997 | Guo et al. | Oct 2015 | B1 |
9215213 | Bansal et al. | Dec 2015 | B2 |
9218527 | Lakshminarayan et al. | Dec 2015 | B2 |
9223767 | Powell et al. | Dec 2015 | B1 |
9438560 | Mohanty et al. | Sep 2016 | B2 |
9438634 | Ross et al. | Sep 2016 | B1 |
9454444 | Agarwal et al. | Sep 2016 | B1 |
9467476 | Shieh et al. | Oct 2016 | B1 |
9497206 | Bernstein et al. | Nov 2016 | B2 |
9578050 | Barabash et al. | Feb 2017 | B1 |
9680877 | Duffield et al. | Jun 2017 | B2 |
9699049 | Gupta et al. | Jul 2017 | B2 |
9767197 | Agarwal et al. | Sep 2017 | B1 |
9787641 | Bansal et al. | Oct 2017 | B2 |
9792447 | Thota et al. | Oct 2017 | B2 |
9882713 | Raza et al. | Jan 2018 | B1 |
9891940 | Feroz et al. | Feb 2018 | B2 |
9998339 | Brajkovic et al. | Jun 2018 | B1 |
10129162 | Faulk, Jr. | Nov 2018 | B1 |
10257227 | Stickle et al. | Apr 2019 | B1 |
10298505 | Grant et al. | May 2019 | B1 |
10298619 | Nimmagadda et al. | May 2019 | B2 |
10324746 | Kumar et al. | Jun 2019 | B2 |
10419321 | Raman et al. | Sep 2019 | B2 |
10425437 | Bog et al. | Sep 2019 | B1 |
10432707 | Hosie et al. | Oct 2019 | B2 |
10521584 | Mehr | Dec 2019 | B1 |
10581897 | Natanzon et al. | Mar 2020 | B1 |
10735282 | Singh et al. | Aug 2020 | B1 |
10812409 | Tiwary et al. | Oct 2020 | B2 |
10887337 | Kim et al. | Jan 2021 | B1 |
10911335 | Mordani et al. | Feb 2021 | B1 |
11057414 | Giorgio et al. | Jul 2021 | B1 |
11140090 | Mordani et al. | Oct 2021 | B2 |
11150976 | Marwah et al. | Oct 2021 | B1 |
11176157 | Mordani et al. | Nov 2021 | B2 |
11188570 | Jain et al. | Nov 2021 | B2 |
11269718 | Chen et al. | Mar 2022 | B1 |
11288256 | Jain et al. | Mar 2022 | B2 |
11296960 | Wang et al. | Apr 2022 | B2 |
11321213 | Gunda | May 2022 | B2 |
11340931 | Krishna et al. | May 2022 | B2 |
11343262 | Junod et al. | May 2022 | B2 |
11347896 | Brown, Jr. et al. | May 2022 | B1 |
11349876 | Krishna et al. | May 2022 | B2 |
11374952 | Coskun et al. | Jun 2022 | B1 |
11374968 | Colón et al. | Jun 2022 | B1 |
11398987 | Jain et al. | Jul 2022 | B2 |
11425150 | Emanuel et al. | Aug 2022 | B1 |
11436075 | Jain et al. | Sep 2022 | B2 |
11593639 | Garg et al. | Feb 2023 | B1 |
11616708 | Chraim et al. | Mar 2023 | B1 |
20030120955 | Bartal et al. | Jun 2003 | A1 |
20030236677 | Casati et al. | Dec 2003 | A1 |
20040190724 | Dettinger et al. | Sep 2004 | A1 |
20050108444 | Flauaus et al. | May 2005 | A1 |
20050119001 | Watanabe | Jun 2005 | A1 |
20050262554 | Brooks et al. | Nov 2005 | A1 |
20050289219 | Nazzal | Dec 2005 | A1 |
20060085785 | Garrett | Apr 2006 | A1 |
20060168657 | Baentsch et al. | Jul 2006 | A1 |
20060174337 | Bernoth | Aug 2006 | A1 |
20060239203 | Talpade et al. | Oct 2006 | A1 |
20070011734 | Balakrishnan et al. | Jan 2007 | A1 |
20070016666 | Duffield et al. | Jan 2007 | A1 |
20070058632 | Back et al. | Mar 2007 | A1 |
20070147236 | Lee | Jun 2007 | A1 |
20080037423 | Singh et al. | Feb 2008 | A1 |
20080059596 | Ogawa | Mar 2008 | A1 |
20080196102 | Roesch | Aug 2008 | A1 |
20080196103 | Lin et al. | Aug 2008 | A1 |
20080263661 | Bouzida | Oct 2008 | A1 |
20080267186 | Boukis et al. | Oct 2008 | A1 |
20080281660 | Sajja et al. | Nov 2008 | A1 |
20080282335 | Abzarian et al. | Nov 2008 | A1 |
20090077663 | Sun et al. | Mar 2009 | A1 |
20090106228 | Weinman, Jr. | Apr 2009 | A1 |
20090300341 | Buehler et al. | Dec 2009 | A1 |
20100049968 | Dimitrakos et al. | Feb 2010 | A1 |
20100106764 | Chadwick et al. | Apr 2010 | A1 |
20100107085 | Chadwick et al. | Apr 2010 | A1 |
20100153316 | Duffield et al. | Jun 2010 | A1 |
20100211673 | Kosbab et al. | Aug 2010 | A1 |
20100241480 | Rokhlin et al. | Sep 2010 | A1 |
20100309812 | Marquez et al. | Dec 2010 | A1 |
20100325199 | Park et al. | Dec 2010 | A1 |
20100332262 | Horvitz et al. | Dec 2010 | A1 |
20110082962 | Horovitz et al. | Apr 2011 | A1 |
20110162039 | Trace et al. | Jun 2011 | A1 |
20110170413 | Shi et al. | Jul 2011 | A1 |
20120131591 | Moorthi et al. | May 2012 | A1 |
20120226808 | Morgan | Sep 2012 | A1 |
20120266231 | Spiers et al. | Oct 2012 | A1 |
20130041522 | Mori et al. | Feb 2013 | A1 |
20130067090 | Batrouni et al. | Mar 2013 | A1 |
20130085914 | Mcpherson et al. | Apr 2013 | A1 |
20130117567 | Chang et al. | May 2013 | A1 |
20130124753 | Ansari et al. | May 2013 | A1 |
20130185413 | Beaty et al. | Jul 2013 | A1 |
20130198459 | Joshi et al. | Aug 2013 | A1 |
20130212255 | Chao et al. | Aug 2013 | A1 |
20130227687 | Lee | Aug 2013 | A1 |
20130254766 | Zuo et al. | Sep 2013 | A1 |
20130297768 | Singh | Nov 2013 | A1 |
20140019964 | Neuse et al. | Jan 2014 | A1 |
20140075564 | Singla et al. | Mar 2014 | A1 |
20140089506 | Naga et al. | Mar 2014 | A1 |
20140207918 | Kowalski et al. | Jul 2014 | A1 |
20140230008 | Feroz et al. | Aug 2014 | A1 |
20140245423 | Lee | Aug 2014 | A1 |
20140282591 | Stich et al. | Sep 2014 | A1 |
20140310513 | Barney et al. | Oct 2014 | A1 |
20150113529 | Zhong | Apr 2015 | A1 |
20150124608 | Agarwal et al. | May 2015 | A1 |
20150135003 | Cota-Robles et al. | May 2015 | A1 |
20150156214 | Kaminsky | Jun 2015 | A1 |
20150180892 | Balderas | Jun 2015 | A1 |
20150181394 | Zuniga et al. | Jun 2015 | A1 |
20150207813 | Reybok et al. | Jul 2015 | A1 |
20150281056 | Liljenstolpe | Oct 2015 | A1 |
20150281065 | Liljenstolpe | Oct 2015 | A1 |
20150286783 | Kumar et al. | Oct 2015 | A1 |
20150304349 | Bernstein et al. | Oct 2015 | A1 |
20150355957 | Steiner et al. | Dec 2015 | A1 |
20150358391 | Moon | Dec 2015 | A1 |
20160050589 | Safavi | Feb 2016 | A1 |
20160080404 | Kohout et al. | Mar 2016 | A1 |
20160087847 | Krithivas et al. | Mar 2016 | A1 |
20160087859 | Kuan et al. | Mar 2016 | A1 |
20160156591 | Zhou et al. | Jun 2016 | A1 |
20160191306 | Gasparakis et al. | Jun 2016 | A1 |
20160191413 | Feroz et al. | Jun 2016 | A1 |
20160191463 | Mohanty et al. | Jun 2016 | A1 |
20160191521 | Feroz et al. | Jun 2016 | A1 |
20160216994 | Sefidcon et al. | Jul 2016 | A1 |
20160218951 | Vasseur et al. | Jul 2016 | A1 |
20160294800 | Oppenheim, Jr. et al. | Oct 2016 | A1 |
20160294987 | Tian et al. | Oct 2016 | A1 |
20160301603 | Park et al. | Oct 2016 | A1 |
20160308898 | Teeple et al. | Oct 2016 | A1 |
20160350683 | Bester et al. | Dec 2016 | A1 |
20160352765 | Mermoud et al. | Dec 2016 | A1 |
20160359759 | Singh et al. | Dec 2016 | A1 |
20160380812 | Chanda et al. | Dec 2016 | A1 |
20160380884 | Sarikaya et al. | Dec 2016 | A1 |
20170005986 | Bansal et al. | Jan 2017 | A1 |
20170078168 | Harris et al. | Mar 2017 | A1 |
20170126677 | Kumar et al. | May 2017 | A1 |
20170134247 | Hoja et al. | May 2017 | A1 |
20170149804 | Kolbitsch et al. | May 2017 | A1 |
20170207968 | Eicken et al. | Jul 2017 | A1 |
20170212799 | Konireddygari | Jul 2017 | A1 |
20170214634 | Li | Jul 2017 | A1 |
20170223046 | Singh | Aug 2017 | A1 |
20170272452 | Kraemer et al. | Sep 2017 | A1 |
20170279687 | Muntés-Mulero et al. | Sep 2017 | A1 |
20170293994 | Li et al. | Oct 2017 | A1 |
20170324632 | Arora | Nov 2017 | A1 |
20170359217 | Ahuja et al. | Dec 2017 | A1 |
20170374102 | Woolward | Dec 2017 | A1 |
20170374106 | Hamou et al. | Dec 2017 | A1 |
20180007005 | Chanda et al. | Jan 2018 | A1 |
20180007127 | Salapura et al. | Jan 2018 | A1 |
20180027080 | Yang et al. | Jan 2018 | A1 |
20180032399 | Johnson et al. | Feb 2018 | A1 |
20180034856 | Mallya | Feb 2018 | A1 |
20180041578 | Lee et al. | Feb 2018 | A1 |
20180048623 | Bansal et al. | Feb 2018 | A1 |
20180054456 | Ground et al. | Feb 2018 | A1 |
20180063164 | Balasubramanian et al. | Mar 2018 | A1 |
20180063178 | Jadhav et al. | Mar 2018 | A1 |
20180077119 | Fields et al. | Mar 2018 | A1 |
20180077120 | Baughman et al. | Mar 2018 | A1 |
20180077189 | Doppke et al. | Mar 2018 | A1 |
20180084034 | Netto et al. | Mar 2018 | A1 |
20180088964 | Hussain et al. | Mar 2018 | A1 |
20180091485 | Lee et al. | Mar 2018 | A1 |
20180101371 | Flanakin et al. | Apr 2018 | A1 |
20180123907 | Raman et al. | May 2018 | A1 |
20180123939 | Raman et al. | May 2018 | A1 |
20180145999 | Ertugrul et al. | May 2018 | A1 |
20180167405 | Comay et al. | Jun 2018 | A1 |
20180176102 | Bansal et al. | Jun 2018 | A1 |
20180176252 | Nimmagadda et al. | Jun 2018 | A1 |
20180176261 | Bansal et al. | Jun 2018 | A1 |
20180181423 | Gunda et al. | Jun 2018 | A1 |
20180181754 | Gunda | Jun 2018 | A1 |
20180183757 | Gunda et al. | Jun 2018 | A1 |
20180183759 | Gunda et al. | Jun 2018 | A1 |
20180183761 | Gunda et al. | Jun 2018 | A1 |
20180183764 | Gunda | Jun 2018 | A1 |
20180183866 | Gunda | Jun 2018 | A1 |
20180189667 | Tsou et al. | Jul 2018 | A1 |
20180234333 | Inamdar et al. | Aug 2018 | A1 |
20180248904 | Villella et al. | Aug 2018 | A1 |
20180270189 | Montenot et al. | Sep 2018 | A1 |
20180270308 | Shea et al. | Sep 2018 | A1 |
20180287876 | Strobel et al. | Oct 2018 | A1 |
20180288063 | Koottayi et al. | Oct 2018 | A1 |
20180295036 | Krishnamurthy et al. | Oct 2018 | A1 |
20180316704 | Durairaj et al. | Nov 2018 | A1 |
20180324199 | Crotinger et al. | Nov 2018 | A1 |
20190007292 | Nevo et al. | Jan 2019 | A1 |
20190036956 | Gunda | Jan 2019 | A1 |
20190065739 | Manadhata et al. | Feb 2019 | A1 |
20190065762 | Kim et al. | Feb 2019 | A1 |
20190075056 | Lu et al. | Mar 2019 | A1 |
20190138423 | Agerstam et al. | May 2019 | A1 |
20190158520 | DiValentin et al. | May 2019 | A1 |
20190163900 | Zhang et al. | May 2019 | A1 |
20190166008 | Gintis et al. | May 2019 | A1 |
20190171474 | Malboubi et al. | Jun 2019 | A1 |
20190180141 | Tiagi et al. | Jun 2019 | A1 |
20190182276 | Tiagi et al. | Jun 2019 | A1 |
20190182281 | Neil et al. | Jun 2019 | A1 |
20190199599 | Zavesky et al. | Jun 2019 | A1 |
20190266004 | Kumar et al. | Aug 2019 | A1 |
20190280949 | Wang et al. | Sep 2019 | A1 |
20190303562 | Masputra et al. | Oct 2019 | A1 |
20190319863 | Gupta et al. | Oct 2019 | A1 |
20190342335 | Ni et al. | Nov 2019 | A1 |
20190373007 | Salunke et al. | Dec 2019 | A1 |
20190373052 | Pollitt et al. | Dec 2019 | A1 |
20190379612 | Tiwary et al. | Dec 2019 | A1 |
20190392329 | Rangarajan et al. | Dec 2019 | A1 |
20200028756 | Hale | Jan 2020 | A1 |
20200084087 | Sharma et al. | Mar 2020 | A1 |
20200100145 | Enqvist et al. | Mar 2020 | A1 |
20200128043 | Xie | Apr 2020 | A1 |
20200162407 | Tillotson | May 2020 | A1 |
20200167258 | Chattopadhyay et al. | May 2020 | A1 |
20200167784 | Kursun | May 2020 | A1 |
20200183947 | Reeve et al. | Jun 2020 | A1 |
20200193031 | Avraham et al. | Jun 2020 | A1 |
20200210260 | Prabhakar et al. | Jul 2020 | A1 |
20200244676 | Amit et al. | Jul 2020 | A1 |
20200310884 | Villalobos et al. | Oct 2020 | A1 |
20200396075 | Visegrady et al. | Dec 2020 | A1 |
20200396254 | Crabtree et al. | Dec 2020 | A1 |
20210006642 | He et al. | Jan 2021 | A1 |
20210026677 | Krishna et al. | Jan 2021 | A1 |
20210026720 | Jain et al. | Jan 2021 | A1 |
20210026830 | Jain et al. | Jan 2021 | A1 |
20210026863 | Mordani et al. | Jan 2021 | A1 |
20210026870 | Jain et al. | Jan 2021 | A1 |
20210028996 | Mordani et al. | Jan 2021 | A1 |
20210029002 | Mordani | Jan 2021 | A1 |
20210029050 | Jain | Jan 2021 | A1 |
20210029051 | Mordani et al. | Jan 2021 | A1 |
20210029166 | Krishna | Jan 2021 | A1 |
20210075789 | Wen et al. | Mar 2021 | A1 |
20210084074 | Kirner et al. | Mar 2021 | A1 |
20210099473 | Fainberg et al. | Apr 2021 | A1 |
20210110282 | McCann et al. | Apr 2021 | A1 |
20210110407 | Albero et al. | Apr 2021 | A1 |
20210136101 | Ben-Yosef et al. | May 2021 | A1 |
20210185073 | Ewaida et al. | Jun 2021 | A1 |
20210185085 | Wang et al. | Jun 2021 | A1 |
20210203684 | Maor et al. | Jul 2021 | A1 |
20210218770 | Ben-Yosef et al. | Jul 2021 | A1 |
20210219219 | Sundararaj et al. | Jul 2021 | A1 |
20210224179 | Gunda et al. | Jul 2021 | A1 |
20210243212 | Bowman et al. | Aug 2021 | A1 |
20210248240 | Comish et al. | Aug 2021 | A1 |
20210264025 | Givental et al. | Aug 2021 | A1 |
20210281591 | Furtak | Sep 2021 | A1 |
20210344689 | Mehr | Nov 2021 | A1 |
20210350248 | Rogers et al. | Nov 2021 | A1 |
20210367842 | Guillou et al. | Nov 2021 | A1 |
20220014560 | Crabtree et al. | Jan 2022 | A1 |
20220070699 | Thiyagarajan et al. | Mar 2022 | A1 |
20220210126 | Keiser | Jun 2022 | A1 |
20220215453 | Achan et al. | Jul 2022 | A1 |
20220224721 | Bertiger et al. | Jul 2022 | A1 |
20220239675 | Panse et al. | Jul 2022 | A1 |
20220239683 | Kaliya et al. | Jul 2022 | A1 |
20220253531 | Kim et al. | Aug 2022 | A1 |
20220269577 | Gechman et al. | Aug 2022 | A1 |
20220365806 | Krishna et al. | Nov 2022 | A1 |
20220385647 | Pabón et al. | Dec 2022 | A1 |
20220407897 | Raghuvanshi et al. | Dec 2022 | A1 |
20220417096 | Vutukuri et al. | Dec 2022 | A1 |
20230011043 | Panse et al. | Jan 2023 | A1 |
20230011397 | Panse et al. | Jan 2023 | A1 |
20230011957 | Panse et al. | Jan 2023 | A1 |
Number | Date | Country |
---|---|---|
3716075 | Sep 2020 | EP |
3767553 | Jan 2021 | EP |
2006091175 | Aug 2006 | WO |
2016003262 | Jan 2016 | WO |
Entry |
---|
Abbes, Tarek, et al., “Detection of Firewall Configuration Errors with Updatable Tree,” International Journal of Information Security, May 2015, 17 pages, vol. 15, No. 3, Springer Verlag. |
El-Atawy, Adel, et al., “Policy Segmentation for Intelligent Firewall Testing,” 1st IEEE ICNP Workshop on Secure Network Protocols, Nov. 6, 2005, 6 pages, IEEE, Boston, MA, USA. |
Oliveira, Ricardo M., et al., “Automatic Detection of Firewall Misconfigurations Using Firewall and Network Routing Policies,” Jan. 2009, 6 pages. |
Ring, Markus, et al., “Detection of Slow Port Scans in Flow-Based Network Traffic,” PLOS One, Sep. 25, 2018, 18 pages, retrieved from https://journals.plos.org/plosone/article?id=10.1371/journal.pone.0204507. |
Turcotte, Melissa J. M., et al., “Unified Host and Network Data Set”, Aug. 24, 2017, 16 pages, arXiv:1708.07518v1, arXiv.org, Cornell University, Ithaca, NY, USA. |
Waye, Lucas, et al., “Cryptographically Secure Information Flow Control on Key-Value Stores,” CCS '17: Proceedings of the 2017 ACM SIGSAC Conference on Computer and Communications Security, Oct. 30-Nov. 3, 2017, 15 pages, ACM, Dallas, TX, USA. |
Arbuthnot, Tom, “What are Thresholds for Good and Poor Network Packet Loss, Jitter and Round Trip Time for Unified Communications?”, Tom Talks, May 17, 2018, 7 pages, retrieved from https://tomtalks.blog/what-are-thresholds-for-good-and-poor-network-packet-loss-jitter-and-round-trip-time-for-unified-communications/. |
Number | Date | Country | |
---|---|---|---|
20220261330 A1 | Aug 2022 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16745248 | Jan 2020 | US |
Child | 17734250 | US |