Technical Field
The present disclosure relates to mobile data analytics, and more specifically to configuration of rules in a network visibility system.
Related Art
Network visibility systems are designed for facilitating analysis of data traffic flows by analytic servers for aspects such as performance and usage patterns. Network visibility systems may contain forwarding rules, which are designed to determine the specific analytical server to which each of the packets constituting the data traffic are forwarded to for further analysis.
The forwarding rules may be designed to ensure appropriate grouping of packets for forwarding of specific group of packets to individual one of the analytical servers such that related packets may be analyzed for meaningful patterns.
Aspects of the present disclosure relate to configuration of such forwarding rules in a network visibility system.
Example embodiments of the present disclosure will be described with reference to the accompanying drawings briefly described below.
In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements. The drawing in which an element first appears is indicated by the leftmost digit(s) in the corresponding reference number.
Aspects of the present disclosure enable a router controller to maintain a default rules table indicating allocation of IP addresses (of GTP packets) to respective output ports. In an embodiment, the router controller receives information indicating the respective tunnel endpoint IP addresses of a control session and a data session of a user. The router controller is configured to determine whether such IP addresses of the control session and the data session(s) are allocated to the same output port. If the IP addresses of the control session and the data session are not allocated to the same output port, router controller is configured to generate a dynamic rule to force packets of both the control session and the data session to the same output port.
In an embodiment, the control session and the data session are created on a 4G/LTE network containing a Mobility Management Entity (MME), a Serving Gateway (SGW) and an eNodeB, The control session is established between the MME and a first interface of the SGW, and the data session is established between the eNodeB and a second interface of the SGW, with the data session terminating at a second tunnel endpoint having second TEID (tunnel endpoint identifier) at the second interface. In addition, the first IP address is at the first interface and the second IP address is at the second interface. Assuming that the default table maps the first IP address to a first output port and the second IP address to a second output port, the dynamic rule operates to force packets of the second IP address and the second TEID to the first output port.
In another embodiment, the control session and the data session are created on a 3G network, containing an SGSN and a GGSN in a path from a user equipment to Internet. The GGSN contains a first interface and a second interface communicatively coupled to the SGSN, with the first interface and the second interface being respectively assigned the first IP address and the second IP address. The control session is established to terminate at the first IP address, and the data session is established to terminate with a second TEID at the second IP address. Assuming that the default table maps the first IP address to a first output port and the second IP address to a second output port, the dynamic rule operates to force packets of the second IP address and the second TEID to the first output port.
Several aspects of the present disclosure are described below with reference to examples for illustration. However, one skilled in the relevant art will recognize that the disclosure can be practiced without one or more of the specific details or with other methods, components, materials and so forth. In other instances, well-known structures, materials, or operations are not shown in detail to avoid obscuring the features of the disclosure. Furthermore, the features/aspects described can be practiced in various combinations, though only some of the combinations are described herein for conciseness.
General Packet Radio Service (GPRS) is a standard for wireless communications that enables data to be transmitted at speeds up to 115 kilobits per second, compared with Global System for Mobile Communications (GSM) systems' 9.6 kilobits per second. GPRS supports a wide range of bandwidths and thus is suitable for sending and receiving small bursts of data (e.g., e-mail, Web browsing data) as well as larger volumes of data (e.g., video streams, file downloads).
GPRS Tunneling Protocol (GTP) is a group of Internet Protocol (IP)-based communications protocols used to carry packets conforming to the GPRS standard within GSM, UMTS and LTE networks. GTP can be decomposed into a number of separate protocols, including GTP-C and GTP-U. In 3G and 4G/LTE wireless networks, GTP-C messages are control messages that are used between network elements to activate and de-activate sessions originating from mobile user endpoints. As an example, in 3G networks, GTP-C is used within a GPRS core network for signaling between gateway GPRS support nodes (GGSN) and serving GPRS support nodes (SGSN).
This allows the SGSN to activate a session on a user's behalf, deactivate the same session, adjust quality of service parameters, or update a session for a subscriber who has just arrived from another SGSN. GTP-U is used for carrying user data within a GPRS core network and between a radio access network and the core network. The user data transported can be packets in any of IPv4, IPv6, or Point-to-Point Protocol (PPP) formats.
For various reasons, an operator of a wireless telecommunication network, such as a 3G or 4G/LTE network, may be interested in analyzing traffic flows within the network. For instance, the operator may want to collect and analyze flow information for network management or business intelligence/reporting. Alternatively or in addition, the operator may want to monitor traffic flows in order to, e.g., detect and thwart malicious network attacks.
To facilitate these and other types of analyses, the operator can implement a network telemetry, or “visibility,” system, such as system 100 shown in
In the example of
Router controller 104 (which may be implemented using, e.g., a blade(s)/server computer system, such as an x86 server) can be considered part of the control plane of network visibility system 100 and is generally responsible for determining, based on a mirrored stream of GTP-C traffic sent from packet router 102 via path 112, forwarding rules on behalf of packet router 102. Once these forwarding rules have been formed, router controller 104 can program the rules into packet router 102's tables (via path 112) so that packet router 102 can forward network traffic to analytic servers 110-1 to 110-P according to customer (e.g., network operator) requirements.
While packet router 102 and router controller 104 are shown as separate systems (implying implementation based on corresponding separate hardware components), it should be appreciated that alternative embodiments can be implemented in other configurations, as will be apparent to one skilled in the relevant arts by reading the disclosure provided herein. For example, packet router 102 and router controller 104 may be implemented (with suitable modifications) as respective virtual machines realized on one or more physical machines. In such embodiments, the physical ports (both input and output) of
It may be generally appreciated that the packets constituting the network traffic need to be tapped from desired tap points from the networks of interest such that the necessary data packets and control packets are provided to network visibility system 100. The network tap points in respective example implementations of 3G and 4G networks are briefly noted below. It should be appreciated that at least some of the features of the present disclosure can be implemented in the context of future generation mobile networks as well.
The general operation of the components of
Broadly, user equipment 201-202 (e.g., mobile phones, tablet computers) access Internet via NBs (e.g., cell towers or base stations) 210-1 and 210-2, which provides wireless communication facility to the user equipment. RNC 220-1 provides various radio resource management functions, in addition to providing for encryption of data sent to the user equipment and decryption of data received from user equipment.
SGSN 230-1 processes the packet switched data received on GPRS, and provides the mobility management functions (in addition to authentication of users). GGSN 240-1 provides interworking between the GPRS network and external packet switched networks, such as Internet 260. NAT 250-1 provides network address translation (NAT) functions for packets being transmitted and received, in a known way.
It may be appreciated that each user equipment (such as 201/202) can have multiple sessions for sending and receiving data (e.g., one for video, another for Internet access data, yet another for telephony functions). The data corresponding to each session may be carried in the form of a corresponding tunnel in each of the two hops RNC-SGSN, SGSN-GGSN. The corresponding packet format is depicted in
The IP packet in the wireless path between UE and NB, between the NB and the RNC, and between GGSN and NAT is transmitted in its native form (instead of being encapsulated by tunnel headers). In other words, the packets transmitted on these paths would contain only native packet 281 (but not tunnel header 291). Such native IP packets are referred to as non-GTP packets in the description herein.
Tunnel endpoint identifiers (TEIDs) are allocated on activation of a GTP tunnel. Each network element involved in a tunnel (sender/receiver) signals to the opposing node in the flow from which it wishes to receive subsequent messages, its TEID and its IP address. When the respective combination of TEID and IP address is passed by each end element of a tunnel with the element of the other end, the tunnel is said to be formed. Each tunnel endpoint is thus uniquely represented by the combination of the TEID and the associated IP address.
Initially, when user equipment 201 requests a session to be created, a control session and a data session (to exchange data) are established between the SGSN 230-1 and GGSN 240-1, initiated by the SGSN 230-1. Data received thereafter at GGSN 240-1 destined to the user equipment 201, is transferred on the data session thus formed between SGSN 230-1 and GGSN 240-1. The sessions' tunnels will have a corresponding TEID and IP address (i.e., tunnel endpoints) associated with each of the two elements of the tunnel. More than one data session can be formed to exchange data between SGSN 230-1 and GGSN 240-1.
Packets are shown being tapped on paths between respective pairs of network elements, with each pair containing an SGSN and a GGSN, coupled by a path. The tapped data is provided via path 162 to packet router 102. As may be appreciated, the tunnel outer header 291 would contain the IP addresses of the GGSN and SGSN. While only one path is described for conciseness, the components in the remaining paths would operate similarly.
It should be appreciated that network visibility system 100 may analyze packets related to many hundreds or thousands of such GGSN-SGSN pairs. Further, although not shown in
Broadly, user equipment 301-302 (e.g., mobile phones, tablet computers) access Internet via ENB (e.g., cell tower or base station) 310-1, which provides wireless communication facility to the user equipment. The pair of SGW 320-1 and PGW 330-1 operates in the data plane, implying the user data is transported by the pair in both directions. PGW 330-1 provides interworking between the 4G network and external packet switched networks, such as Internet 360. In particular, PGW 330-1 allocates IP addresses to the user equipment during setup of the connection, and also provides filtering of the user data. NAT 340-1 provides network address translation (NAT) functions for packets being transmitted and received, in a known way.
MME 350-1 operates in the control plane providing control/signaling functions related to, for example, mobility and security. HSS 360-1 is a database storing user-related information, which is used for supporting functions in mobility management, call and session setup, user authentication and access authorization.
Similar to the 3G network, TEIDs in 4G/LTE networks are allocated on activation of a GTP tunnel. Each network element involved in a tunnel (sender or receiver) signals to the opposing node in the flow with which it wishes to receive subsequent messages, its TEID and its IP address. When the pair of TEIDs and IP addresses between the two network elements is exchanged, a tunnel is said to be formed. It may be appreciated that the packet format is similar to that shown in
Initially, when user equipment 301 requests a session to be created, a control session is established between the MME 350-1 and SGW 320-1, initiated by MME 350-1. Thereafter, a data session (or more than one data sessions) is formed between ENB 310-1 and SGW 320-1 to exchange data. Similarly, when data is received at SGW 320-1 destined to the user equipment 301, a data session (or more than one data sessions) is established between SGW 320-1 and ENB 310-1, initiated by SGW 320-1 via MME 350-1. The sessions' tunnels will have a corresponding TEID and IP address (i.e., tunnel endpoints) associated with each of the two network element pairs of the tunnel. While only one path is described for conciseness, the components in the remaining paths would operate similarly.
Various packets are shown being tapped on paths between respective pair of ENB and SGW, as well as between respective pairs of MME and SGW, and provided via path 182 to packet router 102. Again, although not shown in
Thus, the packets captured at the various network tap points depicted in
In an embodiment of the present disclosure, formation of the forwarding rules may require various IP addresses operative in relation to networks 106 and 108. In one prior approach, administrators may be required to provide such IP addresses manually, which may lead to undesirable situations such as errors and undesirable overheads. An aspect of the present disclosure simplifies identification of the IP addresses in network visibility systems.
In addition, some of the steps may be performed in a different sequence than that depicted below, as suited to the specific environment, as will be apparent to one skilled in the relevant arts. Many of such implementations are contemplated to be covered by several aspects of the present disclosure. The flow chart begins in step 401, in which control immediately passes to step 410.
In step 410, router controller 104 receives IP packets tapped from networks 106/108. In an embodiment described herein, the packets include GTP packets and native (i.e., without being tunneled) IP packets, though other packets can be tapped and received as suited according to corresponding analysis approach. Control then passes to step 415.
In step 415, router controller 104 discovers (learns) IP addresses of various network nodes in networks 106/108 by examining the fields of interest in the corresponding communication packets. A network node refers to any processing device that operates at the network/IP level, implying that the device has an assigned IP address using which packets are received and sent in accordance with the IP protocol. As is well known in the relevant arts, an IP address uniquely identifies the corresponding machine to which the address is assigned. In IPV4, each IP address contains 32-bits. Control then passes to step 420.
In step 420, router controller 104 configures packet router 102 using the discovered IP addresses. As a result, packet router 102 forwards the subsequently received IP packets to respective analytic servers 110-1 to 110-P, as configured by router controller 104. Control then passes to step 429, in which the flow chart ends.
Due to such reliance on discovery based on received packets, the desired IP addresses may all be accurately identified, thereby at least avoiding the overheads and error possibilities, noted above with the manual approach, in addition to ensuring reliable analysis of the related packets in analytic servers 110-1 to 110-P. Reliable formation of forwarding rules by router controller 104 is thus simplified.
The manner in which the features noted above with respect to
In an embodiment of the present disclosure, each analytics server is designed to analyze all packets (control and data) related to a single user equipment (UE), i.e., related to a single IMSI (International Mobile Subscriber Identity). However, as many forwarding rules are based on addresses of network nodes and as each network node (or link between nodes) is shared for transferring packets related to multiple UEs, forwarding rules based merely on IP addresses of network nodes may present conflicts with the requirement of analyzing all packets related to a single UE by a single analytics server.
Accordingly, it would be desirable to have techniques that enable router controller 104 to configure dynamic filters that group packets originating from the same user (also known as a “subscriber”), across various data and control sessions, even though the packets may have different associated IP addresses (i.e., tunnel endpoint IP addresses). Several aspects of the present disclosure enable a router controller to specify rules for grouping the data traffic forwarded to analytic servers 110 in a user-centric manner, as described below in further detail.
In addition, some of the steps may be performed in a different sequence than that depicted below, as suited to the specific environment, as will be apparent to one skilled in the relevant arts. Many of such implementations are contemplated to be covered by several aspects of the present disclosure. The flow chart begins in step 431, in which control immediately passes to step 440.
In step 440, router controller 104 maintains a default rules table specifying allocation of IP addresses to respective output ports. The IP addresses are of the tunnel endpoints of various sessions maintained related to providing connectivity for user equipment. In case of 4G/LTE network 108, the IP addresses are of various SGWs and eNBs shown in
In step 445, router controller 104 receives control information indicating the respective tunnel endpoint IP addresses for a control session and a data session. In an embodiment, the control information may be received as part of one or more control packets received from the 3G or 4G networks. Specifically, in case of 4G/LTE network, the control packets are received from the tap point on the link between respective pair of MME and SGW. In case of 3G network, the control packets are received from the tap point on the link between respective pairs of SGSN and GGSN.
In step 450, router controller 104 determines whether the IP addresses of the control session and the data session are allocated to the same output port. If yes, control moves to step 445. If, per step 450, the (endpoint) IP addresses of the control session and the data session are not allocated to the same output port, control moves to step 460.
In step 460, router controller 104 configures a dynamic rule to force packets of both the control session and the data session to the same output port. The dynamic rules may be implemented in one of several known ways, to bypass the operation of default rules based on IP addresses of tunnel endpoints. Control thereafter returns to step 445.
It may thus be appreciated that the user can specify a single output port at which to send all data pertaining to an end user's control and data sessions. In embodiments described below, the IP addresses corresponding control sessions are allocated to specific output port (and thus to the corresponding analytic server). However, alternative embodiments can be implemented using other approaches, as will be apparent to one skilled in the relevant arts by reading the disclosure provided herein.
While example embodiments implementing the features of
It may be appreciated that packet router 102 may contain several components and the applying of the forwarding rules against the incoming packets may be distributed among such components. It may be appreciated that at least some of the components may fail, thereby becoming unavailable. Alternatively, new components may be added or a previously unavailable component may become available. The manner in which such changes in availability status of components in a packet router is addressed according to an aspect of the present disclosure, is described below with examples.
In addition, some of the steps may be performed in a different sequence than that depicted below, as suited to the specific environment, as will be apparent to one skilled in the relevant arts. Many of such implementations are contemplated to be covered by several aspects of the present disclosure. The flow chart begins in step 471, in which control immediately passes to step 480.
In step 480, router controller 104 programs respective forwarding rules in each of a set of load-sharing components of packet router 102. Each component in the set is designed to provide the same or a substantially similar function, and operates to forward communication packets according to the respective programmed forwarding rule. Control then passes to step 485.
In step 485, router controller 104 receives information from packet router 102 indicating an update to the availability status of components in the set of components. Examples of such status include failure of a component in the set, augmentation of the set by addition of a new component to the set. Control then passes to step 490.
In step 490, router controller 104 changes the respective forwarding rules to reflect the update to the availability status. For example, assuming the update indicated failure of a component in the set, router controller 104 re-assigns the forwarding rules assigned earlier to the failed component to the remaining (functioning) components in the set. The re-assignment of the forwarding rules may be done in a load-balanced manner. Control then passes to step 499, in which the flow chart ends.
Thus, the change of availability status of components in packet router 102 is addressed by router controller 104 in network visibility system 100. By addressing the changes in the availability status, packet router 102 is facilitated to forward the packets to the analytic servers at line rate or near line rate. The manner in which the features noted above with respect to
It may be appreciated that the nature of the forwarding rules depends on the internal architecture of packet router 102. Accordingly, the description is continued with respect to the details of packet router 102 in an embodiment.
Ingress card 502 is shown containing input ports 120-1 through 120-X, which are communicatively coupled with one or more networks to be monitored (e.g., 3G network 106 via path 162 and 4G/LTE network 108 via path 182). Ingress card 502 receives packets on input ports 120-1 through 120-X (from paths 162/182), and forwards each packet on path 528 or to whitelist card 504. Ingress card 502 determines whether the packet is a GTP packet (i.e., a GTP-C or GTP-U packet) or not. If the packet is not a GTP packet, ingress card 502 can match the packet against a native-IP table 581 that contains forwarding entries for non-GTP traffic. Based on the native-IP table 581, ingress card 502 can forward the packet, on path 528, to an appropriate output port 130-1 through 130-P (on egress card 508) for transmission to one of the analytic servers 110-1 to 110-P (e.g., an analytic server that has been specifically designated to process non-GTP traffic).
In an embodiment, ingress card 502 may be configured such that non-GTP traffic which does not match any of the rules in native-IP table 581, and GTP traffic that does not match any of the rules in zoning table 580, are dropped (i.e., not forwarded or processed further), in which case port 561 is non-existent in corresponding embodiments. Alternatively, accordingly to an aspect of the present disclosure, such non-matching packets (GTP packets as well as native-IP/non-GTP packets which have no matching entries in zoning table 580 and native-IP table 581 respectively) are forwarded on learning port 561 such that router controller 104 can learn IP addresses for generating additional rules, as described above with respect to
On the other hand, if the packet is a GTP packet, ingress card 502 can match the packet against zoning table 580 and can tag the packet with a zone VLAN ID (as specified in the matched zoning entry) as its inner VLAN tag and a service instance ID as its outer VLAN tag. In one embodiment, the zone VLAN ID is dependent upon: (1) the input port on which the packet is received, and (2) the IP address range of the GGSN associated with the packet in the case of a 3G network, or the IP address range of the SGW associated with the packet in the case of a 4G/LTE network. Thus, the zone VLAN ID enables analytic servers 110-1 to 110-P to classify GTP packets based on such a [input ports, GGSN/SGW IP address range] combination.
In certain embodiments, the GTP traffic belonging to each zone may be mapped to two different zone VLAN IDs depending whether the traffic is upstream (i.e., to GGSN/SGW) or downstream (i.e., from GGSN/SGW). Once tagged (i.e., tag data representing the VLAN ID is appended or associated), the GTP packet can be forwarded to whitelist card 504. The VLAN ID may be used to distribute the processing load across multiple whitelist cards (though a single instance is shown in
Whitelist card 504 receives the VLAN-tagged GTP packets from ingress card 502, and operates to filter the GTP packets according to rules specified by an operator, and stored in a whitelist table 582. Whitelisting enables significant reduction in the processing load of the analytics servers 110-1 to 110-P, by eliminating “non-interesting” (undesirable) network traffic. For example, packets originating from or destined to specific (non-interesting) IP addresses maybe dropped by whitelist card 504 without further processing by components downstream in the processing pipeline of packet router 102.
In one embodiment, whitelist card 504 receives the packet forwarded from ingress card 502 and attempts to match the packet against the whitelist table 582, which includes match parameters (e.g., IP addresses of service providers) and pre-defined actions corresponding to the match parameters. Depending on the configuration of the whitelist table 582, the whitelist card 504 may be configured to either drop the GTP packets (thereby eliminating undesirable traffic) or to forward them to the service cards 506A-506N. Of the incoming GTP packets, GTP-C packets which are not dropped by whitelist card 504 are duplicated (i.e., “mirrored”) and sent to router controller 104 on mirror port 571.
Each of service cards 506A-506N can host one or more service instances, each of which is identifiable by a corresponding address, and which is responsible for processing some subset of the incoming GTP traffic from 3G network 106 and 4G/LTE network 108 (based on, e.g., GGSN/SGW). In a particular embodiment, a service card can host a separate service instance for each hardware packet processor implemented on the service card. The description is continued below with the example operation of a service instance of service card 506A, although other service cards also contain similar structure and functionality as of service card 506A.
In an embodiment, router controller 104 maintains a default GCL table and a dynamic GCL table in service card 506A. It should be appreciated that each service card has a corresponding pair of default and dynamic GCL tables, consistent with the definition and usage of VLAN IDs noted above. However, multiple service instances hosted on a same service card may share the same pair of tables.
Default GCL table 583 contains entries which operate to allocate GTP packets to respective output ports based on the tunnel endpoint the packet is destined to or originates from. Dynamic GCL table 584, provided according to an aspect of the present disclosure, contains dynamically-generated entries which override the operation of the default GCL table 583 to force packets of specific data sessions to desired output ports. In other words, if an entry of default GCL table 583 requires a packet to be forwarded to a first port, and an entry of dynamic GCL table 584 requires a packet to be forwarded to a second port, the packet is forwarded to the second port since the operation based on dynamic GCL table 584 overrides the operation based on default GCL table.
In operation, a service instance (in service card 506A) receives the GTP packet, and attempts to match the packet against the dynamic GCL table defined for the service instance/service card. If there is no match found in the dynamic GCL table 584, service card 506A may then examine entries stored in the default GCL table 583. If a match is found in dynamic GCL table 584, service card 506A forwards the GTP packet to an output port 130-1-130-P (via egress card 508) based on the matched entry in the dynamic GCL table 584. On the other hand, if no match is found in dynamic GCL table 584, service card 506A forwards the GTP packet to an output port 130-1-130-P specified in a matching entry in the default GCL table 583.
Egress card 508 is shown containing output ports 130-1 through 130-P, which are communicatively coupled with corresponding analytic servers 110-1-110-P via paths 131-1-131-P respectively. Analytic servers 110-1 through 110-P are respectively connected to a corresponding one of output ports 130-1 through 130-P, which analyze all the packets related to a user, even if the user moves across areas covered by different NBs/ENBs.
Thus, packet router 102 receives mobile traffic (e.g., GTC-P and GTP-U packets) intercepted from taps in 3G network 106 (via paths 162) and 4G/LTE network 108 (via paths 182), and forwards the traffic to analytic servers 110-through 110-P. The description is continued with respect to the details of various tables stored in packet router 102 and programmed by router controller 104 in corresponding example scenarios.
VLAN ID 653 specifies a zone VLAN ID that is tagged to the incoming packet. The values of VLAN IDs are generally specified by the customer or network operator (and provided to router controller 104 in a configuration file), and depends on the criteria of how zones are created in the network (3G and 4G). Service Instance ID 654 specifies the ID of the service instance (i.e., though shown as service card 506A-506N for illustration) to which the packet is programmed to be forwarded. Whitelist port 655 contains the port number on the whitelist card 504 to which the packet is programmed to be forwarded.
Row 610 indicates that for a packet received on port 120-1 with a destination IP address of SGWIP1, ingress card 502 is to tag the received packet with a VLAN ID of IV1, the service instance ID as service instance 506A, and the whitelist port as WP1. Similarly, row 611 indicates that for a packet received on port 120-2 with a source IP address of SGWIP2, ingress card 502 is to tag the received packet with VLAN ID of IV2, the service instance ID as service instance 506B, and the whitelist port as WP1.
L4 source port 663 specifies the source port in the L4 header of the packet, while L4 destination port 664 specifies the destination port in the L4 header of the packet. Output port 665 specifies the port number on the egress card 508 to which the packet is programmed to be forwarded. VLAN ID 666 specifies a zone VLAN ID that is tagged to the incoming packet.
Row 615 indicates that for a packet received from a server with the source IP address of server1 and with a destination IP address of UE1, the packet is to be forwarded to the output port 130-1 with VLAN ID set to IV4. Similarly, row 616 indicates that for a packet received from a user equipment with the source IP address of server2 and with a destination IP address of UE2, the packet is to be forwarded to the output port 130-2 with VLAN ID set to IV5.
Row 620 indicates that for a packet received from a server with the source IP address of server4 and with a destination IP address of UE5, the action is “drop” (that is, whitelist card 504 drops the packet). Similarly, row 621 indicates that for a packet received from a user equipment with the source IP address of UE7 and with a destination IP address of server5, the action is also “drop”.
Row 630 indicates that for control and user data sent with destination IP of SGWIP1, output port 130-1 is allocated to receive such data. Row 631 indicates that for control and user data sent from (that is, with the source IP of) SGWIP1, output port 130-1 is allocated to receive such data. Similarly, rows 632-633 show other IP addresses (of SGWIP2) and the corresponding destination output ports in the 3G network.
As shown, dynamic GCL table 584 contains columns 690-693. Source IP address 690 specifies the IP address of the source network element from which the packet is sent, while destination IP address 691 specifies the IP address of the destination network element to which the packet is directed. Tunnel Endpoint Identifier (TEID) 692 specifies the endpoint identifier assigned by the network elements while creating the corresponding data sessions. Output port 693 specifies the output port allocated to receive the packets.
Rows 640-643 indicate the dynamic rules mapped to various tunnel endpoints in the network. Row 640 indicates that the dynamic rule allocates incoming data directed at tunnel endpoint TEID3 (with destination IP address of ENBIP1) to be sent to output port 130-1. Similarly, for user data sent with the respective tunnel endpoints (e.g., TIED4) shown in rows 641-643, dynamic rules allocate the corresponding destination output ports to 130-1 as well.
According to an aspect of the present disclosure described in detail in below sections, dynamic rules are used to ensure that the tunnel endpoints of the control session and the tunnel endpoints of the data session of a particular user are allocated to the same output port. It may be observed in
It may be appreciated that the above noted tables in packet router 102 are maintained/updated by router controller 104 such that network visibility system 100 provides several aspects of the present invention. In real-world implementations, network visibility system 100 is responsible for processing a large number of packets (e.g., order of millions per second), flowing through the 3G (106) and 4G/LTE (108) networks, with many of those packets (or relevant portions of such packets) being mirrored to the router controller 104 for determining forwarding rules.
Router controller 104 may also accordingly need to be implemented to support aspects such as scalability and fail-safe (i.e., back-up processing in case some of the components fail) processing. Several aspects of the present disclosure provide an architecture for router controller 104 meeting one or more of such requirements, as described below in further detail.
Switch 710 is configured to receive one or more packets and to forward the received packets to one or more server blades for further processing. Switch 710 is shown with input port 705 and output ports 715A-715N. As noted earlier, mirrored stream of GTP-C traffic is sent from packet router 102 via path 112 (specifically via mirror port 571 of
Switch 710 is configured with one or more routing tables, and distributes incoming packets to the various output ports 715A-715N based on distribution rules configured in the routing tables. For example, the routing tables may maintain rules based on IP addresses of incoming packets. Accordingly, incoming packets with IP addresses (source or destination) that fall in a particular range may be forwarded to one output port, while incoming packets with IP addresses that fall in a different range may be forwarded to another output port.
Alternatively (or in addition), routing tables may maintain rules based on zone VLAN IDs, which are described with reference to
In operation, GTP-C traffic is received by router controller 104 via path 112 on input port 705. Thereafter, switch 710 distributes the incoming packets to the various output ports 715A-715N based on distribution rules maintained in one or more routing tables stored in switch 710. The packets are then forwarded to corresponding server blades 720A-720N via respective paths 712A-712N for further processing.
Each of server blades 720A-720N represents a controller block that accepts incoming packets (e.g., GTP-C packets) from switch 710, processes the packets to generate forwarding rules, and programs the forwarding rules into packet router 102's tables via switch 710. Accordingly, each of the controller blocks may be implemented as a desired combination of hardware, software and firmware, as will be apparent to one skilled in the relevant arts by reading the disclosure provided herein.
In the embodiments described herein, the controller blocks are shown using server blades. However, one skilled in the relevant arts will recognize that any other type of controller blocks (e.g., virtual machines implemented on a single server, other types of processing entities such as rack servers) may be implemented without deviating from the scope and spirit of the present disclosure.
Each of the server blades 720A-720N contains one or more processors with a corresponding local memory unit. The server blades are commonly provided within a blade server, even though multiple blade servers can be employed for further scalability.
Immediately after initial boot-up (i.e., before being operational), router controller 104 assigns one of the server blades (e.g., the blade that establishes communication with switch 210 first) as the ‘master’ blade, and the remaining server blades as ‘slave’ blades. In the example of
Thus, upon being designated as a master blade at initial boot-up, master blade 720A configures initial (packet) forwarding rules available based on user configurations and/or prior operation (and retrieved from a non-volatile memory, not shown). Thereafter, master blade 720A programs the initial forwarding rules in the tables of packet router 102 by sending the rules via path 760A and input port 716A, through switch 710, and via path 112 to packet router 102.
Master blade 720A maintains a copy of the initial forwarding rules locally in its memory, and synchronizes (“syncs”) a copy of the initial forwarding rules with the remaining slave blades 720B-720N by sending the initial forwarding rules via path 740A, on bus 750, to each of the slave blades 720B-720N. Therefore, after the synchronization of the initial forwarding rules, each of the server blades 720A-720N maintain the same copy of the initial forwarding rules as are present in the packet router 102.
Thereafter, each server blade (master and slaves) receives packets from switch 710 based on the distribution rules configured in the routing tables maintained in switch 710. Upon processing the received packets, each of the server blades 720A-720N may generate additional rules based on the processed packets.
Each of the server blades 720A-720N programs the corresponding forwarding rules in the tables of packet router 102 (via corresponding paths 760A-760N, through switch 710, and via path 112), and maintains a copy of the forwarding rules locally in memory. As with the initial forwarding rules, these additional generated forwarding rules are synced with the remaining server blades via a corresponding paths 740A-740N on bus 750.
Thus, upon completion of synchronization, all of the blades 720A-720N has the same view of the programmed rules (in router 102) and each of the blades 720A-720N can process any of the control packets received from switch. Accordingly, switch 710 can be implemented with any distribution rules that operate to balance the load across different blades 720A-720N. In other words, switch 710 can send any received packet to any of the blades 720A-720N, and can therefore distribute the load among the blades based on any distribution approaches. In an embodiment, the distribution of the load is based on VLAN IDs or ‘zones’, such that switch 710 forwards mirrored GTP-C packets originating or terminating in a first zone to a first one of blades 720A-720-N, while forwarding mirrored GTP-C packets originating or terminating in a second zone to a second one of blades 720A-720-N.
Additionally,
The pairs of blades may be implemented with appropriate communication protocol, for example, shown as paths 713A-713N, such that only one of the blades takes on active role, and the other the passive (non-operational) role at any given time instance. When the active blade becomes non-operational, the passive blade switches role to thereafter operate as the active blade.
It may be observed that both the blades of a pair receive packets via the same output port of switch 2710. Due to such a feature and redundancy for the individual blades, switch 710 can continue to operate with the same switching rules, irrespective of which of the blades of the pair is operating as the active blade.
When blades 720A-720N configure the initial forwarding rules, or generate additional rules (by examination of control packets), such rules are programmed in packet router 102 via corresponding paths 760A-760N and input ports 716A-716N, through switch 710, and via path 112. Further, such rules are also synced with the remaining server blades, via corresponding paths 740A (P)-740N (P) on bus 250.
Therefore, even when passive server blades 720A(P)-720N(P) are not active, each of the passive server blades are synchronized with the remaining server blades such that the passive server blades have the same view of the forwarding rules as the active server blades.
As noted previously, when the active blade becomes non-operational, the passive blade switches role to thereafter operate as the active blade. The distribution rules in switch 710 need not be modified, as the now-operational passive blade simply accepts the packets that were previously destined for the non-operational active server (via paths 712A (P)-712N (P)).
Further, any additional rules generated by the passive (now operational) server are programmed in packet router 102 in a similar fashion as described above with respect to the active server blades (i.e., via corresponding paths 760A (P)-760N (P) and input ports 716A-716N, through switch 710, and via path 112 for updates to the router, and via corresponding paths 740A (P)-740N (P) on bus 250 for syncing with the remaining server blades). If the active server associated with the passive server returns to operational status at a future point in time, the passive server may switch role to become non-operational again such that all packets are processed by the now operational active server.
Therefore, in operation, when GTP-C traffic is received by router controller 104 via path 112 on input port 705, switch 710 distributes the incoming packets to the various output ports 715A-715N based on rules maintained in one or more routing tables stored in switch 710. The packets are then distributed to corresponding server blades 720A-720N via respective paths 712A-712N for further processing. Configuration of the initial forwarding rules, as well as additional rules is done by the server blades via switch 710.
Further, the forwarding rules are synced with remaining server blades via a common bus. If an active server becomes non-operational, an associated passive server switches role as the active server, and the incoming packets destined to the non-operational server are distributed to the passive server without modifying distribution rules in the switch, until such time that the active server returns to operational status.
Though not shown, various components of router controller 104 (including blades 720A-720N and switch 710), may be driven by software instructions provided from a non-volatile storage media/medium. The instructions may be retrieved into random access memories (for superior performance) and executed by the processors to provide various features described above, including (one or more of) distributing packets based on distribution rules, and syncing forwarding rules between blades 720A-720N.
It may thus be appreciated that for achieving high throughput performance, router controller 104 may implement a scalable active-active server blade architecture (containing multiple active blades) that performs packet processing in a load-sharing way. Further, for high-availability (or fail-safe) processing of packets, router controller 104 is shown employing corresponding passive components.
The description is continued with respect to the details of an embodiment of master blade 720A, which generates forwarding rules in accordance with several aspects of the present disclosure.
As described above with reference to
Input interface 810A represents a communication interface to enable communication between various blocks of master blade 720A and packet router 102 via switch 710, and between master blade 720A and the remaining blades. In general, packets received by master blade 720A (via path 712A) are examined by input interface 810A for forwarding to appropriate internal block (e.g., 811A, 818A, 819A). Similarly, input interface 810A sends packets (via path 760A) directed to external elements such as packet router 102 upon receipt of the corresponding packets from the respective internal block (e.g., 815A). Further, input interface 810A, via path 713A, operates to communicate the operational status of the master blade 720A, as well as to receive the operational status of the corresponding passive server blade 720A(P) in cooperation with role management block 818A.
Input interface 810A forwards GTP and non-GTP/native-IP packets received from learning port 516 (of
Role management block 818A pings (via path 713A) passive blade 720A(P) to ascertain the operational status of the passive blade 720A(P). Similarly, a corresponding role management block 818A (P) (not shown) in passive blade 720A (P) pings master blade 720A regarding the operational status of the master blade 720A. As described above, if passive blade 720A(P) learns of the master blade 720A being non-operational, passive blade 720A(P) switches role and assumes the role of the master blade 720A. Role management block 818A sends the operational status (i.e., the state) of the corresponding passive blade 720A (P) to sync management block 812A on a periodic basis.
Sync management block 812A maintains a state table (not shown) that stores the operational status of the various blades in router controller 104. For example, if master blade 720A becomes non-operational, such event is communicated by the sync management block of the passive blade 720A (P) (via path 740A (P) to bus 250 as shown in
Further, sync management block 812A receives the configured forwarding rules from configuration block 815A and updates remaining blades 720B-720N (and additionally, in the embodiment of
Similarly, when additional rules are generated (e.g., via the addition of newly discovered IP addresses), configuration block 815A sends a copy of such forwarding rules to sync management block 812A. Sync management block 812A then syncs a copy of such rules with the remaining blades via path 740A (to bus 250) in router controller 104.
Accordingly, the current data maintained in the zoning table 580, the native-IP table 581, whitelist table 582, default GCL table 583, and dynamic GCL table 584 of packet router 102 is synced with all server blades in router controller 104 such that failure of any one server blade does not impact the operation of the router controller 104.
In the context of packets sent from packet router 102 on path 571, input interface 810A receives the packets and forwards them to queue manager 811A. Queue manager 811A receives control packets from input interface 810A and places the packets in a queue before further processing by GTP discriminator 813A (e.g., on a first-in-first-out basis). Master blade 720A receives a large number of packets (e.g., GTP-C control packets) for processing, and as such queue manager 811A buffers the packets in one or more queues prior to retrieval by GTP discriminator 813A.
GTP discriminator 813A retrieves packets from queue manager 811A and distributes the packets to session management blocks 814A1 or 814A2 based on whether the incoming packet is a 3G network packet or a 4G/LTE network packet respectively. In an embodiment, GTP discriminator 813A identifies 3G and 4G/LTE packets based on a version field contained in the GTP header of the received GTP packets, as is well known in the relevant arts.
Session management blocks 814A1 and 814A2 (collectively “block 814A”) process 3G and 4G/LTE packets respectively. Session management block 814A operates to ensure that GTP-C and GTP-U packets of the same user session continue to be directed to the same output port, as described in below sections.
Configuration block 815A configures the initial forwarding rules, and additional rules in corresponding tables on packet router 102. Zoning table 580, Native-IP table 581, whitelist table 582, default and dynamic GCL tables 583 and 584 of packet router 102 may be implemented in the form of CAMs (content addressable memory). Configuration block 815A maintains a list of the available hardware resources of packet router 102, e.g., the number of operational service cards and the number of operational output ports. Configuration block 815A maintains a count of the total number of CAM entries (an example format for an entry in a default GCL table is shown in
Additionally, upon receiving dynamic GCL rules from session management block 814A, configuration block 815A sends the dynamic forwarding rules to switch 210 via input interface 810A and path 760A. The dynamic rules are sent from switch 210 to packet router 102 via service port 573 (shown in
Configuration block 815A also stores a copy of the initial forwarding rules, and additional rules in memory 817A. The saved data (i.e., the forwarding rules) associated with the zoning table 580, the native-IP table 581, whitelist table 582, default GCL table 583, and dynamic GCL table 584 is shown represented as zoning table data 580A, the native-IP table data 581A, whitelist table data 582A, default GCL table data 583A, and dynamic GCL table data 584A respectively in memory 817A. Configuration block 815A further sends each of the configured forwarding rules (stated above) to sync management block 812A on a periodic basis (e.g., after configuring each rule).
Configuration file 816A (which may be part of memory 817A, although shown separately) stores the IP addresses of network elements (such as those shown in
Configuration file 816A may also contain entries indicating a mapping of specific IP network addresses to the corresponding VLAN IDs and also the specific node type the specific IP addresses of such network addresses may be allocated to. Such information may be provided by the network administrators based on the knowledge of IP address allocations to different node types in various networks and geographies. The mapping is used in providing the appropriate values for various rows of
The description is continued with respect to the initial (boot-up/power up) operation of master blade 720A (in particular configuration block 815A) in one embodiment.
When packet router 102 is powered up, configuration block 815A reads the user-configured rules in configuration file 816A and runs algorithms to determine whether there is capacity available in the CAM memory to program the corresponding rules. Configuration block 815A also validates the rules by performing validation checks on various fields in the rules (e.g., ingress/egress ports and protocol). Thereafter, configuration block 815A configures, via input interface 810A and path 760A, the zoning table 580, the native-IP table 581, whitelist table 582, and default GCL table 583 in packet router 102 based on the entries already present in configuration file 816A.
In an embodiment, with respect to the zoning table 580, configuration block 815A first identifies the set of all relevant IP addresses from configuration file 816A. Assuming there are ‘n’ service cards (e.g., 506A-506N), configuration block 815A creates ‘n’ sets of IP addresses (e.g., by dividing the set of all relevant IP addresses by a factor of ‘n’) and assigns each set of IP addresses to a corresponding one of the ‘n’ service cards. Thereafter, configuration block 815A configures forwarding rules corresponding to each set of IP addresses in the zoning table 580 of packet router 102, to cause packets with the corresponding IP addresses to be forwarded to a corresponding service card (i.e., 506A-506N).
With respect to native IP table 581, assuming there are ‘p’ output ports (shown as 130-1 to 130-P in
With respect to whitelist table 582, configuration file 815A identifies all the whitelisted IP addresses configured by the user in configuration file 816A and programs corresponding forwarding rules based on such IP addresses in the whitelist table 582. In one embodiment, all packets originating from or destined to the whitelisted IP addresses are dropped by the packet router 102. The whitelisted IP addresses are typically configured by the user in the configuration file 816A either in the form of static IP addresses or in the form of domain names, which are dynamically converted into IP addresses by the configuration block 815A prior to programming the forwarding rules in the whitelist table 582.
With respect to default GCL table 583, as described earlier, each service card 506A-506N is assigned a set of IP addresses in the zoning table 580. Packets received at the corresponding service card are forwarded to an output port for further processing, based on forwarding rules in the default GCL table 583. Accordingly, assuming there are ‘p’ output ports, and assuming all ‘p’ output ports can process each incoming packet, configuration block 815A creates ‘p’ sets of IP addresses from the set of IP addresses assigned to each service card, and assigns each set of IP addresses to a corresponding one of the ‘p’ output ports. Thereafter, configuration block 815A configures the forwarding rules corresponding to each set of IP addresses to a corresponding output port (i.e., 131-1 to 131-P) in default GCL table 583 of packet router 102 such that packets are distributed among the various output ports in a proportional manner.
For example, assuming there are 600 IP addresses that need to be distributed between two service cards and six output ports. In an embodiment, configuration block 815A first configures forwarding rules (in the zoning table 580) assigning a set of 300 IP addresses to the first service card, and assigning another set of 300 IP addresses to the second service card. Thereafter, the 600 IP addresses are equally distributed among the 6 output ports (at 100 IP addresses each) in default GCL table 583 such that packets with the corresponding IP addresses are forwarded to a corresponding output port.
In one embodiment, configuration block 815A computes the total number of IP addresses that are to be assigned to a single output port (equal to the number of incoming IP addresses divided by the number of output ports) and then distributes the total number of IP addresses equally among all the service cards. In the above examples, configuration block 815A creates 6 sets of IP addresses (50 each=total number of IP addresses to be assigned to each output port/number of service cards=100/2) that are each assigned to a corresponding one of the 6 output ports. Accordingly, a single output port is assigned 50 IP addresses each from each of the two service cards, for a total of 100 IP addresses assigned per port from both the service cards.
The initial forwarding rules are sent from switch 710 to packet router 102 via control port 563 (shown in
According to an aspect of the present disclosure, ingress card 502 in packet router 102 forwards non-matching packets (those not matching any of the rules/rows in native-IP table 581 and zoning table 580) on learning port 561 to router controller 104. As noted above, the non-matching packets may include GTP as well as non-GTP/native-IP packets. Learning block 819A (in router controller 104) parses each received GTP and non-GTP/native-IP packet to identify IP addresses and stores the identified IP addresses contained in the packet (as well as the node type to which the IP address belongs) in configuration file 816A. The manner in which various packets can be examined/parsed for determining the IP addresses for corresponding node types, is noted below in Appendix A, and learning block 819A implements the packet-parsing logic described in Appendix A.
Based on the discovered (and stored) IP addresses and the corresponding node types, configuration block 815A may verify if node types and their corresponding IP addresses as specified by a network operator (via a configuration file (e.g., 816A)) match. For example, configuration block 815A may determine if source and destination IP addresses (which may have been obtained from a network operator) in table 580 of
Configuration block 815A may use the newly discovered IP addresses (stored by learning block 819A in configuration file 816A) to configure zoning table 580, native-IP table 581, and default GCL table 583. For example, configuration block 815A includes the newly discovered IP addresses in the identified set of all relevant IP addresses (noted above), and then sets up zoning table 580 such that the newly identified set (including the discovered IP addresses) are equally distributed among the existing (‘n’) service cards. Similar to the operations with respect to zoning table 580, forwarding rules for newly discovered IP addresses are distributed among the various output ports in a proportional manner in native-IP table 581 and default GCL table 583.
Configuration block 815A sends the additional rules (generated based on discovered IP addresses) to switch 710 via input interface 810A and path 760A. The additional rules are sent from switch 710 to packet router 102 via control port 563 and service port 573 (shown in
Thus, by having router controller 104 discover new IP addresses and generate forwarding rules based on the newly discovered IP addresses, the formation of forwarding rules is simplified. The description is continued with respect to another aspect of the present disclosure.
As noted above, an aspect of the present disclosure enables router controller 104 to configure dynamic filters which ensure that control (GTP-C) and user (GTP-U) packets of the same user session continue to be directed to the same output port (and thus to the same analytic server). Such configuration may be necessitated when the packets received from the same user have different associated IP addresses.
For example, in 4G/LTE network 108 (
Upon receiving the create session request message, it is assumed that SGW 320-1 returns a create session response message with the cause code as “request accepted”. As with MME 350-1, SGW 320-1 also sends its IP address and TEID (i.e., SGWIP1, and TEID2 respectively) to indicate acceptance of the create session request message, as well as to indicate to MME 350-1 that when sending any future control messages to SGW 320-1, MME 350-1 must use the tunnel endpoint SGWIP1 and TEID2 to identify SGW 320-1 for that particular control session.
Once the corresponding IP addresses and TEIDs are exchanged between MME 350-1 and SGW 320-1, a control session 1010 is established with TEIDs of TEID1 and TEID2 at the respective ends of the tunnel.
Referring to
Upon receiving the request (via ENB 310-1), MME 350-1 initiates communication with SGW 320-1 via a “modify bearer” message, which is a message sent to request the establishment of data channels between SGW 320-1 and ENB 310-1. The modify bearer message identifies the IP address and the TEID of SGW 320-1 assigned during the creation of the control session (as shown in
Upon receiving the modify bearer message, it is assumed that SGW 320-1 returns a modify bearer response message with cause code as “request accepted”. As with MME 350-1, SGW 320-1 also sends its IP address and TEIDs (i.e., SGWIP2, and TEID4 and TEID6 respectively) to indicate acceptance of the modify bearer message (thereby forming the corresponding two data sessions), as well as to indicate to ENB 310-1 that when sending future data to SGW 320-1, ENB 320-1 must use the tunnel endpoints SGWIP2/TEID4, and SGWIP2/TEID6 to identify SGW 320-1 for the corresponding first and second data channels respectively.
Although the tunnel endpoint information is shown being received in a separate modify bearer message, it would be evident to one of ordinary skill in the art by reading the disclosure herein that the tunnel endpoint information of the modify bearer message may be communicated on the same create session request message shown in
It may be appreciated that configuration block 815A may specify forwarding rules in default GCL table 583 of packet router 102 to reflect the scenarios shown in
In particular, row 630 of
Referring again to
However, if session management block 814A2 determines that GTP traffic for the data and control sessions associated with the current GTP-C packet will not still be sent to the same output port (as in the scenario depicted in
With respect to the rules shown in
Thus, by creating appropriate dynamic filters and updating dynamic GCL table 584 with the created filters, router controller 104 ensures that the analysis of all packets of a single user is a performed by the same analytic server 110-1 to 110-P. Although the description of
For example, in 3G networks, control and data sessions are created between GGSN and SGSN nodes, with tunnel endpoints forming between the respective pairs of nodes. This allows the SGSN to activate a control or data session on a user's behalf or deactivate the same session. Similarly, GGSN may be utilized to activate or deactivate sessions on behalf of an external server sending data directed at the user equipment (e.g., user equipment 201-202). In such cases, the information stored in the default and dynamic rules tables would reflect the tunnel endpoints of the corresponding nodes (typically the GGSN) as applicable in the 3G network context.
Similar to as in 4G/LTE networks (although not necessarily), a GGSN may contain two interfaces, each with different IP addresses. A control session packet from SGSN may be forwarded to one interface (i.e., one IP address and a corresponding TEID) of the GGSN, while data sessions (associated with the control session) from SGSN may be forwarded on the second interface (i.e., second IP address and with corresponding TEIDs for each data session). Therefore, similar to that as noted above with respect to 4G/LTE networks, if session management block 814A2 determines from the default table 583 that packets of the control and the associated data sessions are not programmed to be forwarded to the same output port, then session management block 814A2 creates a new dynamic GCL entry (in dynamic GCL table 584) to force packets of the control and data sessions to the same output port.
In an embodiment, session management block 814A1 generates and processes duplicate dynamic rules. For example, as described earlier, data corresponding to each session is carried over a corresponding GTP tunnel between a set of network elements (e.g., between SGSN 230-1 and GGSN 240-1), with a set of tunnel endpoint identifiers (TEIDs) being allocated for the corresponding network elements in the GTP tunnel. When the session is terminated, a corresponding termination packet indicating the termination of the session is generated by one of the network elements in the GTP tunnel. The termination packet is processed by router controller 104 such that any corresponding dynamic rule is deleted in the dynamic GCL table 584 of the packet router 104.
However, in case the termination packet is lost in transit, the packet is not processed by router controller 104 and the corresponding dynamic rule is not deleted from dynamic GCL table 584. In such an event, if the same tunnel identifiers are reused by the network elements for a subsequent GTP tunnel, a duplicate dynamic rule (matching the existing dynamic rule) may be generated by session management block 814A, during processing of the GTP packet.
In such a case, if session management block 814A processes a subsequent GTP-C packet that generates a duplicate dynamic rule (i.e., the new dynamic rule matches an existing dynamic rule), then session management block 814A either deletes the newly generated duplicate dynamic rule (so that configuration block 815A does not program the duplicate rule into the dynamic GCL table 584 in the packet router 102), or replaces the existing dynamic rule with the new duplicate rule (i.e., updating the rule in the table 584).
The description is continued with respect to another aspect of the present disclosure.
It may be observed from the description above, that packet router 102 contains multiple components, which individually perform a similar function with respect to corresponding set of assigned packets. For example, multiple service instances (GVSI) are hosted on service card 506A (and other service cards), each responsible for processing a corresponding set of packets. Similarly, multiple output ports (130-1 to 130-P) are provided on egress card 508. The various components may communicate with each other based on the configuration/data specified in the various tables (shown in
GTP packets with IP addresses (both source and destination) ranging from IP1 through IP4 are assumed to be tagged in ingress card 502 to be sent to GVSI-1, while GTP packets with IP addresses ranging from IP4 through IP8 are tagged to be sent to GVSI-2. The default GCL table in GVSI-1 is assumed to map IP addresses IP1-IP2 to OP1, and IP addresses IP3-IP4 to OP2, although ports OP3 and OP4 are also accessible from GVSI-1. The default GCL table in GVSI-2 is assumed to map IP addresses IP5-IP6 to OP3, and IP addresses IP7-IP8 to OP4, although ports OP1 and OP2 are also accessible from GVSI-1. In operation, a GTP packet with tunnel end point address(es) with value IP5 is forwarded to GVSI-2 by whitelist card 504 (based on the tagging done by ingress card 502). GVSI-2 would forward the GTP packet to OP3. A GTP packet with tunnel end point addresses with value IP2 is forwarded to GVSI-1 by whitelist card 504. GVSI-1 would forward the GTP packet to OP2, and so on, based on the corresponding default GCL tables.
According to an aspect of the present disclosure, default forwarding rules associated with a component (such as service card/service instance) are re-assigned to other functioning components upon change in availability status such as failure, removal, and addition of components in packet router 102. Configuration block 815A performs such re-assigning with a view to balance the load among the remaining functioning components. Configuration block 815A can determine the load on a component by inspecting locally-stored data (e.g., which may be stored in memory 817A of
For example, upon failure (for reasons such as mal-function and power-supply failure, which are not specifically manually instructed by a user) of a service card or a service instance within a service card, or if a user expressly indicates that a specific service instance not be used, configuration block 815A deletes the forwarding rules (default as well as dynamic entries) applied to the service instance, and assigns the deleted default and dynamic rules to another service instance that is functional by creating default and dynamic entries in that service instance. Similarly, on failure of an output port, configuration block 815A creates new entries in the default GCL table of the corresponding service instance(s) to now cause the service instance to forward GTP packets to another (functioning) output port. Such re-assigning may be done to balance the load across the remaining functioning components of packet router 102 (load balanced manner).
In one embodiment, configuration block 815A receives information indicating failure, or removal by a user, of components such as service cards, from packet router 102 via control port 563. Upon receipt of such ‘failure’ information (although the information could instead be related addition of a resource/component rather than failure), configuration block 815A operates to re-assign, in a load balanced manner, the rules in the failed component to other functioning components. Examples of instances when configuration block 815A re-assigns/updates rules in components of packet router 102 are briefly described next.
When a service instance fails (e.g., due to hardware failure), configuration block 815A performs the following operations:
To illustrate, assuming GVSI-1 of
In operation, a GTP packet with tunnel end point addresses with value IP1 is forwarded to GVSI-2 (rather than GVSI-1) by whitelist card 504, with GVSI-2 then forwarding the GTP packet to OP1. A GTP packet with tunnel end point addresses with value IP4 is also forwarded to GVSI-2 by whitelist card 504, with GVSI-2 then forwarding the GTP packet to OP2, and so on. Assuming that two more GVSI instances had been present, configuration block 815A distributes the entries in the default GCL table of GVSI-1 across the default GCL tables of the other three GVSI instances in a load balanced manner (i.e., taking into account the current load on each instance). As noted above, configuration block 815A determines the load on each instance by inspecting locally-stored data indicating availability of CAM space in the default GCL tables of the corresponding service instances. Configuration block 815A also makes corresponding changes to zoning table in ingress card 502. Dynamic entries in GVSI-1 would similarly be distributed across the three remaining GVSI instances.
When the failed service instance is again available for operation, rules that were earlier applied to the service instance when the service instance was operational, may be re-applied by configuration block 815A to the now functioning service instance, while also deleting the re-applied rules from the other corresponding service instances, and making corresponding entry changes in zoning table 580 to include forwarding of packets to the now available service instance also. Accordingly, upon a service instance being detected to have failed, information indicating the specific rules then processed by the service instance, as well as the specific service instance to which each rule is re-allocated, may be stored in memory 817A of
However, if the renewed availability of the service instance occurred after de-configuration (manual intervention instructing that the service instance is no longer to be used) of the service instance by an operator (rather than failure of the service instance), then configuration block 815A may not remap or load balance existing default rules to the new service instance, but merely programs new (as-yet un-assigned) rules to the new service instance.
As another example, if a service card itself is removed or de-configured by an operator, configuration block 815A distributes (for example, equally) the default rules configured on the removed service card among the remaining functioning service cards. Configuration block 815A may also update zoning table 580 to reflect the removal of the service card, i.e., stop forwarding packets to the removed service card, and instead to forward such packets to one or more of the functioning service cards.
As another example, if a new service card is added, configuration block 815A may not attempt to remap existing default rules in other service cards to the new service card. Instead, configuration block 815A programs the default GCL table of the new service card with rules containing new (as yet un-assigned) IP addresses of tunnel end points (e.g., GGSN, SGW) since the new card is the least loaded. Configuration block 815A may create new rules in zoning table 580 also to cause packet forwarding to the new service card.
As another example, when an output port fails (malfunctions or otherwise becomes unavailable due to reasons other than express administrator commands), configuration block 815A updates the default and dynamic rules in service instances that contain the failed output port as the destination port for packets, to now be forwarded to other functioning output ports. Configuration block 815A may perform such updating to distribute the forwarding of packets evenly to the functioning output ports, i.e., in a load-balanced manner. Configuration block 815A also changes entries in native-IP table (581) to reflect the failure (i.e., to cause the corresponding rules to direct incoming native IP packets to functioning output ports). The rules thus changed due to failure of an output port are marked as such in local memory 817A, including information indicating the now failed output port before the change to which all of the rules were pointing to, prior to the failure of the output port.
When operation of the failed output port is restored, configuration block 815A retrieves the rules that were mapped to the port before the failure of the output port occurred, and remaps the rules to the now functioning output port. Thus, configuration block 815A identifies (by inspecting the copy of rules stored in local memory 817A) entries in the default and dynamic GCL tables of service instances that were earlier changed to forward packets to other functioning output ports (rather than the failed output port), and now causes those entries to once again forward packets to the now-restored output port.
When a new output port is made available for operation by an operator, configuration block 815A programs the default GCL tables of service instances with as yet un-assigned rules, specifying the newly available output port as the destination for packets. Configuration block 815A may not attempt to remap existing default rules in service cards to the new output port, but may create corresponding new entries in native-IP table 581 to cause native-IP packets to be forwarded now to the new output port rather than the output port specified earlier in native-IP table 581.
As another example, when an egress card (e.g., 508) fails (malfunctions or otherwise becomes unavailable due to reasons other than express administrator commands), configuration block 815A updates the default and dynamic rules in service instances that contain output ports on the failed egress card as the destination port for packets, to now be forwarded to functioning output ports on other functioning egress cards. Configuration block 815A may perform such updating to distribute the forwarding of packets evenly to the functioning egress cards, i.e., in a load-balanced manner. When operation of the failed egress card is restored, configuration block 815A retrieves the rules that were mapped to the egress card before the failure of the egress card occurred, and remaps the rules to the now functioning egress card. Thus, configuration block 815A identifies (by inspecting the copy of rules stored in local memory 817A) entries in the default and dynamic GCL tables of service instances that were earlier changed to forward packets to other functioning output ports (and not output ports on the failed egress card), and now causes those entries to once again forward packets to the corresponding output ports of the now-restored egress card.
As another example, when a new egress card is added by an operator, configuration block 815A programs the default GCL tables of service instances with as yet un-assigned rules, specifying corresponding output ports on the new egress card as the destination for packets. Configuration block 815A may not attempt to remap existing default rules in service cards to the new egress card. Configuration block 815A may also create corresponding new entries in native-IP table 581 to cause native-IP packets to be forwarded now to output ports on the new egress card (rather than the output port specified earlier in native-IP table 581).
If control port 563 fails, then for the duration of such failure configuration block 815A cannot receive (from packet router 102) notifications of change in availability status (additions/removal, failure) of service instances/service cards and/or output ports/egress cards. When operation of control port 563 is restored, configuration block 815A gets an indication from packet router 102 (via control port 563) that control port 563 is now operational. In addition, packet router 102 also sends the ‘current’ (i.e., latest) state of all service instances/cards and output ports/egress cards to configuration block 815A via control port 563.
Configuration block 815A compares the difference between the latest state and the state before failure of control port 563 (which configuration block 815A maintains in memory 817A), and either adds new forwarding rules in newly available service instances/cards and/or output ports/egress cards, or re-assigns forwarding rules from now-unavailable service instances/cards and/or output ports/egress cards to functioning service instances/cards and/or output ports/egress cards in a load balanced manner. For example, if a new service card was added in the duration that control port 563 was non-operational, configuration block 815A adds as-yet unassigned forwarding rules to the new service card. On the other hand, if a service card had failed, configuration block 815A assigns rules earlier assigned to the now-failed service card to other functional service cards in a load balanced manner.
If service port 573 fails, session management block 814A cannot create entries in the dynamic GCL tables in service cards 506A-506N for the duration of such failure. Session management block 814A marks any unsuccessful attempts at creation of entries in the dynamic GCL tables. When operation of service port 573 is restored, session management block 814A performs creation of the hitherto unsuccessful entries (if any) in the dynamic GCL tables.
If mirror port 571 or learning port 561 fail, router controller 104 cannot receive mirrored GTP-C packets from whitelist card 504, or newly discovered packets from ingress card 502. Configuration block 518A cannot therefore perform discovery of IP addresses and/or session correlation of GTP packets as noted above for the duration of such failure. Configuration block 815A resumes discovery of IP addresses and session correlation operations (if any is required) once ports 561/571 resume operation.
In cases in which packet router 102 becomes non-operational (e.g., due to power-failure), then on resumption of operation of packet router 102, configuration block 815A reprograms (afresh) all rules in ingress card, service cards and egress cards as if network visibility system 100 had re-started. Similarly, on resumption of operation of router controller 104 after a failure, configuration block 815A programs all rules in ingress cards, service cards and egress cards, as if network visibility system 100 had re-started (re-initialized).
It should be appreciated that the features described above can be implemented in various embodiments as a desired combination of one or more of hardware, executable modules, and firmware. The description is continued with respect to an embodiment in which various features are operative when the instructions in the executable modules are executed.
Digital processing system 1200 may contain one or more processors (such as a central processing unit (CPU) 1210), random access memory (RAM) 1220, secondary memory 1230, graphics controller 1260, display unit 1270, network interface 1280, and input interface 1290. All the components except display unit 1270 may communicate with each other over communication path 1250, which may contain several buses as is well known in the relevant arts. The components of
CPU 1210 may execute instructions stored in RAM 1220 to provide several features of the present disclosure. CPU 1210 may contain multiple processing units, with each processing unit (containing one or more processors) potentially being designed for a specific task. Alternatively, CPU 1210 may contain only a single general-purpose processing unit. RAM 1220 may receive instructions from secondary memory 1230 using communication path 1250. RAM 1220 is shown currently containing software instructions constituting shared environment 1225 and/or user programs 1226. Shared environment 1225 contains utilities shared by user programs, and such shared utilities include operating system, device drivers, virtual machines, and flow engines, which provide a (common) run time environment for execution of user programs 1226.
Graphics controller 1260 generates display signals (e.g., in RGB format) to display unit 1270 based on data/instructions received from CPU 1210. Display unit 1270 contains a display screen to display the images defined by the display signals. Input interface 1290 may correspond to a keyboard and a pointing device (e.g., touch-pad, mouse) that may be used to provide various desired inputs (such as user specified entries in configuration file 816A). Network interface 1280 provides connectivity to a network (e.g., using Internet Protocol), and may be used to communicate with other connected systems.
Secondary memory 1230 represents a non-transitory medium, which may store the data and software instructions (for example, for performing the steps of
Secondary memory 1230 may contain hard drive 1235, flash memory 1236, and removable storage drive 1237. Some or all of the data and instructions may be provided on removable storage unit 1240, and the data and instructions may be read and provided by removable storage drive 1237 to CPU 1210. Removable storage unit 1240 may be implemented using medium and storage format compatible with removable storage drive 1237 such that removable storage drive 1237 can read the data and instructions. Thus, removable storage unit 1240 includes a computer readable (storage) medium having stored therein computer software and/or data. However, the computer (or machine, in general) readable medium can be in other forms (e.g., non-removable, random access).
In this document, the term “computer program product” is used to generally refer to removable storage unit 1240 or hard disk installed in hard drive 1235. These computer program products are means for providing software to digital processing system 1200. CPU 1210 may retrieve the software instructions, and execute the instructions to provide various features of the present disclosure described above.
The term “storage media/medium” as used herein refers to any non-transitory media that store data and/or instructions that cause a machine to operate in a specific fashion. Such storage media may comprise non-volatile media and/or volatile media. Non-volatile media includes, for example, optical disks, magnetic disks, or solid-state drives, such as storage memory 1230. Volatile media includes dynamic memory, such as RAM 1220. Common forms of storage media include, for example, a floppy disk, a flexible disk, hard disk, solid-state drive, magnetic tape, or any other magnetic data storage medium, a CD-ROM, any other optical data storage medium, any physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, NVRAM, any other memory chip or cartridge.
Storage media is distinct from but may be used in conjunction with transmission media. Transmission media participates in transferring information between storage media. For example, transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 1250. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
Reference throughout this specification to “one embodiment”, “an embodiment”, or similar language means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present disclosure. Thus, appearances of the phrases “in one embodiment”, “in an embodiment” and similar language throughout this specification may, but do not necessarily, all refer to the same embodiment.
Furthermore, the described features, structures, or characteristics of the disclosure may be combined in any suitable manner in one or more embodiments. In the above description, numerous specific details are provided such as examples of programming, software modules, user selections, network transactions, database queries, database structures, hardware modules, hardware circuits, hardware chips, etc., to provide a thorough understanding of embodiments of the disclosure.
While various embodiments of the present disclosure have been described above, it should be understood that they have been presented by way of example only, and not limitation. Thus, the breadth and scope of the present disclosure should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
It should be understood that the figures and/or screen shots illustrated in the attachments highlighting the functionality and advantages of the present disclosure are presented for example purposes only. The present disclosure is sufficiently flexible and configurable, such that it may be utilized in ways other than that shown in the accompanying figures.
Further, the purpose of the following Abstract is to enable the Patent Office and the public generally, and especially the scientists, engineers and practitioners in the art who are not familiar with patent or legal terms or phraseology, to determine quickly from a cursory inspection the nature and essence of the technical disclosure of the application. The Abstract is not intended to be limiting as to the scope of the present disclosure in any way.
Detecting SGW-IP Addresses
Number | Date | Country | Kind |
---|---|---|---|
3037/CHE/2015 | Jun 2015 | IN | national |
3308/CHE/2015 | Jun 2015 | IN | national |
3310/CHE/2015 | Jun 2015 | IN | national |
3893/CHE/2015 | Jul 2015 | IN | national |
The present application is related to and claims priority from the following co-pending Patent Applications, each naming as Applicant: Brocade Communications Systems, Inc., which are all incorporated into the instant patent application in their entirety to the extent not inconsistent with the disclosure of the instant patent application: a. India Provisional Application Number: 3037/CHE/2015; Entitled, “Configuration of A Network Visibility System”; Inventors: Pragash et al; Filed on: 17 Jun. 2015;b. India Provisional Application Number: 3893/CHE/2015; Entitled, “Architecture for a Network Visibility System”; Inventors: Sharma et al; Filed on: 29 Jul. 2015;c. India Provisional Application Number: 3308/CHE/2015; Entitled, “Configuration of Rules in a Network Visibility System”; Inventors: Sharma et al; Filed on: 29 Jun. 2015; andd. India Provisional Application Number: 3310/CHE/2015; Entitled, “Configuration Of Load-Sharing Components of a Network Visibility Router in a Network Visibility System”; Inventors: Sharma et al; Filed on: 29 Jun. 2015. In addition, the present application is a continuation-in-part of the following US patent applications, which are incorporated into instant patent application in their entirety to the extent not inconsistent with the disclosure of the instant patent application: a. U.S. Non-provisional application Ser. No. 14/848,586, filed Sep. 9, 2015, entitled “Techniques for Exchanging Control and Configuration Information in a Network Visibility System”, which claims priority to U.S. Provisional Application No. 62/137,073, filed Mar. 23, 2015, entitled “Techniques for Exchanging Control and Configuration Information in a Network Visibility System”; andb. U.S. Non-provisional application Ser. No. 14/848,645, filed Sep. 9, 2015, entitled “Techniques for Efficiently Programming Forwarding Rules in a Network Visibility System”, which claims priority to U.S. Provisional Application No. 62/137,084, filed Mar. 23, 2015, entitled “Techniques for Efficiently Programming Forwarding Rules in a Network Visibility System”. The present application is also related to the following co-pending US patent applications, naming as Applicant: Brocade Communications Systems, Inc., which are all incorporated into the instant patent application in their entirety to the extent not inconsistent with the disclosure of the instant patent application: a. patent application Ser. No. 14/927,479; Filed: Oct. 30, 2015; Entitled, “Architecture for a Network Visibility System”; Inventors: Sharma et al;b. patent application Ser. No. 14/927,478; Filed: Oct. 30, 2015; Entitled, “Configuration of A Network Visibility System”; Inventors: Pragash et al;c. patent application Ser. No. 14/927,484; Filed: Oct. 30, 2015; Entitled, “Configuration of Load-Sharing Components of a Network Visibility Router in a Network Visibility System”; Inventors: Sharma et al;d. patent application Ser. No. 14/603,304; filed: Jan. 22, 2015; Entitled, “Session-Based Packet Routing For Facilitating Analytics”; ande. patent application Ser. No. 14/848,677, filed Sep. 9, 2015, entitled “Techniques for User-Defined Tagging of Traffic in a Network Visibility System”.
Number | Name | Date | Kind |
---|---|---|---|
5031094 | Toegel et al. | Jul 1991 | A |
5359593 | Derby et al. | Oct 1994 | A |
5948061 | Merriman et al. | Sep 1999 | A |
5951634 | Sitbon et al. | Sep 1999 | A |
6006269 | Phaal | Dec 1999 | A |
6006333 | Nielsen | Dec 1999 | A |
6078956 | Bryant et al. | Jun 2000 | A |
6092178 | Jindal et al. | Jul 2000 | A |
6112239 | Kenner et al. | Aug 2000 | A |
6115752 | Chauhan | Sep 2000 | A |
6128279 | O'Neil et al. | Oct 2000 | A |
6128642 | Doraswamy et al. | Oct 2000 | A |
6148410 | Baskey et al. | Nov 2000 | A |
6167445 | Gai et al. | Dec 2000 | A |
6167446 | Lister et al. | Dec 2000 | A |
6182139 | Brendel | Jan 2001 | B1 |
6195691 | Brown | Feb 2001 | B1 |
6205477 | Johnson et al. | Mar 2001 | B1 |
6233604 | Van Home et al. | May 2001 | B1 |
6260070 | Shah | Jul 2001 | B1 |
6286039 | Van Horne et al. | Sep 2001 | B1 |
6286047 | Ramanathan et al. | Sep 2001 | B1 |
6304913 | Rune | Oct 2001 | B1 |
6324580 | Jindal et al. | Nov 2001 | B1 |
6327622 | Jindal et al. | Dec 2001 | B1 |
6336137 | Lee et al. | Jan 2002 | B1 |
6381627 | Kwan et al. | Apr 2002 | B1 |
6389462 | Cohen et al. | May 2002 | B1 |
6427170 | Sitaraman et al. | Jul 2002 | B1 |
6434118 | Kirschenbaum | Aug 2002 | B1 |
6438652 | Jordan et al. | Aug 2002 | B1 |
6446121 | Shah et al. | Sep 2002 | B1 |
6449657 | Stanbach, Jr. et al. | Sep 2002 | B2 |
6470389 | Chung et al. | Oct 2002 | B1 |
6473802 | Masters | Oct 2002 | B2 |
6480508 | Mwikalo et al. | Nov 2002 | B1 |
6490624 | Sampson et al. | Dec 2002 | B1 |
6549944 | Weinberg et al. | Apr 2003 | B1 |
6567377 | Vepa et al. | May 2003 | B1 |
6578066 | Logan et al. | Jun 2003 | B1 |
6606643 | Emens et al. | Aug 2003 | B1 |
6665702 | Zisapel et al. | Dec 2003 | B1 |
6671275 | Wong et al. | Dec 2003 | B1 |
6681232 | Sitanizadeh et al. | Jan 2004 | B1 |
6681323 | Fontsnesi et al. | Jan 2004 | B1 |
6691165 | Bruck et al. | Feb 2004 | B1 |
6697368 | Chang et al. | Feb 2004 | B2 |
6735218 | Chang et al. | May 2004 | B2 |
6745241 | French et al. | Jun 2004 | B1 |
6751616 | Chan | Jun 2004 | B1 |
6754706 | Swildens et al. | Jun 2004 | B1 |
6772211 | Lu et al. | Aug 2004 | B2 |
6779017 | Lamberton et al. | Aug 2004 | B1 |
6789125 | Aviani et al. | Sep 2004 | B1 |
6821891 | Chen et al. | Nov 2004 | B2 |
6826198 | Turina et al. | Nov 2004 | B2 |
6831891 | Mansharamani et al. | Dec 2004 | B2 |
6839700 | Doyle et al. | Jan 2005 | B2 |
6850984 | Kalkunte et al. | Feb 2005 | B1 |
6874152 | Vermeire et al. | Mar 2005 | B2 |
6879995 | Chinta et al. | Apr 2005 | B1 |
6898633 | Lyndersay et al. | May 2005 | B1 |
6901072 | Wong | May 2005 | B1 |
6901081 | Ludwig | May 2005 | B1 |
6920498 | Gourlay et al. | Jul 2005 | B1 |
6928485 | Krishnamurthy et al. | Aug 2005 | B1 |
6944678 | Lu et al. | Sep 2005 | B2 |
6963914 | Breitbart et al. | Nov 2005 | B1 |
6963917 | Callis et al. | Nov 2005 | B1 |
6985956 | Luke et al. | Jan 2006 | B2 |
6987763 | Rochberger et al. | Jan 2006 | B2 |
6996615 | McGuire | Feb 2006 | B1 |
6996616 | Leighton et al. | Feb 2006 | B1 |
7000007 | Valenti | Feb 2006 | B1 |
7009086 | Brown et al. | Mar 2006 | B2 |
7009968 | Ambe et al. | Mar 2006 | B2 |
7020698 | Andrews et al. | Mar 2006 | B2 |
7020714 | Kalyanaraman et al. | Mar 2006 | B2 |
7028083 | Levine et al. | Apr 2006 | B2 |
7031304 | Arberg et al. | Apr 2006 | B1 |
7032010 | Swildens et al. | Apr 2006 | B1 |
7036039 | Holland | Apr 2006 | B2 |
7058706 | Iyer et al. | Jun 2006 | B1 |
7058717 | Chao et al. | Jun 2006 | B2 |
7062642 | Langrind et al. | Jun 2006 | B1 |
7086061 | Joshi et al. | Aug 2006 | B1 |
7089293 | Grosner et al. | Aug 2006 | B2 |
7095738 | Desanti | Aug 2006 | B1 |
7117530 | Lin | Oct 2006 | B1 |
7126910 | Sridhar | Oct 2006 | B1 |
7127713 | Davis et al. | Oct 2006 | B2 |
7136932 | Schneider | Nov 2006 | B1 |
7139242 | Bays | Nov 2006 | B2 |
7177933 | Foth | Feb 2007 | B2 |
7177943 | Temoshenko et al. | Feb 2007 | B1 |
7185052 | Day | Feb 2007 | B2 |
7187687 | Davis et al. | Mar 2007 | B1 |
7188189 | Karol et al. | Mar 2007 | B2 |
7197547 | Miller et al. | Mar 2007 | B1 |
7206806 | Pineau | Apr 2007 | B2 |
7215637 | Ferguson et al. | May 2007 | B1 |
7225272 | Kelley et al. | May 2007 | B2 |
7240015 | Karmouch et al. | Jul 2007 | B1 |
7240100 | Wein et al. | Jul 2007 | B1 |
7254626 | Kommula et al. | Aug 2007 | B1 |
7257642 | Bridger et al. | Aug 2007 | B1 |
7260645 | Bays | Aug 2007 | B2 |
7266117 | Davis | Sep 2007 | B1 |
7266120 | Cheng et al. | Sep 2007 | B2 |
7277954 | Stewart et al. | Oct 2007 | B1 |
7292573 | LaVigne et al. | Nov 2007 | B2 |
7296088 | Padmanabhan et al. | Nov 2007 | B1 |
7321926 | Zhang et al. | Jan 2008 | B1 |
7424018 | Gallatin et al. | Sep 2008 | B2 |
7436832 | Gallatin et al. | Oct 2008 | B2 |
7440467 | Gallatin et al. | Oct 2008 | B2 |
7441045 | Skene et al. | Oct 2008 | B2 |
7450527 | Ashwood Smith | Nov 2008 | B2 |
7454500 | Hsu et al. | Nov 2008 | B1 |
7483374 | Nilakantan et al. | Jan 2009 | B2 |
7492713 | Turner et al. | Feb 2009 | B1 |
7506065 | LaVigne et al. | Mar 2009 | B2 |
7539134 | Bowes | May 2009 | B1 |
7555562 | See et al. | Jun 2009 | B2 |
7558195 | Kuo et al. | Jul 2009 | B1 |
7574508 | Kommula | Aug 2009 | B1 |
7581009 | Hsu et al. | Aug 2009 | B1 |
7584301 | Joshi | Sep 2009 | B1 |
7587487 | Gunturu | Sep 2009 | B1 |
7606203 | Shabtay et al. | Oct 2009 | B1 |
7647427 | Devarapalli | Jan 2010 | B1 |
7657629 | Kommula | Feb 2010 | B1 |
7690040 | Frattura et al. | Mar 2010 | B2 |
7706363 | Daniel et al. | Apr 2010 | B1 |
7716370 | Devarapalli | May 2010 | B1 |
7720066 | Weyman et al. | May 2010 | B2 |
7720076 | Dobbins et al. | May 2010 | B2 |
7746789 | Katoh et al. | Jun 2010 | B2 |
7747737 | Apte et al. | Jun 2010 | B1 |
7756965 | Joshi | Jul 2010 | B2 |
7774833 | Szeto et al. | Aug 2010 | B1 |
7787454 | Won et al. | Aug 2010 | B1 |
7792047 | Gallatin et al. | Sep 2010 | B2 |
7835348 | Kasralikar | Nov 2010 | B2 |
7835358 | Gallatin et al. | Nov 2010 | B2 |
7840678 | Joshi | Nov 2010 | B2 |
7848326 | Leong et al. | Dec 2010 | B1 |
7889748 | Leong et al. | Feb 2011 | B1 |
7899899 | Joshi | Mar 2011 | B2 |
7940766 | Olakangil et al. | May 2011 | B2 |
7953089 | Ramakrishnan et al. | May 2011 | B1 |
3018943 | Pleshek et al. | Sep 2011 | A1 |
8208494 | Leong | Jun 2012 | B2 |
8238344 | Chen et al. | Aug 2012 | B1 |
8239960 | Frattura et al. | Aug 2012 | B2 |
8248928 | Wang et al. | Aug 2012 | B1 |
8270845 | Cheung et al. | Sep 2012 | B2 |
8315256 | Leong et al. | Nov 2012 | B2 |
8386846 | Cheung | Feb 2013 | B2 |
8391286 | Gallatin et al. | Mar 2013 | B2 |
8504721 | Hsu et al. | Aug 2013 | B2 |
8514718 | Zijst | Aug 2013 | B2 |
8537697 | Leong et al. | Sep 2013 | B2 |
8570862 | Leong et al. | Oct 2013 | B1 |
8615008 | Natarajan et al. | Dec 2013 | B2 |
8654651 | Leong et al. | Feb 2014 | B2 |
8824466 | Won et al. | Sep 2014 | B2 |
8830819 | Leong et al. | Sep 2014 | B2 |
8873557 | Nguyen | Oct 2014 | B2 |
8891527 | Wang | Nov 2014 | B2 |
8897138 | Yu et al. | Nov 2014 | B2 |
8953458 | Leong et al. | Feb 2015 | B2 |
9155075 | Song et al. | Oct 2015 | B2 |
9264446 | Goldfarb et al. | Feb 2016 | B2 |
9270566 | Wang et al. | Feb 2016 | B2 |
9270592 | Sites | Feb 2016 | B1 |
9294367 | Natarajan et al. | Mar 2016 | B2 |
9356866 | Sivaramakrishnan et al. | May 2016 | B1 |
9380002 | Johansson et al. | Jun 2016 | B2 |
9479415 | Natarajan et al. | Oct 2016 | B2 |
9565138 | Chen et al. | Feb 2017 | B2 |
9648542 | Hsu et al. | May 2017 | B2 |
20010049741 | Skene et al. | Dec 2001 | A1 |
20010052016 | Skene et al. | Dec 2001 | A1 |
20020009081 | Sampath et al. | Jan 2002 | A1 |
20020018796 | Wironen | Feb 2002 | A1 |
20020023089 | Woo | Feb 2002 | A1 |
20020026551 | Kamimaki et al. | Feb 2002 | A1 |
20020038360 | Andrews et al. | Mar 2002 | A1 |
20020055939 | Nardone et al. | May 2002 | A1 |
20020059170 | Vange | May 2002 | A1 |
20020059464 | Hata et al. | May 2002 | A1 |
20020062372 | Hong et al. | May 2002 | A1 |
20020078233 | Biliris et al. | Jun 2002 | A1 |
20020091840 | Pulier et al. | Jul 2002 | A1 |
20020112036 | Bohannan et al. | Aug 2002 | A1 |
20020120743 | Shabtay et al. | Aug 2002 | A1 |
20020124096 | Loguinov et al. | Sep 2002 | A1 |
20020133601 | Kennamer et al. | Sep 2002 | A1 |
20020150048 | Ha et al. | Oct 2002 | A1 |
20020154600 | Ido et al. | Oct 2002 | A1 |
20020188862 | Trethewey et al. | Dec 2002 | A1 |
20020194324 | Guha | Dec 2002 | A1 |
20020194335 | Maynard | Dec 2002 | A1 |
20030023744 | Sadot et al. | Jan 2003 | A1 |
20030031185 | Kikuchi et al. | Feb 2003 | A1 |
20030035430 | Islam et al. | Feb 2003 | A1 |
20030065711 | Acharya et al. | Apr 2003 | A1 |
20030065763 | Swildens et al. | Apr 2003 | A1 |
20030105797 | Dolev et al. | Jun 2003 | A1 |
20030115283 | Barbir et al. | Jun 2003 | A1 |
20030135509 | Davis et al. | Jul 2003 | A1 |
20030202511 | Sreejith et al. | Oct 2003 | A1 |
20030210686 | Terrell et al. | Nov 2003 | A1 |
20030210694 | Jayaraman et al. | Nov 2003 | A1 |
20030229697 | Borella | Dec 2003 | A1 |
20040019680 | Chao et al. | Jan 2004 | A1 |
20040024872 | Kelley et al. | Feb 2004 | A1 |
20040032868 | Oda et al. | Feb 2004 | A1 |
20040064577 | Dahlin et al. | Apr 2004 | A1 |
20040194102 | Neerdaels | Sep 2004 | A1 |
20040243718 | Fujiyoshi | Dec 2004 | A1 |
20040249939 | Amini et al. | Dec 2004 | A1 |
20040249971 | Klinker | Dec 2004 | A1 |
20050021883 | Shishizuka et al. | Jan 2005 | A1 |
20050033858 | Swildens et al. | Feb 2005 | A1 |
20050060418 | Sorokopud | Mar 2005 | A1 |
20050060427 | Phillips et al. | Mar 2005 | A1 |
20050086295 | Cunningham et al. | Apr 2005 | A1 |
20050149531 | Srivastava | Jul 2005 | A1 |
20050169180 | Ludwig | Aug 2005 | A1 |
20050190695 | Phaal | Sep 2005 | A1 |
20050207417 | Ogawa et al. | Sep 2005 | A1 |
20050278565 | Frattura et al. | Dec 2005 | A1 |
20050286416 | Shimonishi et al. | Dec 2005 | A1 |
20060036743 | Deng et al. | Feb 2006 | A1 |
20060039374 | Belz et al. | Feb 2006 | A1 |
20060045082 | Fertell et al. | Mar 2006 | A1 |
20060143300 | See et al. | Jun 2006 | A1 |
20060256721 | Yarlagadda | Nov 2006 | A1 |
20070044141 | Lor et al. | Feb 2007 | A1 |
20070053296 | Yazaki et al. | Mar 2007 | A1 |
20070171918 | Ota et al. | Jul 2007 | A1 |
20070195761 | Tatar et al. | Aug 2007 | A1 |
20070233891 | Luby et al. | Oct 2007 | A1 |
20080002591 | Ueno | Jan 2008 | A1 |
20080028077 | Kamata et al. | Jan 2008 | A1 |
20080031141 | Lean et al. | Feb 2008 | A1 |
20080089336 | Mercier et al. | Apr 2008 | A1 |
20080137660 | Olakangil et al. | Jun 2008 | A1 |
20080159141 | Soukup et al. | Jul 2008 | A1 |
20080181119 | Beyers | Jul 2008 | A1 |
20080195731 | Harmel et al. | Aug 2008 | A1 |
20080225710 | Raja et al. | Sep 2008 | A1 |
20080304423 | Chuang et al. | Dec 2008 | A1 |
20090135835 | Gallatin et al. | May 2009 | A1 |
20090240644 | Boettcher et al. | Sep 2009 | A1 |
20090262745 | Leong et al. | Oct 2009 | A1 |
20090323703 | Bragagnini | Dec 2009 | A1 |
20100011126 | Hsu et al. | Jan 2010 | A1 |
20100135323 | Leong | Jun 2010 | A1 |
20100209047 | Cheung et al. | Aug 2010 | A1 |
20100228974 | Watts et al. | Sep 2010 | A1 |
20100293296 | Hsu et al. | Nov 2010 | A1 |
20100325178 | Won et al. | Dec 2010 | A1 |
20110044349 | Gallatin et al. | Feb 2011 | A1 |
20110058566 | Leong et al. | Mar 2011 | A1 |
20110211443 | Leong et al. | Sep 2011 | A1 |
20110216771 | Gallatin et al. | Sep 2011 | A1 |
20120023340 | Cheung | Jan 2012 | A1 |
20120103518 | Kakimoto et al. | May 2012 | A1 |
20120157088 | Gerber et al. | Jun 2012 | A1 |
20120201137 | Le Faucheur et al. | Aug 2012 | A1 |
20120243533 | Leong | Sep 2012 | A1 |
20120257635 | Gallatin et al. | Oct 2012 | A1 |
20120275311 | Ivershen | Nov 2012 | A1 |
20130010613 | Cafarelli et al. | Jan 2013 | A1 |
20130028072 | Addanki | Jan 2013 | A1 |
20130034107 | Leong et al. | Feb 2013 | A1 |
20130156029 | Gallatin et al. | Jun 2013 | A1 |
20130173784 | Wang et al. | Jul 2013 | A1 |
20130201984 | Wang | Aug 2013 | A1 |
20130259037 | Natarajan et al. | Oct 2013 | A1 |
20130272135 | Leong | Oct 2013 | A1 |
20140016500 | Leong et al. | Jan 2014 | A1 |
20140022916 | Natarajan et al. | Jan 2014 | A1 |
20140029451 | Nguyen | Jan 2014 | A1 |
20140040478 | Hsu et al. | Feb 2014 | A1 |
20140101297 | Neisinger et al. | Apr 2014 | A1 |
20140204747 | Yu et al. | Jul 2014 | A1 |
20140219100 | Pandey et al. | Aug 2014 | A1 |
20140233399 | Mann et al. | Aug 2014 | A1 |
20140321278 | Cafarelli et al. | Oct 2014 | A1 |
20150009828 | Murakami | Jan 2015 | A1 |
20150009830 | Bisht et al. | Jan 2015 | A1 |
20150033169 | Lection et al. | Jan 2015 | A1 |
20150071171 | Akiyoshi | Mar 2015 | A1 |
20150103824 | Tanabe | Apr 2015 | A1 |
20150142935 | Srinivas et al. | May 2015 | A1 |
20150170920 | Purayath et al. | Jun 2015 | A1 |
20150180802 | Chen et al. | Jun 2015 | A1 |
20150195192 | Vasseur et al. | Jul 2015 | A1 |
20150207905 | Merchant et al. | Jul 2015 | A1 |
20150215841 | Hsu et al. | Jul 2015 | A1 |
20150256436 | Stoyanov et al. | Sep 2015 | A1 |
20150263889 | Newton | Sep 2015 | A1 |
20150281125 | Koponen et al. | Oct 2015 | A1 |
20150319070 | Nachum | Nov 2015 | A1 |
20160119234 | Valencia Lopez et al. | Apr 2016 | A1 |
20160149811 | Roch et al. | May 2016 | A1 |
20160164768 | Natarajan et al. | Jun 2016 | A1 |
20160182329 | Armolavicius et al. | Jun 2016 | A1 |
20160182378 | Basavaraja et al. | Jun 2016 | A1 |
20160204996 | Lindgren et al. | Jul 2016 | A1 |
20160248655 | Francisco et al. | Aug 2016 | A1 |
20160285735 | Chen et al. | Sep 2016 | A1 |
20160285762 | Chen et al. | Sep 2016 | A1 |
20160285763 | Laxman et al. | Sep 2016 | A1 |
20160308766 | Register et al. | Oct 2016 | A1 |
20160373303 | Vedam et al. | Dec 2016 | A1 |
20160373351 | Sharma et al. | Dec 2016 | A1 |
20160373352 | Sharma et al. | Dec 2016 | A1 |
20170187649 | Chen et al. | Jun 2017 | A1 |
20170237632 | Hegde et al. | Aug 2017 | A1 |
20170237633 | Hegde et al. | Aug 2017 | A1 |
Number | Date | Country |
---|---|---|
101677292 | Mar 2010 | CN |
2654340 | Oct 2013 | EP |
3206344 | Aug 2017 | EP |
3206345 | Aug 2017 | EP |
20070438 | Feb 2008 | IE |
201641010295 | Mar 2016 | IN |
201641016960 | May 2016 | IN |
201641035761 | Oct 2016 | IN |
2010135474 | Nov 2010 | WO |
2015116538 | Aug 2015 | WO |
2015138513 | Sep 2015 | WO |
Entry |
---|
U.S. Appl. No. 61/919,244, filed Dec. 20, 2013 by Chen et al. |
U.S. Appl. No. 61/932,650, filed Jan. 28, 2014 by Munshi et al. |
U.S. Appl. No. 61/994,693, filed May 16, 2014 by Munshi et al. |
U.S. Appl. No. 62/088,434, filed Dec. 5, 2014 by Hsu et al. |
U.S. Appl. No. 62/137,073, filed Mar. 23, 2015 by Chen et al. |
U.S. Appl. No. 62/137,084, filed Mar. 23, 2015 by Chen et al. |
U.S. Appl. No. 62/137,096, filed Mar. 23, 2015 by Laxman et al. |
U.S. Appl. No. 62/137,106, filed Mar. 23, 2015 by Laxman et al. |
U.S. Appl. No. 60/998,410, filed Oct. 9, 2007 by Wang et al. |
U.S. Appl. No. 60/169,502, filed Dec. 7, 2009 by Yeejang James Lin. |
U.S. Appl. No. 60/182,812, filed Feb. 16, 2000 by Skene et al. |
PCT Patent Application No. PCT/US2015/012915 filed on Jan. 26, 2015 by Hsu et al. |
U.S. Appl. No. 14/320,138, filed Jun. 30, 2014 by Chen et al. |
U.S. Appl. No. 14/603,304, filed Jan. 22, 2015 by Hsu et al. |
U.S. Appl. No. 14/848,586, filed Sep. 9, 2015 by Chen et al. |
U.S. Appl. No. 14/848,645, filed Sep. 9, 2015 by Chen et al. |
U.S. Appl. No. 14/848,677, filed Sep. 9, 2015 by Laxman et al. |
U.S. Appl. No. 09/459,815, filed Dec. 13, 1999 by Skene et al. |
U.S. Appl. No. 14/927,478, filed Oct. 30, 2015 by Vedam et al. |
U.S. Appl. No. 14/927,479, filed Oct. 30, 2015 by Sharma et al. |
U.S. Appl. No. 14/927,482, filed Oct. 30, 2015 by Sharma et al. |
U.S. Appl. No. 14/927,484, filed Oct. 30, 2015 by Sharma et al. |
Non-Final Office Action for U.S. Appl. No. 11/827,524 dated Dec. 10, 2009, 15 pages. |
Non-Final Office Action for U.S. Appl. No. 11/827,524 dated Jun. 2, 2010, 14 pages. |
Non-Final Office Action for U.S. Appl. No. 11/827,524 dated Nov. 26, 2010, 16 pages. |
Final Office Action for U.S. Appl. No. 11/827,524 dated May 6, 2011, 19 pages. |
Advisory Action for U.S. Appl. No. 11/827,524 dated Jul. 14, 2011, 5 pages. |
Non-Final Office Action for U.S. Appl. No. 11/827,524 dated Oct. 18, 2012, 24 pages. |
Notice of Allowance for U.S. Appl. No. 11/827,524 dated Jun. 25, 2013, 11 pages. |
Non-Final Office Action for U.S. Appl. No. 14/030,782 dated Oct. 6, 2014, 14 pages. |
Non-Final Office Action for U.S. Appl. No. 13/584,534 dated Oct. 24, 2014, 24 pages. |
Restriction Requirement for U.S. Appl. No. 13/584,534 dated Jul. 21, 2014, 5 pages. |
Non-Final Office Action for U.S. Appl. No. 11/937,285 dated Jul. 6, 2009, 28 pages. |
Final Office Action for U.S. Appl. No. 11/937,285 dated Mar. 3, 2010, 28 pages. |
Non-Final Office Action for U.S. Appl. No. 11/937,285 dated Aug. 17, 2010, 28 pages. |
Final Office Action for U.S. Appl. No. 11/937,285 dated Jan. 20, 2011, 41 pages. |
Final Office Action for U.S. Appl. No. 11/937,285 dated May 20, 2011, 37 pages. |
Non-Final Office Action for U.S. Appl. No. 11/937,285 dated Nov. 28, 2011, 40 pages. |
Notice of Allowance for U.S. Appl. No. 11/937,285 dated Jun. 5, 2012, 10 pages. |
Final Office Action for U.S. Appl. No. 14/030,782 dated Jul. 29, 2015, 14 pages. |
Final Office Action for U.S. Appl. No. 13/584,534 dated Jun. 25, 2015, 21 pages. |
Notice of Allowance for U.S. Appl. No. 14/030,782 dated Nov. 16, 2015, 20 pages. |
Notice of Allowance for U.S. Appl. No. 13/584,534 dated Dec. 16, 2015, 7 pages. |
Non-Final Office Action for U.S. Appl. No. 14/320,138 dated Feb. 2, 2016, 30 pages. |
Non-Final Office Action for U.S. Appl. No. 15/043,421 dated Apr. 13, 2016, 18 pages. |
IBM User Guide, Version 2.1AIX, Solaris and Windows NT, Third Edition (Mar. 1999) 102 Pages. |
White Paper, Foundry Networks, “Server Load Balancing in Today's Web-Enabled Enterprises” Apr. 2002 10 Pages. |
International Search Report & Written Opinion for PCT Application PCT/US2015/012915 dated Apr. 10, 2015, 15 pages. |
Gigamon: Vistapointe Technology Solution Brief; Visualize-Optimize-Monetize-3100-02; Feb. 2014; 2 pages. |
Gigamon: Netflow Generation Feature Brief; 3099-04; Oct. 2014; 2 pages. |
Gigamon: Unified Visibility Fabric Solution Brief; 3018-03; Jan. 2015; 4 pages. |
Gigamon: Active Visibility for Multi-Tiered Security Solutions Overview; 3127-02; Oct. 2014; 5 pages. |
Gigamon: Enabling Network Monitoring at 40Gbps and 100Gbps with Flow Mapping Technology White Paper; 2012; 4 pages. |
Gigamon: Enterprise System Reference Architecture for the Visibility Fabric White Paper; 5005-03; Oct. 2014; 13 pages. |
Gigamon: Gigamon Intelligent Flow Mapping White Paper; 3039-02; Aug. 2013; 7 pages. |
Gigamon: Maintaining 3G and 4G LTE Quality of Service White Paper; 2012; 4 pages. |
Gigamon: Monitoring, Managing, and Securing SDN Deployments White Paper; 3106-01; May 2014; 7 pages. |
Gigamon: Service Provider System Reference Architecture for the Visibility Fabric White Paper; 5004-01; Mar. 2014; 11 pages. |
Gigamon: Unified Visibility Fabric—A New Approach to Visibility White Paper; 3072-04; Jan. 2015; 6 pages. |
Gigamon: The Visibility Fabric Architecture—A New Approach to Traffic Visibility White Paper; 2012-2013; 8 pages. |
Ixia: Creating a Visibility Architecture—a New Perspective on Network Visibilty White Paper; 915-6581-01 Rev. A, Feb. 2014; 14 pages. |
Gigamon: Unified Visibility Fabric; https://www.gigamon.com/unfied-visibility-fabric; Apr. 7, 2015; 5 pages. |
Gigamon: Application Note Stateful GTP Correlation; 4025-02; Dec. 2013; 9 pages. |
Brocade and IBM Real-Time Network Analysis Solution; 2011 Brocade Communications Systems, Inc.; 2 pages. |
Ixia Anue GTP Session Controller; Solution Brief; 915-6606-01 Rev. A, Sep. 2013; 2 pages. |
Netscout; Comprehensive Core-to-Access IP Session Analysis for GPRS and UMTS Networks; Technical Brief; Jul. 16, 2010; 6 pages. |
Netscout: nGenius Subscriber Intelligence; Data Sheet; SPDS_001-12; 2012; 6 pages. |
Gigamon: Visibility Fabric Architecture Solution Brief; 2012-2013; 2 pages. |
Gigamon: Visibility Fabric; More than Tap and Aggregation.bmp; 2014; 1 page. |
Ntop: Monitoring Mobile Networks (2G, 3G and LTE) using nProbe; http://www.ntop.org/nprobe/monitoring-mobile-networks-2g-3g-and-lte-using-nprobe; Apr. 2, 2015; 4 pages. |
Gigamon: GigaVUE-HB1 Data Sheet; 4011-07; Oct. 2014; 4 pages. |
Brocade IP Network Leadership Technology; Enabling Non-Stop Networking for Stackable Switches with Hitless Failover; 2010; 3 pages. |
Gigamon: Adaptive Packet Filtering; Feature Brief; 3098-03 Apr. 2015; 3 pages. |
Delgadillo, “Cisco Distributed Director”, White Paper, 1999, at URL:http://www-europe.cisco.warp/public/751/distdir/dd_wp.htm, (19 pages) with Table of Contents for TeleCon (16 pages). |
Cisco LocalDirector Version 1.6.3 Release Notes, Oct. 1997, Cisco Systems, Inc. Doc No. 78-3880-05. |
“Foundry Networks Announces Application Aware Layer 7 Switching on Serverlron Platform,” (Mar. 1999). |
Foundry Serverlron Installation and Configuration Guide (May 2000), Table of Contents—Chapter 1-5, http://web.archive.org/web/20000815085849/http://www.foundrynetworks.com/techdocs/SI/index.html. |
Foundry ServerIron Installation and Configuration Guide (May 2000), Chapter 6-10, http://web.archive.org/web/20000815085849/http://www.foundrynetworks.com/techdocs/SI/index.html. |
Foundry ServerIron Installation and Configuration Guide (May 2000), Chapter 11—Appendix C, http://web.archive.org/web/20000815085849/http://www.foundrynetworks.com/techdocs/SI/index.html. |
nGenius Subscriber Intelligence, http://www.netscout.com/uploads/2015/03NetScout_DS_Subscriber_Intelligence_SP.pdf, downloaded circa Mar. 23, 2015, pp. 1-6. |
Xu et al.: Cellular Data Network Infrastructure Characterization and Implication on Mobile Content Placement, Sigmetrics '11 Proceedings of the ACM SIGMETRICS joint international conference on Measurement and modeling of computer systems, date Jun. 7-11, 2011, pp. 1-12, ISBN: 978-1-4503-0814-4 ACM New York, NY, USA copyright 2011. |
E.H.T.B. Brands, Flow-Based Monitoring of GTP Trac in Cellular Networks, Date: Jul. 20, 2012, pp. 1-64, University of Twente, Enschede, The Netherlands. |
Qosmos DeepFlow: Subscriber Analytics Use Case, http://www.qosmos.com/wp-content/uploads/2014/01/Qosmos-DeepFlow-Analytics-use-case-datasheet-Jan-2014.pdf, date Jan. 2014, pp. 1-2. |
Configuring GTM to determine packet gateway health and availability, https://support.f5.com/kb/en-us/products/big-ip_gtm/manuals/product/gtm-implementations-11-6-0/9.html, downloaded circa Mar. 23, 2015, pp. 1-5. |
ExtraHop-Arista Persistent Monitoring Architecture for SDN, downloaded circa Apr. 2, 2015, pp. 1-5. |
7433 GTP Session Controller, www.ixia.com, downloaded circa Apr. 2, 2015, pp. 1-3. |
Stateful GTP Correlation, https://www.gigamon.com/PDF/appnote/AN-GTP-Correlation-Stateful-Subscriber-Aware-Filtering-4025.pdf, date 2013, pp. 1-9. |
GigaVUE-2404 // Data Sheet, www.gigamon.com, date Feb. 2014, pp. 1-6. |
nGenius Performance Manager, www.netscout.com, date Mar. 2014, pp. 1-8. |
GigaVUE-VM // Data Sheet, www.gigamon.com, date Oct. 2014, pp. 1-3. |
Unified Visibility Fabric an Innovative Approach, https://www.gigamon.com/unified-visibility-fabric, Downloaded circa Mar. 30, 2015, pp. 1-4. |
adaptiv.io and Apsalar Form Strategic Partnership to Provide Omni-channel Mobile Data Intelligence, http://www.businesswire.com/news/home/20150113005721/en/adaptiv.io-Apsalar-Form-Strategic-Partnership-Provide-Omni-channel, Downloaded circa Mar. 30, 2015, pp. 1-2. |
Real-time Data Analytics with IBM InfoSphere Streams and Brocade MLXe Series Devices, www.rocade.com, date 2011, pp. 1-2. |
Syniverse Proactive Roaming Data Analysis—VisProactive, http://m.syniverse.com/files/service_solutions/pdf/solutionsheet_visproactive_314.pdf.,date 2014, pp. 1-3. |
Network Analytics: Product Overview, www.sandvine.com, date Apr. 28, 2014, pp. 1-2. |
Notice of Allowance for U.S. Appl. No. 13/584,534 dated Jan. 6, 2016, 4 pages. |
U.S. Appl. No. 12/272,618, Final Office Action dated May 5, 2014, 13 pages. |
U.S. Appl. No. 12/272,618, NonFinal Office Action dated Jul. 29, 2013, 13 pages. |
U.S. Appl. No. 12/272,618, NonFinal Office Action dated Jan. 12, 2015, 5 pages. |
U.S. Appl. No. 12/272,618, Notice of Allowance dated Aug. 26, 2015, 11 pages. |
U.S. Appl. No. 12/272,618, Final Office Action dated Feb. 28, 2012, 12 pages. |
U.S. Appl. No. 13/925,670, NonFinal Office Action dated Nov. 16, 2015, 48 pages. |
U.S. Appl. No. 14/230,590, Notice of Allowance dated Sep. 23, 2015, 8 pages. |
U.S. Appl. No. 15/043,421, Notice of Allowance dated Jun. 27, 2016, 21 pages. |
Stateful GTP Correlation, https://www.gigamon.com/PDF/appnote/AN-GTP-Correlation-Stateful-Subscriber-Aware-Filtering-4025.pdf, date 2013, pp. 1-9.nGenius Subscriber Intelligence, http://www.netscout.com/uploads/2015/03NetScout_DS__Subscriber_Intelligence_SP.pdf, downloaded circa Mar. 23, 2015, pp. 1-6. |
Comprehensive Core-to-Access IP Session Analysis for GPRS and UMTS Networks, www.netscout.com, date Jul. 16, 2010, pp. 1-6. |
Visibility fabric Architecture, www.gigamon.com, date 2012, pp. 1-2. |
Gigamon Visibility Fabric: More than Tap and Aggregation, https://www.youtube.com/watch?v=Rb5-3To6AF0, date Sep. 12, 2014, pp. 1-1. |
The Visibility Fabric Architecture—A New Approach to Traffic Visibility, www.gigamon.com, date 2012, pp. 1-8. |
adaptiv.io and Apsalar Form Strategic Partnership to Provide Omni-channel Mobile Data Intelligence, http://www.businesswire.com/news/home/20150113005721/en/adaptiv.io-Apsalar-Form-Strategic-Partnership-Provide-Omni-channel, Downlaoded circa Mar. 30, 2015, pp. 1-2. |
U.S. Appl. No. 15/336,333, filed Oct. 27, 2016 by Vedam et al. |
U.S. Appl. No. 14/603,304, Notice of Allowance dated Jan. 11, 2017, 13 pages. |
U.S. Appl. No. 14/848,677, NonFinal Office Action dated Feb. 10, 2017, 83 pages. |
Krishnan et al.: “Mechanisms for Optimizing LAG/ECMP Component Link Utilization in Networks”, Oct. 7, 2014, 27 pages, https://tools.ietf.org/html/draft-ietf-opsawg-large-flow-load-balancing-15. |
U.S. Appl. No. 14/927,484, NonFinal Office Action dated Aug. 9, 2017, 77 pages. |
U.S. Appl. No. 14/848,677, Notice of Allowance dated Aug. 28, 2017, 31 pages. |
U.S. Appl. No. 14/320,138, Notice of Allowance dated Sep. 23, 2016, 17 pages. |
U.S. Appl. No. 15/205,889, filed Jul. 8, 2016 by Hegde et al. |
U.S. Appl. No. 15/206,008, filed Jul. 8, 2016 by Hegde et al. |
U.S. Appl. No. 14/603,304, NonFinal Office Action dated Aug. 1, 2016, 86 pages. |
U.S. Appl. No. 15/466,732, filed Mar. 22, 2017 by Hegde et al. (Unpublished). |
U.S. Appl. No. 15/467,766, filed Mar. 23, 2017 by Nagaraj et al. (Unpublished). |
U.S. Appl. No. 15/425,777, filed Feb. 6, 2017, by Chen et al. (Published). |
Joshi et al.: A Review of Network Traffic Analysis and Prediction Techniques; arxiv.org; 2015; 22 pages. |
Anjali et al.: MABE: A New Method for Available Bandwidth Estimation in an MPLS Network; submitted to World Scientific on Jun. 5, 2002; 12 pages. |
Cisco Nexus Data Broker. Scalable and Cost-Effective Solution for Network Traffic Visibility; Cisco 2015; 10 pages. |
VB220-240G Modular 10G/1G Network Packet Broker; VSS Monitoring; 2016, 3 pages. |
Big Tap Monitoring Fabric 4.5; Big Switch Networks; Apr. 2015; 8 pages. |
Gigamon Intelligent Flow Mapping—Whitepaper; 3039-04; Apr. 2015; 5 pages. |
Ixia White Paper; The Real Secret to Securing Your Network; Oct. 2014; 16 pages. |
Accedian—Solution Brief; FlowBROKER; Feb. 2016; 9 pages. |
Network Time Machine for Service Providers; Netscout; http://enterprise.netscout.com/telecom-tools/lte-solutions/network-time-machine-service-providers;Apr. 18, 2017; 8 pages. |
Arista EOS Central—Introduction to TAP aggregation; https://eos.arista.com/introduction-to-tap-aggregation/; Apr. 18, 2017; 6 pages. |
Brocade Session Director—Data Sheet; 2016; https://www.brocade.com/content/dam/common/documents/content-types/datasheet/brocade-session-director-ds.pdf; 5 pages. |
Ixia—Evaluating Inline Security Fabric: Key Considerations; White Paper, https://www.ixiacom.com/sites/default/files/2016-08/915-8079-01-S-WP-Evaluating%20Inline%20Security%20Fabric_v5.pdf; 10 pages. |
Next-Generation Monitoring Fabrics for Mobile Networks; Big Switch Networks—White Paper; 2014; 9 pages. |
Gigamon Adaptive Packet Filtering; Jan. 25, 2017; 3 pages. |
VB220 Modular 10G.1G Network Packet Broker Datasheet; VSS Monitoring; 2016; 8 pages. |
FlexaWare; FlexaMiner Packet Filter FM800PF; Jan. 27, 2017; 5 pages. |
GL Communications Inc.; PacketBroker—Passive Ethernet Tap; Jan. 27, 2017; 2 pages. |
International Search Report & Written Opinion for PCT Application PCT/US2017/025998 dated Jul. 20, 2017, 8 pages. |
Ixia & VECTRA, Complete Visibility for a Stronger Advanced Persistent Threat (APT) Defense, pp. 1-2, May 30, 2016. |
Extended European Search Report & Opinion for EP Application 17000212.5 dated Aug. 1, 2017, 9 pages. |
Extended European Search Report & Opinion for EP Application 17000213.3 dated Aug. 1, 2017, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20160373304 A1 | Dec 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14848586 | Sep 2015 | US |
Child | 14927482 | US | |
Parent | 14848645 | Sep 2015 | US |
Child | 14848586 | US |