This disclosure relates in general to the field of communications and, more particularly, to discovering and grouping application endpoints in a network environment.
Industry shifts are redefining Information Technology (IT) at all levels. On-premise IT consumption models are shifting to cloud-based services. IT as a service (IaaS) is supplanted by applications as a service. Separate development and operations are moving toward integrated development and operations (DevOps). Box-centric management models are migrating to application-centric management. Business agility requires application agility, so IT teams need to provision applications in hours instead of months. Resources need to scale up (or down) in minutes, not hours. Traditional approaches take a silo-ed operational view, with no common operational model between the application, network, security, and cloud teams. A common operational model delivers application agility, simplified operations, assured performance, and scale.
To provide a more complete understanding of the present disclosure and features and advantages thereof, reference is made to the following description, taken in conjunction with the accompanying figures, wherein like reference numerals represent like parts, in which:
Overview
An example method for discovering and grouping application endpoints in a network environment is provided and includes discovering (e.g., discerning, ascertaining, learning, determining, identifying, etc.) endpoints communicating in a network environment, calculating affinity between the discovered endpoints, and grouping the endpoints into separate endpoint groups (EPGs) according to the calculated affinity, each EPG comprising a logical grouping of similar endpoints that can be used to apply common forwarding and policy logic according to logical application boundaries.
As used herein, the broad term “affinity” encompasses any type of common property, such as traffic attribute (e.g., source address, destination address, protocol, etc.), process attribute (e.g., process performance, process definition, process deployment, etc.), socket attribute (e.g., type, protocol, domain, etc.), communication pattern, configuration setting, profile, etc. that links two endpoints in the network. An “endpoint” comprises an addressable application component (e.g., portion of an application encapsulating a set of related functions and/or data) that provides or consumes a network service (e.g., data storage, manipulation, presentation, communication or other such function); EPGs act as flexible containers for endpoints on which common policy can be applied. For example, a database tier endpoint can represent a configurable connection point to a database; an application tier endpoint can represent a connection point for services provided by the application tier component. In a general sense, all communication to and from a specific application occurs through the application's endpoints.
Turning to
Each server 14 may host one or more applications 20 that can comprise various application components, for example, web tier components 22, application tier components 24 and database tier components 26. By way of example, and not as limitation, the application components may execute as endpoints 28 on servers 14, and/or virtual machines 29. According to various embodiments, entity discovery and grouping module 16 may enable discovery and grouping of endpoints 28 into suitable endpoint groups (EPGs) 30 according to user defined criteria. As used herein, the term “Endpoint Group” refers to a collection of similar endpoints representing application components, such as application tier, set of services, or other logical application boundary. For example, EPGs 30 can comprise collections of one or more endpoints 28 that provide similar functionalities. Note that endpoints can be identified (e.g., for purposes of grouping) by virtual port, physical port, Internet Protocol (IP) address, Domain Name System (DNS) name, IP address plus Layer 4 port, and other suitable unique identifiers.
EPGs 30 can provide logical groupings that can be used to apply forwarding and policy logic (e.g., rules, strategies, plans, configurations, etc.), potentially allowing for separating network policy, security, and forwarding from addressing and enforcing them on logical application boundaries. Within a particular EPG, separate endpoints can exist in one or more subnets, and subnets can be applied to one or more EPGs. For example, a particular EPG can include HTTPS endpoints and HTTP endpoints; HTTPS endpoints may reside in 10.10.11.x subnet and HTTP endpoints may reside in 10.10.10.x subnet. Regardless of the separate subnets, a common policy can be applied to both HTTPS and HTTP services within the EPG. In a general sense, EPGs 30 allow for better mapping of applications to network 12, and for better mapping of network 12 to application owners and developers. For example, rather than application owners and developers being required to maintain mappings to IP addressing and subnets, they can group application components into logical EPGs according to the embodiments described herein.
EPGs 30 can be used to group endpoints 28 according to any suitable criteria. For example, EPGs 30 can be specified according to traditional network VLANs: all endpoints connected to a given VLAN are placed in a particular EPG; EPGs 30 can be specified according to Virtual Extensible LAN (VXLAN): all endpoints connected to a given VXLAN are placed in a particular EPG; EPGs 30 can be mapped to a port group; EPGs 30 can be specified by IP or subnet (e.g., 172.168.10.10 or 172.168.10 may be grouped into one EPG); EPGs 30 can be specified by DNS names or DNS ranges: for instance, example.foo.com or *.web.foo.com can be mapped to a specific EPG; and so on.
By way of examples and not as limitations, certain endpoints 28 representing web tier components 22 corresponding to application 20(1) may be grouped into EPG 30(1); certain other endpoints 28 representing application tier components corresponding to application 20(1) may be grouped into EPG 30(2); and certain other endpoints 28 representing database tier components corresponding to application 20(1) may be grouped into EPG 30(3). The combination of EPGs 30(1)-30(3) and forwarding elements (e.g., switches, routers, etc.) 32(1) and connectivity and policies between them may comprise an application profile of application 20(1).
Similarly, certain other endpoints representing web tier components 22 corresponding to application 20(2) may be grouped into EPG 30(4); certain other endpoints representing application tier components corresponding to application 20(2) may be grouped into EPG 30(5); and certain other endpoints representing database tier components corresponding to application 20(2) may be grouped into EPG 30(6). The combination of EPGs 30(4)-30(6) and forwarding elements 32(2) and connectivity and policies between them may comprise an application profile of application 20(2) and so on.
Entity discovery and grouping module 16 may include a memory element 38, a processor 40 (e.g., associated with network element 18), a collection engine 42, a grouping analysis module 44 and a reporting module 46 for performing the discovery and grouping (and other) operations as described herein. In various embodiments, collection engine 42 may collect configuration information (including address resolution protocol (ARP) tables, established connections and listening port information) of switches 48, servers 14, VMs 29 and other such network element(s) 18 in network 12. Grouping analysis module 44 may analyze communication patterns amongst endpoints 28 and classify (e.g., group) endpoints 28 that are sending or receiving traffic, based on certain criteria. Reporting module 46 arranges the grouping results in a user presentable form.
For purposes of illustrating the techniques of communication system 10, it is important to understand the communications that may be traversing the system shown in
In a data center environment, business services rely upon many instances of a variety of application types. In some scenarios, it may be desirable to distinguish such instances and classify them into distinct groups based on the services offered by the applications. Moreover, it may be desirable to closely track performance, capacity, faults and other parameters associated with each of their application instances, as also the inter-dependencies between applications, for example, to ensure that service level agreements (SLAs) between customers and the data center are being met for the business services. Over time, the data center environment may host a complex set of heterogeneous applications, whose type, number of instances and inter-dependencies can be lost in operational processes, potentially leading to lack of visibility and introducing inefficiencies in the application and data center life-cycle.
Groupings of applications are currently based on virtual LAN (VLAN) and subnets and are tailored towards network management. For example, connectivity and policies may be applied based on the VLAN groupings—one or more applications are grouped into VLANs and IP subnets are mapped to those VLANs; connectivity through routing is configured and network services are applied to the subnet addressing. Such a grouping mechanism can restrict the types of groups into which applications can be grouped and the policies that can be applied to the applications. The grouping mechanism also lends itself to misconfiguration and undesirable loose policy configuration. Manual configurations, process, and coupled constructs from the grouping mechanism can lead to slower deployment, higher configuration error rates, and reduced auditability, potentially creating significant business impact.
Cisco® Application Centric Infrastructure™ (ACI) in the data center is a holistic architecture with centralized automation and policy-driven application profiles that can permit more flexible grouping. ACI delivers software flexibility with scalable hardware performance. ACI includes various switches configured (or configurable) for ACI, a centralized policy management and application policy infrastructure controller (APIC), an application virtual switch (AVS) for virtual network edges, software and hardware components, integrated physical and virtual infrastructure, and an open ecosystem of network, storage, management, and orchestration vendors. ACI can facilitate a network that is deployed, monitored, and managed in a fashion that supports development operations (DevOps) and rapid application change, with reduced complexity and a common policy framework that can automate provisioning and managing of resources.
Within the APIC, software applications are defined logically using constructs that are application centric, rather than network centric. For example, a group of physical and virtual web servers may be grouped in a single tier of a three-tier application. The communication between the tiers and the policies that define that communication comprise the complete application. Within the APIC, the complete application definition is comprised in the application profile, which is specified based on the communication, security, and performance needs of the application. APIC used the application profile to push the logical topology and policy definitions down to stateless network hardware in the network fabric. Such an approach is reverse of traditional architectures, in which VLANs, subnets, fire-wall rules, etc. dictate where and how an application can run.
The application profile can comprise a collection of EPGs, their connections, and the policies that define those connections. Application profiles are used to define connectivity of application tiers such as web-app-database, compute, -network -storage. They can be represented as connectivity graphs. Application profiles may comprise instantiation of a complete application on the network. In the ACI implementation, the Application profiles are used by network engineers, application owners, and developers to map an application onto the network hardware. In other words, Application profiles are the logical representation of an application and its interdependencies in the network fabric. Application profiles are designed to be modeled in a logical way that matches the way that applications are designed and deployed. The configuration and enforcement of policies and connectivity is handled by the ACI system (e.g., software) rather than manually by an administrator.
In addition, ACI permits EPGs to be created manually. Rather than using forwarding constructs such as addressing or VLANs to apply connectivity and policy, EPGs use a grouping of application endpoints. For example, an EPG could be the group of components that make up an application's web tier. EPGs are also used to represent entities such as outside networks, network services, security devices, and network storage. Within an EPG separate endpoints can exist in one or more subnets, and subnets can be applied to one or more EPGs based on several other design considerations. Layer 2 forwarding behavior can also be applied independently of the Layer 3 addressing.
EPGs are designed for flexibility, allowing their use to be tailored to one or more deployment models that the customer can choose. The EPGs are used to define the elements to which policy is applied. Within the network fabric, policy is applied between EPGs (e.g., configuring the mode in which EPGs communicate with one another), rather than being based on addressing and forwarding constructs. The EPG model offers a number of management advantages. For example, it offers a single object with uniform policy to higher-level automation and orchestration tools. Tools need not operate on individual endpoints to modify policies. Additionally, it helps ensure consistency across endpoints in the same group regardless of their placement in the network.
Several methods exist for defining endpoints and placing them in EPGs. The use of EPGs can differ across customer environments and even across a single fabric deployment. The combination of EPGs and Application profiles allows for stateless network policy definition and enforcement free from dependencies on locality and forwarding. Application policy is defined in the user space and automatically mapped onto the network hardware when applied based on workload location.
However, generating groupings are currently based on manual or semi-manual methods and require prior knowledge of application instances and types of applications deployed in the network. Many products in the market providing application discovery, analysis and migration solutions suffer from the same drawback, and require user specification of applications and/or application components to work effectively.
Note that although a number of discovery and collection tools are available in the network market, there are no solutions that perform an automated network traffic-based grouping using the collected information. Moreover, none of the available discovery and collection tools apparently calculate affinity based on communication targets for network data and compute data.
Communication system 10 is configured to address these issues (among others) to offer a system and method for automatically discovering and grouping application endpoints 28 in a network environment. According to various embodiments, entity discovery and grouping module 16 may discover endpoints 28 communicating in network 12, calculate affinity between the discovered endpoints 28, and group endpoints 28 into separate EPGs 30 according to the calculated affinity, each EPG 30 representing a logical grouping of similar endpoints that can be used to apply common forwarding and policy logic according to logical application boundaries.
Embodiments of communication system 10 can facilitate identification and correlation of data points and conditions to distinguish the type and variety of applications 20 in network 12, which can include a heterogeneous data center environment. Entity discovery and grouping module 16 may identify and collect specific data points across endpoints 28 and network devices that provide network services to endpoints 28. Entity discovery and grouping module 16 may correlate the collected data-points to check for conditions that can distinguish and group endpoints 28 based on instances of applications 20.
In some embodiments, collection engine 42 may execute on customer premises. In other embodiments, collection engine 42 may execute in another part of network 12. Collection engine 42 may provide the ability to securely capture device configuration information securely through multiple protocols such as Simple Network Management Protocol (SNMP), Secure Shell (SSH), and Windows Management Instrumentation (WMI). Collection engine 42 may collect configuration settings and other related information, including ARP tables and other communication protocol state tables, of various network element(s) 18 (e.g., servers 14, VMs 29, switches 48, etc.) in network 12. Collection engine 42 may also collect process, established connections, and listening port information from each of endpoints 28 that are to be classified.
The collection process may be repeated for substantially all endpoints 28 in a selected set of VLANs. In addition to collecting configuration information, collection engine 42 may also collect live network flow information from aggregation switches (e.g., 48) in the data center, yielding communication patterns between endpoints 28. In various embodiments, collection engine 42 may automate discovery of and collection of various network parameters (including compute infrastructure) from network 12, allowing the process to scale to handle larger customer deployments consisting of potentially thousands of endpoints 28.
Grouping analysis module 44 may analyze communication patterns amongst endpoints 28 within a selected set of VLANs and classify or group endpoints 28 that are sending or receiving network traffic, based on certain criteria. In various embodiments, grouping analysis module 44 may build (e.g., generate, calculate, determine, etc.) affinity between pairs of endpoints 28 based on a weighted average of multiple factors such as percentage of common flows between endpoints 28 and their peers and percentage of common application instances executing on endpoints 28. Grouping analysis module 44 may group endpoints 28 based on the affinity using an appropriate algorithm, as discussed further herein. In some embodiments, grouping analysis module 44 may sort endpoints 28 in an order (e.g., descending order; ascending order), for example, based on the number of traffic flows they have with their peers. Top talkers within a certain window of time may be selected as seeds and other endpoints 28 within the selected VLANs may be grouped with the seeds based on their affinity values.
In various embodiments, reporting module 46 arranges the grouping results in a user presentable form. The user can view the membership of each EPG 30 of endpoints 28 along with the services being offered and consumed at the group level and can edit the results as necessary. Reporting module 46 may also allow the user to export the results in a form that can be used to configure a software defined networking (SDN) controller (e.g., an SDN controller is a strategic control point in the network, relaying information to the switches/routers ‘below’ (via southbound APIs) and the applications and business logic ‘above’ (via northbound APIs); some of the basic tasks of the SDN controller include inventorying what devices are within the network and the capabilities of each, gathering network statistics, etc.)
In a general sense, embodiments of communication system 10 may use one or more algorithms to identify similarities between endpoints 28, including their communication patterns, calculate affinities, and create EPGs 30 with endpoints 28 having similar functionalities (e.g., in terms of application components). In an example embodiment, for every endpoint 28 in a VLAN subnet, information from network traffic that it receives or generates may be gathered. Based on the gathered information (but excluding well-known and widespread services such as DNS), endpoints 28 may be grouped into EPGs 30. In some embodiments, the grouping may be based on user specified criterion, for example, as a percentage of communication attributes (e.g., traffic attributes, process attributes, socket attributes, etc.). Configurations of switches 48 in network 12 may be analyzed in view of the groupings to generate (or facilitate, as the case may be) access control lists (ACLs) between the groups. Such mechanisms may be extended to other network element(s) 18 such as firewall, load-balancer etc. In some embodiments, aggregate bandwidth specifications may be based on the discovered traffic patterns and groupings. In various embodiments, a user amenable graphical user interface (GUI) to input data, control grouping criteria, etc. may be provided.
According to various embodiments of communication system 10, endpoints 28 that are active in network 12 may be identified, and their relationship (e.g., association, connection, affiliation, etc.) to particular application components may be discovered, thereby defining their membership in a particular EPG 30. It may be assumed that each application 20 is associated to a process running on at least one of endpoints 28. Processes on the endpoint open TCP/UDP ports to services or to consume requests from other endpoints through network 12. For example, server processes open listening ports through OS socket interface for serving requests; client processes open dynamic ports to consume services from other processes. Network conversations indicate endpoints 28 and corresponding ports in communication with each other.
In various embodiments, entity discovery and grouping module 16 may aggregate and categorize multiple conversations and flows in network 12 over a predetermined duration. Collection engine 42 may discover endpoint communications and grouping analysis module 44 may create a peer relationship matrix. The peer relationship matrix may include substantially every endpoint 28 being analyzed, and indicate the type of peer relationship, such as server or client (e.g., associated server endpoints to which the analyzed endpoint is a client of, associated client endpoints to which the analyzed endpoint is a server for). The peer relationship matrix may also indicate packet and/or byte counts transferred over network 12 for each kind of traffic associated with the endpoint being analyzed.
Collection engine 42 may discover processes running on each one of endpoints 28 and create a process matrix. The process matrix can include every endpoint being analyzed and associated processes currently running on each endpoint, associated port numbers being used by the processes to serve requests, associated processes acting as client to a particular server, and other attributes such as user identifier (UID), group identifier (GID) being used to execute the process. Entity discovery and grouping module 16 may use adaptive intelligence to filter out noises that might influence creation of peer relationship matrix and process matrix. Examples of traffic related noise can include non-server traffic (e.g., user traffic), network policy server (NPS) traffic, network time protocol (NTP) traffic, DNS traffic or security vulnerability on the endpoint etc. Examples of process related noise can include virus scan software, various VMWare® tools processes, network management software, etc. In some embodiments, the peer relationship matrix and process matrix may be consolidated into a single endpoint matrix.
Entity discovery and grouping module 16 may calculate the affinity between endpoint 28, for example, based on a weighted average of network affinity, compute affinity, and user specified affinity. Network affinity includes a percentage of server peers and traffic attributes (e.g., octets/packets) that are common between each pair of endpoints 28 in the peer relationship matrix, and a percentage of client peers and traffic attributes that are common between each pair of endpoints 28 in the peer relationship matrix.
Consider that an endpoint, acting as a client, establishes a secure communication session with another endpoint, acting as a server. The server endpoint may store security credentials associated with the client endpoint. Because only the server endpoint would be able to decrypt the client endpoint's messages based on the stored security credentials, the client should contact the particular server endpoint (and not other server endpoints) for subsequent requests, at least while the security arrangement is still valid. That a client should direct subsequent requests to the same server, as described above, is the notion of affinity between the client endpoint and server endpoint. When affinity has been established between the client and server, the server is known as the client's elected server. Establishing affinity may require storing affinity information so that the client can determine which server to contact for its subsequent requests. The affinity information can include any information relating to the affinity relationship, such as the identity of the elected server, and can be stored in many locations, such as in a file system or an HTTP cookie. Furthermore, two client endpoints talking to the same server endpoint may indicate a network affinity between the two client endpoints.
In various embodiments, endpoints 28 may have network-client affinity (e.g., selecting the endpoint as a client) towards certain endpoints, and network-server affinity (e.g., selecting the endpoint as a server) towards certain other endpoints. In an example embodiment, network affinity between two endpoints i and j is computed as follows: network-affinity[i,j]=wni*network-server-affinity[i,j]+wn2*network-client-affinity[i,j], where wni and wag are the weights associated with server and client network affinity values, respectively.
Compute affinity includes a percentage of process and socket attributes (e.g., listening port) that are common between each pair of endpoints 28 in the process matrix. User specified affinity includes a percentage of common attributes between endpoints 28 across network configuration, DNS naming, virtualization attributes, etc. In an example embodiment, affinity between endpoints i and j is computed as follows: affinity [i,j]=wi*network−affinity[i,j]+w2*compute-affinity[i,j]+w3*user-specified-affinity[i,j], where wi, w2, and w3 are the relative weights associated with network, compute and user-specified affinities, respectively.
Based on the affinity calculations, any two endpoints in the peer relationship matrix belong to the same application component if their affinity factor is above the median of its affinity with all other endpoints, and can therefore be placed in the same endpoint group. In an example, assuming the mean to be an affinity threshold value, the following steps may be executed to group endpoints 28: sort endpoints 28 in the peer relationship matrix in an order (e.g., descending order; ascending order) of total number of peers (e.g., server peers and client peers); pick the first endpoint in the matrix as a seed; compare other endpoints in the matrix with the selected seed based on affinity of the other endpoints with the seed. The other endpoints that exceed a pre-selected affinity threshold can be grouped with the seed into a common EPG. Other factors that can influence grouping, such as duplicate Media Access Control (MAC) addresses can also be considered. After all endpoints in the matrix are compared with the seed, all grouped endpoints may be removed from the matrix and the process repeated by picking the first endpoint in the revised matrix as the next seed and comparing it with the remaining ungrouped endpoints, and so on until no endpoints remain to be grouped in the matrix. The grouping results may be subsequently displayed to a user in any suitable manner.
The methodology and apparatus to discover various instances of applications 20 and corresponding application components can be used for a variety of purposes, including for ACI migration. In some embodiments, Cisco's ACI framework may be implemented to provide a variety of benefits in network 12, for example, better application visibility, agility and performance. Because migrating to the ACI infrastructure from a legacy data center architecture (comprising non-ACI infrastructure) can pose a non-trivial challenge. The various operations described herein can automate discovery of application profiles to enable migration from non-ACI infrastructure to ACI enabled infrastructure.
Turning to the infrastructure of communication system 10, the network topology can include any number of computing devices, smartphones, servers, hardware accelerators virtual machines, switches (including distributed virtual switches), routers, and other nodes inter-connected to form a large and complex network. A node may be any electronic device, client, server, peer, service, application, or other object capable of sending, receiving, or forwarding information over communications channels in a network. Elements of
Communication system 10 may include a configuration capable of TCP/IP communications for the electronic transmission or reception of data packets in a network. Communication system 10 may also operate in conjunction with a User Datagram Protocol/Internet Protocol (UDP/IP) or any other suitable protocol, where appropriate and based on particular needs. In addition, gateways, routers, switches, and any other suitable nodes (physical or virtual) may be used to facilitate electronic communication between various nodes in the network.
Note that the numerical and letter designations assigned to the elements of
The example network environment may be configured over a physical infrastructure that may include one or more networks and, further, may be configured in any form including, but not limited to, local area networks (LANs), wireless local area networks (WLANs), VLANs, metropolitan area networks (MANs), VPNs, Intranet, Extranet, any other appropriate architecture or system, or any combination thereof that facilitates communications in a network.
In some embodiments, a communication link may represent any electronic link supporting a LAN environment such as, for example, cable, Ethernet, wireless technologies (e.g., IEEE 802.11x), ATM, fiber optics, etc. or any suitable combination thereof. In other embodiments, communication links may represent a remote connection through any appropriate medium (e.g., digital subscriber lines (DSL), telephone lines, T1 lines, T3 lines, wireless, satellite, fiber optics, cable, Ethernet, etc. or any combination thereof) and/or through any additional networks such as a wide area networks (e.g., the Internet).
In various embodiments, network 12 may comprise an ACI fabric including an Application Policy Infrastructure Controller (APIC), spine switches, and leaf switches that together handle the application of network policy and the delivery of packets. In some embodiments, the fabric may be configured in a leaf-and-spine architecture, with links connecting each leaf to each spine, enabling linear scalability and robust multi-pathing within the fabric, optimized for east-to-west traffic suitable for applications.
The controller including APIC may comprises a clustered network control system, may provide programmability and simplified management. In a general sense, the APIC exposes a northbound API through Extensible Markup Language (XML) and JavaScript Object Notation (JSON) and provides a command-line interface (CLI) and graphical user interface (GUI) that use the API to manage the fabric. The system also provides an open source southbound API, which allows third-party network service vendors to implement policy control for devices through the controller. The APIC is responsible for tasks from fabric activation and switch firmware management to network policy configuration and instantiation.
While the controller can act as the centralized policy and network management engine for the fabric, it may be completely removed from the data path, including the forwarding topology in some embodiments. In such embodiments, the fabric can still forward traffic even when communication with the controller is lost. The controller may be implemented in a separate network appliance, and it can be executed as three or more appliances for performance and availability. In some embodiments, the controller may be modeled on distributed computing to provide scalability and reliability.
In various embodiments, entity discovery and grouping module 16 may comprise a portion of APIC executing in network 12. In other embodiments, entity discovery and grouping module 16 may execute in a separate network element 18 (e.g., server, network appliance) that can interface with the controller and APIC to provide grouping results as appropriate. In some embodiments, substantially all portions of entity discovery and grouping module 16 may execute in a single network element 18; in other embodiments, entity discovery and grouping module 16 may execute in a distributed manner, in a plurality of network element(s) 18 throughout network 12.
In some embodiments, each of application components (e.g., web tier components 22, application tier components 24 and database tier components 26) may represent separate endpoints 28 in network 12. Virtually any suitable network and computing architecture may be used to host and execute application components within the broad scope of the embodiments. Note that forwarding elements 32(1)-32(3) may comprise switches, routers and other network element(s) 18 capable of forwarding packets in a network environment.
In various embodiments, servers 14 may comprise physical servers with single operating system, hosting one or more virtual machines 29. In other embodiments, servers 14 may comprise virtual servers capable of hosting multiple virtual machines 29, each VM having its own unique operating system. In various embodiments, servers 14 may comprise physical or virtual computing devices capable of multiplexing different application software on a single processing platform.
Turning to
Grouping analysis module 44 may at 56 analyze communication patterns among endpoints 28 based on the captured information. Grouping analysis module 44 may at 58 group endpoints 28 based on predefined criteria. In various embodiments, the predefined criteria may be programmed into grouping analysis module 44; in other embodiments, the predefined criteria may be generated from user specified criteria in addition to default criteria, if any. Users may specify the criteria through suitable CLIs or GUIs, as appropriate. Reporting module 46 may, at 60, arrange grouping results in a user presentable form (e.g., amenable to be displayed on a computer screen, or printed out).
Turning to
Turning to
Turning to
Entity discovery and grouping module 16 may discover the various network relationships and process characteristics in network 12 and generate a peer relationship matrix 86 and a process matrix 88. Peer relationship matrix 86 may lay out the network attributes, such as network relationship (server, client, etc.) and traffic (e.g., type, quantity, etc.) between pairs of endpoints 28. In an example embodiment, each endpoint 28 may be listed in rows and columns separately, and the relationship and traffic between pairs of endpoints 28 may be captured in each cell. For example, the cell common to the row for endpoint A and column for endpoint B may indicate that endpoint A has no network traffic with endpoint B; the cell common to the row for endpoint A and column for endpoint C may indicate that endpoint A is a client to endpoint C, and the traffic includes P packets of TCP traffic; and so on. Thus, any non-empty cell may indicate a network affinity between the corresponding endpoints. Moreover, any commonly populated column (e.g., column indicating endpoint C is populated for two rows indicating endpoints A and B) may suggest a network affinity between the corresponding rows (e.g., between endpoints A and B). Note that various other formats may also be used to capture the network attributes of pairs of endpoints in peer relationship matrix 86.
Process matrix 88 may lay out the process attributes that are common between pairs of endpoints 28. For example, the cell common to the row for endpoint A and column for endpoint B may indicate that both endpoints A and B run process 1 on port 80; and so on. Thus, any non-empty cell may indicate a compute affinity between the corresponding endpoints. Note that various other formats may also be used to capture the process attributes of pairs of endpoints in process matrix 88. Note also that various other process attributes may be included in process matrix 88 within the broad scope of the embodiments.
Entity grouping and discovery module 16 may compute affinity 82 between pairs of endpoints 28. For example, affinity 1 may be computed between endpoints A and B; affinity 2 may be computed between endpoints B and C; and affinity 3 may be computed between endpoints A and C. Based on the computed affinities 82, and user specified grouping criteria (e.g., group according to application components), entity discovery and grouping module 16 may group endpoints A and B into a common EPG associated with the web tier component of the particular application; endpoint C may be grouped into a separate EPG associated with the application tier component of the particular application; and so on.
Turning to
At 106, entity discovery and grouping module 16 may discover processes running on endpoints 28 and create process matrix 88, including substantially every endpoint being analyzed and associated processes running on endpoint, associated port numbers being used by the processes to serve requests, associated processes acting as client to a particular server, and other process attributes. At 108, adaptive intelligence algorithms may be used to filter out noises. At 110, network affinity 76, compute affinity 78 and user specified affinity 80 may be calculated. At 112, affinity 82 between pairs of endpoints 28 may be calculated based on weighted average of network affinity 76, compute affinity 78 and user specified affinity 80. At 114, a determination may be made whether affinity 82 is greater than a pre-specified affinity threshold. If affinity 82 is greater than a pre-specified affinity threshold, the pairs of endpoints 28 may be grouped into the same EPG 30 at 116; otherwise, at 118, they may not be grouped into the same EPG 30. At 120, the grouping results may be displayed suitably to the user.
Turning to
Note that in this Specification, references to various features (e.g., elements, structures, modules, components, steps, operations, characteristics, etc.) included in “one embodiment”, “example embodiment”, “an embodiment”, “another embodiment”, “some embodiments”, “various embodiments”, “other embodiments”, “alternative embodiment”, and the like are intended to mean that any such features are included in one or more embodiments of the present disclosure, but may or may not necessarily be combined in the same embodiments. Furthermore, the words “optimize,” “optimization,” and related terms are terms of art that refer to improvements in speed and/or efficiency of a specified outcome and do not purport to indicate that a process for achieving the specified outcome has achieved, or is capable of achieving, an “optimal” or perfectly speedy/perfectly efficient state.
In example implementations, at least some portions of the activities outlined herein may be implemented in software in, for example, network element 18 executing entity discovery and grouping module 16. In some embodiments, one or more of these features may be implemented in hardware, provided external to these elements, or consolidated in any appropriate manner to achieve the intended functionality. The various components (e.g., network element(s) 18, endpoints 28, etc.) may include software (or reciprocating software) that can coordinate in order to achieve the operations as outlined herein. In still other embodiments, these elements may include any suitable algorithms, hardware, software, components, modules, interfaces, or objects that facilitate the operations thereof.
Furthermore, entity discovery and grouping module 16 described and shown herein (and/or their associated structures) may also include suitable interfaces for receiving, transmitting, and/or otherwise communicating data or information in a network environment. Additionally, some of the processors and memory elements associated with the various nodes may be removed, or otherwise consolidated such that a single processor and a single memory element are responsible for certain activities. In a general sense, the arrangements depicted in the FIGURES may be more logical in their representations, whereas a physical architecture may include various permutations, combinations, and/or hybrids of these elements. It is imperative to note that countless possible design configurations can be used to achieve the operational objectives outlined here. Accordingly, the associated infrastructure has a myriad of substitute arrangements, design choices, device possibilities, hardware configurations, software implementations, equipment options, etc.
In some of example embodiments, one or more memory elements (e.g., memory element 38) can store data used for the operations described herein. This includes the memory element being able to store instructions (e.g., software, logic, code, etc.) in non-transitory media, such that the instructions are executed to carry out the activities described in this Specification. A processor can execute any type of instructions associated with the data to achieve the operations detailed herein in this Specification. In one example, processors (e.g., processor 40) could transform an element or an article (e.g., data) from one state or thing to another state or thing. In another example, the activities outlined herein may be implemented with fixed logic or programmable logic (e.g., software/computer instructions executed by a processor) and the elements identified herein could be some type of a programmable processor, programmable digital logic (e.g., a field programmable gate array (FPGA), an erasable programmable read only memory (EPROM), an electrically erasable programmable read only memory (EEPROM)), an ASIC that includes digital logic, software, code, electronic instructions, flash memory, optical disks, CD-ROMs, DVD ROMs, magnetic or optical cards, other types of machine-readable mediums suitable for storing electronic instructions, or any suitable combination thereof.
These devices may further keep information in any suitable type of non-transitory storage medium (e.g., random access memory (RAM), read only memory (ROM), field programmable gate array (FPGA), erasable programmable read only memory (EPROM), electrically erasable programmable ROM (EEPROM), etc.), software, hardware, or in any other suitable component, device, element, or object where appropriate and based on particular needs. The information being tracked, sent, received, or stored in communication system 10 could be provided in any database, register, table, cache, queue, control list, or storage structure, based on particular needs and implementations, all of which could be referenced in any suitable timeframe. Any of the memory items discussed herein should be construed as being encompassed within the broad term ‘memory element.’ Similarly, any of the potential processing elements, modules, and machines described in this Specification should be construed as being encompassed within the broad term ‘processor.’
It is also important to note that the operations and steps described with reference to the preceding FIGURES illustrate only some of the possible scenarios that may be executed by, or within, the system. Some of these operations may be deleted or removed where appropriate, or these steps may be modified or changed considerably without departing from the scope of the discussed concepts. In addition, the timing of these operations may be altered considerably and still achieve the results taught in this disclosure. The preceding operational flows have been offered for purposes of example and discussion. Substantial flexibility is provided by the system in that any suitable arrangements, chronologies, configurations, and timing mechanisms may be provided without departing from the teachings of the discussed concepts.
Although the present disclosure has been described in detail with reference to particular arrangements and configurations, these example configurations and arrangements may be changed significantly without departing from the scope of the present disclosure. For example, although the present disclosure has been described with reference to particular communication exchanges involving certain network access and protocols, communication system 10 may be applicable to other exchanges or routing protocols. Moreover, although communication system 10 has been illustrated with reference to particular elements and operations that facilitate the communication process, these elements, and operations may be replaced by any suitable architecture or process that achieves the intended functionality of communication system 10.
Numerous other changes, substitutions, variations, alterations, and modifications may be ascertained to one skilled in the art and it is intended that the present disclosure encompass all such changes, substitutions, variations, alterations, and modifications as falling within the scope of the appended claims. In order to assist the United States Patent and Trademark Office (USPTO) and, additionally, any readers of any patent issued on this application in interpreting the claims appended hereto, Applicant wishes to note that the Applicant: (a) does not intend any of the appended claims to invoke paragraph six (6) of 35 U.S.C. section 112 as it exists on the date of the filing hereof unless the words “means for” or “step for” are specifically used in the particular claims; and (b) does not intend, by any statement in the specification, to limit this disclosure in any way that is not otherwise reflected in the appended claims.
This application is a continuation of U.S. Non-Provisional patent application Ser. No. 17/026,654, filed on Sep. 21, 2020, which in turn, is a continuation of U.S. Non-Provisional patent application Ser. No. 15/686,445, filed Aug. 25, 2017, which in turn, is a continuation U.S. Non-Provisional patent application Ser. No. 14/516,354, filed Oct. 16, 2014, the disclosures of which are incorporated herein by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
5204829 | Lyu et al. | Apr 1993 | A |
6539483 | Harrison et al. | Mar 2003 | B1 |
6763380 | Mayton et al. | Jul 2004 | B1 |
7003562 | Mayer | Feb 2006 | B2 |
7089369 | Emberling | Aug 2006 | B2 |
7127686 | Dreschler et al. | Oct 2006 | B2 |
7360064 | Steiss et al. | Apr 2008 | B1 |
7453886 | Allan | Nov 2008 | B1 |
7505463 | Schuba et al. | Mar 2009 | B2 |
7548967 | Amyot et al. | Jun 2009 | B2 |
7552201 | Areddu et al. | Jun 2009 | B2 |
7609647 | Turk et al. | Oct 2009 | B2 |
7619989 | Guingo et al. | Nov 2009 | B2 |
7698561 | Nagendra et al. | Apr 2010 | B2 |
7743274 | Langford et al. | Jun 2010 | B2 |
7765093 | Li et al. | Jul 2010 | B2 |
8010952 | Datla et al. | Aug 2011 | B2 |
8073935 | Viswanath | Dec 2011 | B2 |
8103480 | Korn et al. | Jan 2012 | B2 |
8190719 | Furukawa | May 2012 | B2 |
8209738 | Nicol et al. | Jun 2012 | B2 |
8261116 | Palmer | Sep 2012 | B2 |
8261339 | Aldridge et al. | Sep 2012 | B2 |
8312261 | Rao et al. | Nov 2012 | B2 |
8375117 | Venable, Sr. | Feb 2013 | B2 |
8441941 | McDade et al. | May 2013 | B2 |
8479267 | Donley et al. | Jul 2013 | B2 |
8484693 | Cox et al. | Jul 2013 | B2 |
8494977 | Yehuda et al. | Jul 2013 | B1 |
8554883 | Sankaran | Oct 2013 | B2 |
8589934 | Makljenovic et al. | Nov 2013 | B2 |
8621284 | Kato | Dec 2013 | B2 |
8627328 | Mousseau et al. | Jan 2014 | B2 |
8693344 | Adams et al. | Apr 2014 | B1 |
8693374 | Murphy et al. | Apr 2014 | B1 |
8761036 | Fulton et al. | Jun 2014 | B2 |
8782182 | Chaturvedi et al. | Jul 2014 | B2 |
8824482 | Kajekar et al. | Sep 2014 | B2 |
8874705 | Satish | Oct 2014 | B1 |
8910143 | Cohen et al. | Dec 2014 | B2 |
8914843 | Bryan et al. | Dec 2014 | B2 |
8924798 | Jerde et al. | Dec 2014 | B2 |
9019840 | Salam et al. | Apr 2015 | B2 |
9038151 | Chua et al. | May 2015 | B1 |
9055000 | Ghosh et al. | May 2015 | B1 |
9106555 | Agarwal et al. | Jun 2015 | B2 |
9137096 | Yehuda et al. | Sep 2015 | B1 |
9225601 | Khurshid et al. | Dec 2015 | B2 |
9246818 | Deshpande et al. | Jan 2016 | B2 |
9264922 | Gillot et al. | Feb 2016 | B2 |
9276877 | Chua et al. | Mar 2016 | B1 |
9319300 | Huynh Van et al. | Apr 2016 | B2 |
9344348 | Ivanov et al. | May 2016 | B2 |
9369434 | Kim et al. | Jun 2016 | B2 |
9389993 | Okmyanskiy et al. | Jul 2016 | B1 |
9397946 | Yadav | Jul 2016 | B1 |
9405553 | Branson et al. | Aug 2016 | B2 |
9444842 | Porras et al. | Sep 2016 | B2 |
9497207 | Dhawan et al. | Nov 2016 | B2 |
9497215 | Vasseur et al. | Nov 2016 | B2 |
9544224 | Chu et al. | Jan 2017 | B2 |
9548965 | Wang et al. | Jan 2017 | B2 |
9553845 | Talmor et al. | Jan 2017 | B1 |
9571502 | Basso et al. | Feb 2017 | B2 |
9571523 | Porras et al. | Feb 2017 | B2 |
9594640 | Chheda | Mar 2017 | B1 |
9596141 | McDowall | Mar 2017 | B2 |
9641249 | Kaneriya et al. | May 2017 | B2 |
9654300 | Pani | May 2017 | B2 |
9654361 | Vasseur et al. | May 2017 | B2 |
9654409 | Yadav et al. | May 2017 | B2 |
9660886 | Ye et al. | May 2017 | B1 |
9660897 | Gredler | May 2017 | B1 |
9667645 | Belani et al. | May 2017 | B1 |
9680875 | Knjazihhin et al. | Jun 2017 | B2 |
9686180 | Chu et al. | Jun 2017 | B2 |
9686296 | Murchison et al. | Jun 2017 | B1 |
9690644 | Anderson et al. | Jun 2017 | B2 |
9781004 | Danait et al. | Oct 2017 | B2 |
9787559 | Schroeder | Oct 2017 | B1 |
9998247 | Choudhury et al. | Jun 2018 | B1 |
10084795 | Akireddy et al. | Sep 2018 | B2 |
10084833 | McDonnell et al. | Sep 2018 | B2 |
10084895 | Kasat et al. | Sep 2018 | B2 |
20020143855 | Traversat | Oct 2002 | A1 |
20020178246 | Mayer | Nov 2002 | A1 |
20030229693 | Mahlik et al. | Dec 2003 | A1 |
20040073647 | Gentile et al. | Apr 2004 | A1 |
20040168100 | Thottan et al. | Aug 2004 | A1 |
20050108389 | Kempin et al. | May 2005 | A1 |
20070011629 | Shacham et al. | Jan 2007 | A1 |
20070124437 | Chervets | May 2007 | A1 |
20070214244 | Hitokoto et al. | Sep 2007 | A1 |
20080031147 | Fieremans et al. | Feb 2008 | A1 |
20080117827 | Matsumoto et al. | May 2008 | A1 |
20080133731 | Bradley | Jun 2008 | A1 |
20080172716 | Talpade et al. | Jul 2008 | A1 |
20080320438 | Funto | Dec 2008 | A1 |
20090240758 | Pasko | Sep 2009 | A1 |
20090249284 | Antosz et al. | Oct 2009 | A1 |
20100191612 | Raleigh | Jul 2010 | A1 |
20100198909 | Kosbab et al. | Aug 2010 | A1 |
20110093612 | Murakami | Apr 2011 | A1 |
20110295983 | Medved et al. | Dec 2011 | A1 |
20120054163 | Iu et al. | Mar 2012 | A1 |
20120198073 | Srikanth et al. | Aug 2012 | A1 |
20120297061 | Pedigo et al. | Nov 2012 | A1 |
20130097660 | Das et al. | Apr 2013 | A1 |
20130191516 | Sears | Jul 2013 | A1 |
20130290238 | Griffith et al. | Oct 2013 | A1 |
20140019597 | Nath et al. | Jan 2014 | A1 |
20140177638 | Bragg et al. | Jun 2014 | A1 |
20140222996 | Vassuer et al. | Aug 2014 | A1 |
20140304831 | Hidlreth | Oct 2014 | A1 |
20140307556 | Zhang | Oct 2014 | A1 |
20140321277 | Lynn, Jr. et al. | Oct 2014 | A1 |
20140379915 | Yang et al. | Dec 2014 | A1 |
20150019756 | Masuda | Jan 2015 | A1 |
20150113143 | Stuart et al. | Apr 2015 | A1 |
20150124826 | Edsall et al. | May 2015 | A1 |
20150186206 | Battacharya et al. | Jul 2015 | A1 |
20150234695 | Cuthbert et al. | Aug 2015 | A1 |
20150244617 | Nakil et al. | Aug 2015 | A1 |
20150271104 | Chikkamath et al. | Sep 2015 | A1 |
20150295771 | Cuni et al. | Oct 2015 | A1 |
20150365314 | Hiscock et al. | Dec 2015 | A1 |
20150381484 | Hira et al. | Dec 2015 | A1 |
20160020993 | Wu et al. | Jan 2016 | A1 |
20160021141 | Liu et al. | Jan 2016 | A1 |
20160026631 | Salam et al. | Jan 2016 | A1 |
20160036636 | Erickson et al. | Feb 2016 | A1 |
20160048420 | Gourlay et al. | Feb 2016 | A1 |
20160078220 | Scharf et al. | Mar 2016 | A1 |
20160080350 | Chaturvedi et al. | Mar 2016 | A1 |
20160099883 | Voit et al. | Apr 2016 | A1 |
20160105317 | Zimmermann et al. | Apr 2016 | A1 |
20160112246 | Singh et al. | Apr 2016 | A1 |
20160112269 | Singh et al. | Apr 2016 | A1 |
20160149751 | Pani et al. | May 2016 | A1 |
20160164748 | Kim | Jun 2016 | A1 |
20160224277 | Batra et al. | Aug 2016 | A1 |
20160241436 | Fourie et al. | Aug 2016 | A1 |
20160254964 | Benc | Sep 2016 | A1 |
20160267384 | Salam et al. | Sep 2016 | A1 |
20160323319 | Gourlay et al. | Nov 2016 | A1 |
20160330076 | Tiwari et al. | Nov 2016 | A1 |
20160352566 | Mekkattuparamnhan et al. | Dec 2016 | A1 |
20160359697 | Scheib et al. | Dec 2016 | A1 |
20160380892 | Mahadevan et al. | Dec 2016 | A1 |
20170026292 | Smith et al. | Jan 2017 | A1 |
20170031800 | Shani et al. | Feb 2017 | A1 |
20170031970 | Burk | Feb 2017 | A1 |
20170048110 | Wu et al. | Feb 2017 | A1 |
20170048126 | Handige Shankar et al. | Feb 2017 | A1 |
20170054758 | Maino et al. | Feb 2017 | A1 |
20170063599 | Wu et al. | Mar 2017 | A1 |
20170093630 | Foulkes | Mar 2017 | A1 |
20170093664 | Lynam et al. | Mar 2017 | A1 |
20170093750 | McBride et al. | Mar 2017 | A1 |
20170093918 | Banerjee et al. | Mar 2017 | A1 |
20170111259 | Wen et al. | Apr 2017 | A1 |
20170118167 | Subramanya et al. | Apr 2017 | A1 |
20170126740 | Bejarano et al. | May 2017 | A1 |
20170126792 | Halpern et al. | May 2017 | A1 |
20170134233 | Dong et al. | May 2017 | A1 |
20170163442 | Shen et al. | Jun 2017 | A1 |
20170187577 | Nevrekar et al. | Jun 2017 | A1 |
20170195187 | Bennett et al. | Jul 2017 | A1 |
20170206129 | Yankilevich et al. | Jul 2017 | A1 |
20170222873 | Lee et al. | Aug 2017 | A1 |
20170353355 | Danait et al. | Dec 2017 | A1 |
20180069754 | Dasi et al. | Mar 2018 | A1 |
20180167294 | Gupta et al. | Jun 2018 | A1 |
20180309629 | Mohanram et al. | Oct 2018 | A1 |
20180367412 | Sethi et al. | Dec 2018 | A1 |
Number | Date | Country |
---|---|---|
105471830 | Apr 2016 | CN |
105721193 | Jun 2016 | CN |
105721297 | Jun 2016 | CN |
106130766 | Nov 2016 | CN |
106603264 | Apr 2017 | CN |
103701926 | Jun 2017 | CN |
2015014177 | Feb 2015 | WO |
2015187337 | Dec 2015 | WO |
2016011888 | Jan 2016 | WO |
2016039730 | Mar 2016 | WO |
3026072996 | May 2016 | WO |
2016085516 | Jun 2016 | WO |
2016093861 | Jun 2016 | WO |
2016119436 | Aug 2016 | WO |
2016130108 | Aug 2016 | WO |
2016161127 | Oct 2016 | WO |
2017031922 | Mar 2017 | WO |
2017039606 | Mar 2017 | WO |
2017105452 | Jun 2017 | WO |
Entry |
---|
“Cisco Application Centric Infrastructure 9ACI) Endpoint Groups (EPG) Usage and Design,” White Paper, Cisco Systems, Inc., May 2014, pp. 1-14. |
Akella, Aditya, et al., “A Highly Available Software Defined Fabric,” HotNets-XIII, Oct. 27-28, 2014, Los Angeles, CA, USA, Copyright 2014, ACM, pp. 1-7. |
Alsheikh, Mohammad Abu, et al., “Machine Learning in Wireless Sensor Networks: Algorithms, Strategies, and Application,” Mar. 19, 2015, pp. 1-23. |
Author Unknown, “Aids to Pro-active Management of Distributed Resources through Dynamic Fault-Localization and Availability Prognosis,” FaultLocalization-TR01-CADlab, May 2006, pp. 1-9. |
Author Unknown, “Requirements for applying formal methods to software-defined networking,” Telecommunication Standardization Sector of ITU, Series Y: Global Information Infrastructure, Internet Protocol Aspects and Next-Generation Networks, Apr. 8, 2015, pp. 1-20. |
Cisco Systems, Inc., “The Cisco Application Policy Infrastructure Controller Introduction: What is the Cisco Application Policy Infrastructure Controller?” Jul. 31, 2014, 19 pages. |
Cisco, “Verify Contracts and Rules in the ACI Fabric,” Cisco, Updated Aug. 19, 2016, Document ID: 119023, pp. 1-20. |
De Silva et al., “Network-wide Security Analysis,” Semantic Scholar, Oct. 25, 2011, pp. 1-11. |
Dhawan, Mohan, et al., “SPHINX: Detecting Security Attacks in Software-Defined Networks,” NDSS 2015, Feb. 8-11, 2015, San Diego, CA, USA, Copyright 2015 Internet Society, pp. 1-15. |
Fayaz, Seyed K., et al., “Efficient Network Reachability Analysis using a Succinct Control Plane Representation,” 2016, ratul.org, pp. 1-16. |
Feldmann, Anja, et al., “IP Network Configuration for Intradomain Traffic Engineering,” Semantic Scholar, accessed on Jul. 20, 2017, pp. 1-27. |
Han, Wonkyu, et al., “LPM: Layered Policy Management for Software-Defined Networks,” Mar. 8, 2016, pp. 1-8. |
Han, Yoonseon, et al., “An Intent-based Network Virtualization Platform for SDN,” 2016 | FIP, pp. 1-6. |
Jain, Praveen, et al., “In-Line Distributed and Stateful Security Policies for Applications in a Network Environment,” Cisco Systems, Inc., Aug. 16, 2016, 13 pages. |
Kazemian, Peyman, et al., “Real Time Network Policy Checking using Header Space Analysis,” USENIX Association, 10th USENIX Symposium on Networked Systems Design and Implementation 2013 (NSDI '13) pp. 99-111. |
Khatkar, Pankaj Kumar, “Firewall Rule Set Analysis and Visualization, A Thesis Presented in Partial Fulfillment of the Requirements for the Degree Master of Science,” Arizona State University, Dec. 2014, pp. 1-58. |
Le, Franck, et al., “Minerals: Using Data Mining to Detect Router Misconfigurations,” CyLab, Carnegie Mellon University, CMU-CyLab-06-008, May 23, 2006, pp. 1-14. |
Liang, Chieh-Jan Mike, et al., “SIFT: Building an Internet of Safe Things,” Microsoft, IPSN' 15, Apr. 14-16, 2015, Seattle, WA, ACM 978, pp. 1-12. |
Lindem, A., et al., “Network Device YANG Organizational Model draft-rtgyangdt-rtgwg-device-model-01,” Network Working Group, Internet-draft, Sep. 21, 2015, pp. 1-33. |
Liu, Jason, et al., “A Real-Time Network Simulation Infrastracture Based on Open VPN,” Journal of Systems and Software, Aug. 4, 2008, pp. 1-45. |
Lopes, Nuno P., et al., “Automatically verifying reachability and well-formedness in P4 Networks,” Microsoft, accessed on Jul. 18, 2017, pp. 1-13. |
Mai, Haohui, et al., “Debugging the Data Plane with Anteater,” SIGCOMM11, Aug. 15-19, 2011, pp. 1-12. |
Maldonado-Lopez, Ferney, et al., “Detection and prevention of firewall-rule conflicts on software-defined networking,” 2015 7th International Workshop on Reliable Networks Design and Modeling (RNDM), IEEE, Oct. 5, 2015, pp. 259-265. |
Miller, Nancy, et al., “Collecting Network Status Information for Network-Aware Applications,” INFOCOM 2000, pp. 1-10. |
Miranda, Joao Sales Henriques, “Fault Isolation in Software Defined Networks,” www.gsd.inescid.pt, 2016, pp. 1-10. |
Moon, Daekyeong, et al., “Bridging the Software/Hardware Forwarding Divide,” Berkeley.edu, Dec. 18, 2010, pp. 1-15. |
Panda, Aurojit, et al., “SCL: Simplifying Distributed SDN Control Planes,” people.eecs.berkeley.edu, Mar. 2017, pp. 1-17. |
Shin, Seugwon, et al., “FRESCO: Modular Composable Security Services for Software-Defined Networks,” To appear in the ISOC Network and Distributed System Security Symposium, Feb. 2013, pp. 1-16. |
Shukla, Apoorv, et al., “Towards meticulous data plane monitoring,” kaust.edu.sa, accessed on Aug. 1, 2017, pp. 1-2. |
Tang, Yongning, et al., “Automatic belief network modeling via policy inference for SDN fault localization,” Journal of Internet Services and Applications, 2016, pp. 1-13. |
Tomar, Kuldeep, et al., “Enhancing Network Security and Performance Using Optimized ACLs,” International Journal in Foundations of Computer Science & Technology (IJFCST), vol. 4, No. 6, Nov. 2014, pp. 25-35. |
Tongaonkar, Alok, et al., “Inferring Higher Level Policies from Firewall Rules,” Proceedings of the 21st Large Installation System Administration Conference (LISA '07), Nov. 11-16, 2007, pp. 1-14. |
Vega, Andres, et al., “Troubleshooting Cisco Application Centric Infrastructure: Analytical problem solving applied to the Policy Driven Data Center,” Feb. 15, 2016, 84 pages. |
Kia, Wenfeng, et al., “A Survey on Software-Defined Networking,” IEEE Communications Surveys and Tutorials, Mar. 16, 2015, pp. 27-51. |
Yu et al., “A Flexible Framework for Wireless-Based Intelligent Sensor with Reconfigurability, Dynamic adding, and Web interface,” Conference Paper, Jul. 24, 2006, IEEE 2006, pp. 1-7. |
Zhou, Shijie, et al., “High-Performance Packet Classification on GPU,” 2014 IEEE, pp. 1-6. |
Number | Date | Country | |
---|---|---|---|
20230020431 A1 | Jan 2023 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17026654 | Sep 2020 | US |
Child | 17936241 | US | |
Parent | 15686445 | Aug 2017 | US |
Child | 17026654 | US | |
Parent | 14516354 | Oct 2014 | US |
Child | 15686445 | US |