The present disclosure relates generally to networks, and more particularly, to the automated construction of virtual interfaces (VIFs) and structures of VIFs acting as hook points for multiple network tunnels. VIFs allow for the shifting of time and resource intensive operations such as routing upstream to the VIF which were typically applied to tunnels.
Human beings are able to perceive delays of 200 ms or more as this is typically the average human reaction time to an event. If latency is too high, online systems such as thin-clients to cloud-based servers, customer relationship management (CRM), enterprise resource planning (ERP) and other systems will perform poorly and may even cease functioning due to timeouts. High latency combined with high packet loss can make a connection unusable. Even if data gets through, at a certain point too much slowness results in a poor user experience (UX) and in those instances the result can be refusal by users to accept those conditions in effect rendering poorly delivered services as useless.
To address some of these issues, various technologies have been developed. One such technology is WAN optimization, typically involving a hardware (HW) device at the edge of a local area network (LAN) which builds a tunnel to another WAN optimization HW device at the edge of another LAN, forming a wide area network (WAN) between them. This technology assumes a stable connection through which the two devices connect to each other. A WAN optimizer strives to compress and secure the data flow often resulting in a speed gain. The commercial driver for the adoption of WAN optimization is to save on the volume of data sent in an effort to reduce the cost of data transmission. Disadvantages of this are that it is often point-to-point and can struggle when the connection between the two devices is not good as there is little to no control over the path of the flow of traffic through the Internet between them. To address this, users of WAN optimizers often opt to run their WAN over an MPLS or DDN line or other dedicated circuit resulting in an added expense and again usually entailing a rigid, fixed point-to-point connection.
Direct links such as MPLS, DDN, Dedicated Circuits or other types of fixed point-to-point connection offer quality of connection and Quality of Service (QoS) guarantees. They are expensive and often take a significantly long time to install due to the need to physically draw lines from a POP at each side of the connection. The point-to-point topology works well when connecting from within one LAN to the resources of another LAN via this directly connected WAN. However, when the gateway (GW) to the general Internet is located at the LAN of one end, say at the corporate headquarters, then traffic from the remote LAN of a subsidiary country may be routed to the Internet through the GW. A slowdown occurs as traffic flows through the internet back to servers in the same country as the subsidiary. Traffic must then go from the LAN through the WAN to the LAN where the GW is located and then through the Internet back to a server in the origin country, then back through the internet to the GW, and then back down the dedicated line to the client device within the LAN. In essence doubling or tripling (or worse) the global transit time of what should take a small fraction of global latency to access this nearby site. To overcome this, alternative connectivity of another internet line with appropriate configuration changes and added devices can offer local traffic to the internet, at each end of such a system.
Another option for creating WAN links from one LAN to another LAN involve the building of tunnels such as IPSec or other protocol tunnels between two routers, firewalls, or equivalent edge devices. These are usually encrypted and can offer compression and other logic to try to improve connectivity. There is little to no control over the routes between the two points as they rely on the policy of various middle players on the internet who carry their traffic over their network(s) and peer to other carriers and/or network operators. Firewalls and routers, switches and other devices from a number of equipment vendors usually have tunneling options built into their firmware.
While last mile connectivity has vastly improved in recent years there are still problems with long distance connectivity and throughput due to issues related to distance, protocol limitations, peering, interference, and other problems and threats. As such, there exists a need for secure network optimization services running over the top of standard internet connections.
Systems and methods for connecting devices via a virtual global network are disclosed. In one embodiment the network system may comprise an endpoint device including a tunnel manager and a first virtual interface, an access point server including at least one tunnel listener and a second virtual interface. One or more communication paths or tunnels are formed connecting the tunnel managers and tunnel listeners. The virtual interfaces provide a logical point of access to the one or more tunnels.
In one embodiment the communication paths include at least one tunnel in the active state and one tunnel in the being built, standby, or deprecated state.
In other embodiments tunnels in the standby state are periodically tested to assess their viability and operational capability. Tunnels in the standby state may be kept alive with at least one of pings or keep alive traffic. In other embodiments tunnels in the active state are periodically tested to assess their viability and operational capability.
In some embodiments tunnels in the active state are transitioned to the deprecated state and tunnels in the standby state are transitioned to the active state. This transition may be based on periodic testing and determining that the quality of service (QoS) indicates that the tunnel in the standby state is the optimal tunnel and should be transitioned to be the active tunnel.
In other embodiments multiple tunnels are in the active state. During periods of low packet loss the active tunnels concurrently send unique streams of data between the endpoint device and the access point server. During periods of high packet loss the active tunnels concurrently send duplicate streams of data between the endpoint device and the access point server during periods of high packet loss.
In order to facilitate a fuller understanding of the present disclosure, reference is now made to the accompanying drawings, in which like elements are referenced with like numerals or references. These drawings should not be construed as limiting the present disclosure, but are intended to be illustrative only.
A GVN offers secure network optimization services to clients over the top of their standard interne connection. This is an overview of the constituent parts of a GVN as well as a description of related technologies which can serve as GVN elements. GVN elements may operate independently or within the ecosystem of a GVN such as utilizing the GVN framework for their own purposes, or can be deployed to enhance the performance and efficiency of a GVN. This overview also describes how other technologies can benefit from a GVN either as a stand-alone deployment using some or all components of a GVN, or which could be rapidly deployed as an independent mechanism on top of an existing GVN, utilizing its benefits.
A software (SW) based virtual private network (VPN) offers privacy via a tunnel between a client device and a VPN server. These have an advantage of encryption and in some cases also compression. But here again there is little to no control over how traffic flows between VPN client and VPN server as well as between the VPN server and host server, host client or other devices at destination. These are often point-to-point connections that require client software to be installed per device using the VPN and some technical proficiency to maintain the connection for each device. If a VPN server egress point is in close proximity via quality communication path to destination host server or host client then performance will be good. If not, then there will be noticeable drags on performance and dissatisfaction from a usability perspective. It is often a requirement for a VPN user to have to disconnect from one VPN server and reconnect to another VPN server to have quality or local access to content from one region versus the content from another region.
A Global Virtual Network (GVN) is a type of computer network over the top (OTT) of the internet providing global secure network optimization services utilizing a mesh of devices distributed around the world securely linked to each other by advanced tunnels, collaborating and communicating via Application Program Interface (API), Database (DB) replication, and other methods. Traffic routing in the GVN is always via best communication path governed by Advanced Smart Routing (ASR) powered by automated systems which combine builders, managers, testers, algorithmic analysis and other methodologies to adapt to changing conditions and learning over time to configure and reconfigure the system.
The GVN offers a service to provide secure, reliable, fast, stable, precise and focused concurrent connectivity over the top (OTT) of one or more regular Internet connections. These benefits are achieved through compression of data flow transiting multiple connections of wrapped, disguised and encrypted tunnels between the EPD and access point servers (SRV_AP) in close proximity to the EPD. The quality of connection between EPD and SRV_AP's is constantly being monitored.
A GVN is a combination of a hardware (HW) End Point Device (EPD) with installed software (SW), databases (DB) and other automated modules of the GVN system such as Neutral Application Programming Interface Mechanism (NAPIM), back channel manager, tunnel manager, and more features which connect the EPD to distributed infrastructure devices such as access point server (SRV_AP) and central server (SRV_CNTRL) within the GVN.
Algorithms continually analyze current network state while taking into account trailing trends plus long term historical performance to determine best route for traffic to take and which is the best SRV_AP or series of SRV_AP servers to push traffic through. Configuration, communication path and other changes are made automatically and on the fly with minimal or no user interaction or intervention required.
Advanced Smart Routing in an EPD and in an SRV_AP ensure that traffic flows via the most ideal path from origin to destination through an as simple as possible “Third Layer” of the GVN. This third layer is seen by client devices connected to the GVN as a normal internet path but with a lower number of hops, better security and in most cases lower latency than traffic flowing through the regular internet to the same destination. Logic and automation operate at the “second layer” of the GVN where the software of the GVN automatically monitors and controls the underlying routing and construct of virtual interfaces (VIF), multiple tunnels and binding of communication paths. The third and second layers of the GVN exist on top of the operational “first layer” of the GVN which interacts with the devices of the underlying Internet network.
The cloud from a technical and networking perspective refers to devices or groups or arrays or clusters of devices which are connected and are available to other devices through the open internet. The physical location of these devices is not of significant importance as they often have their data replicated across multiple locations with delivery to/from closest server to/from requesting client utilizing content delivery network (CDN) or other such technology to speed connectivity which enhances user experience (UX).
In addition to the broader theme of addressing quality of service (QoS) issues related to the network connectivity which improve general performance and enhance user experience, two other main features are that a GVN allows for the extension of a network edge into the cloud. Additionally, the EPD acts as a bridge between the broader network and a local area network (LAN) bringing elements of the cloud as a local node extension into the edge of the LAN. The GVN also allows for the automated construction of virtual interfaces (VIFs) and structures of VIFs acting as hook points for multiple tunnels. These VIFs allow for the shifting of time- and resource-intensive operations such as routing upstream to the VIF which were typically applied to tunnels.
The connection from the host client to the internet is marked as P01—connection from client 101 to POP 102 directly facing or can be located in a local area network (LAN) which then connects to the internet via a point of presence (POP) can be referred to as the last mile connection. The point of presence (POP) 102 which represents connection provided from an end point by an internet service provider (ISP) to the internet via their network and its interconnects. If the URL is a domain name rather than a numeric address, then this URL is sent to domain name system (DNS) server 103 where the domain name is translated to an IPv4 or IPv6 or other address for routing purposes.
Traffic from client 101 to server 301 is routed through the Internet 120 representing transit between POPs (102 and 302) including peering, backhaul, or other transit of network boundaries.
The connection P02 from POP 102 to DNS 103 to look up a number address from a universal resource locator (URL) to get the IPv4 address or other numeric address of target server can be directly accessed from the POP 102, or via the Internet 120. The connection P03 from POP 102 of an ISP to the Internet 120 can be single-honed or multi-honed. There is a connection P04 from the Internet 120 to the ISP's or internet data center's (IDC) internet-facing POP 302. The connection P05 from the POP 302 of the server to the host 301 can be direct or via multiple hops.
The lookups from name to numeric address via domain name systems is a standard on the Internet today and assumes that the DNS server is integral and that its results are current and can be trusted.
In short, the BDP calculation can represent a measure of how much data can fill a pipe before the server knows it is sending too much at too fast a rate.
The Bandwidth 4-000 can be measured in megabits per second (Mbps) and Granularity 4-002 can be unit of time relative to one second. To accurately reflect BDP, the Bytes 4-020 are divided by the number of Bits 4-022 of a system. Latency 4-050 is a measurement of round trip time (RTT) in milliseconds (ms) between the two points.
So for example, BDP of the following network path with these attributes—Bandwidth 4-000 of 10 GigE using Granularity 4-022 of one second, on an eight bit system over a path with Latency 4-050 of 220 ms—can be calculated as follows:
Therefore on a 10 GigE line, the sending device could theoretically send 33,569.3 megabytes of information (MB) in the 220 ms before a message can be received back from the recipient client device.
This calculation can also be the basis of other algorithms such as one to govern the size of a RAM buffer, or one to govern the time and amount of data that is buffered before there is a realization of a problem such as an attack vector. The throttling down by host server could lead to underutilized pipes but the accepting of too much data can also lead to other issues. The calculation of BDP and proactive management approach to issues leads to efficient utilization of hardware and network resources.
Certain other advantages with regards to timing and flow control will be described in subsequent figures below.
EPD and SRV_AP2 denote Egress/Ingress Points (EIP) from a device to/from the internet. The two sided arrow ↔ symbol indicates the routed path between two devices. This can either be directly through the internet, as a network segment OTT the internet as a tunnel or other mechanism (possibly as part of a GVN) or via other network path between devices. The point of origin is on the left and the destination implies the final location where the traffic is to be routed to/from. Paths through the GVN could be structured as a multi-dimensional array or other data pattern to denote the end-to-end path for traffic to take within the GVN.
The rating is a calculated value for a route based on a number of factors. A rating of 0.00 implies an impossible route. A rate of 1.00 implies the most perfect route with highest bandwidth at wire-line speed latency. RT_ID is the route ID number to differential one route from another both for utility, testing and logging purposes. This is utilized to determine the quality of various routes through the GVN. RT_ID is an identification for a specific route from a list of routes. The quality of service (QoS) for each route can include evaluating security, latency, packet loss, jitter, bandwidth, and other factors.
The evaluation of various measures should take into account the total path:
Total Path=GVN to Egress+Egress to destination
While evaluating total path, priority weighting in favor of the GVN over the open internet takes into account the security and optimization of the GVN to supersede certain measures.
There are three layers of the GVN—layer one is the physical network layer such as the internet on which the GVN is built over the top (OTT) of. Layer three is the GVN network layer that client devices see as a partial or complete path to destination. Layer two is the logic layer between the two.
There are components which interact with the physical conditions 9-00. Dynamic construct modules at 9-20 strive to maintain connectivity of the GVN. The joint effort section described herein links the relevant modules of the GVN to physical 9-00 and dynamic 9-20 elements. For example, in order for the advanced smart routing (ASR) module G106 to properly function, there must be multiple access point servers (SRV_AP) GP106 placed at various locations, with adequate routing and peering GR106. In order for an EPD to be able to select the most appropriate SRV_AP to establish a connection with, it needs information about which SRV_AP's are best. The ASR server availability module SA106 ranks servers for that specific EPD based on information provided by ASR test manager TM106 and when an EPD requires a new tunnel to be established, it utilizes the server availability list SA106 in order to build a new tunnel. Tests are then run on that tunnel via TM106.
As another example, for NAPIM G102 to operate it needs API listeners and handlers HL102 on a host server. On both host client and host server in the NAPIM, an operations manager OM102 is running to handle the preparation, then sending, handling, processing of API requests and responses. The dynamic construct of the NAPIM entails peer management PM102, management of related NAPIM actions AM102, and the transactions at physical TP102 and dynamic TM102.
Significant measurements at the base internet level CTN140 are LAN to GVN via EPD 10-100 to SRV_AP 10-300 for which connectivity metrics for bandwidth BW, latency Δt=A ms, Packet Loss, and other factors are evaluated. At the other end of the connection, similar measurements BW, Δt=C ms, Packet Loss and other factors at CTN142 measure the on-ramping of traffic into the GVN from EPD 10-102. Through the GVN between SRV_AP 10-300 and SRV_AP 10-302 for the GVN trans-regional OTT various internet segments CTN340 measure BW, Δt=B ms, Packet Loss, and other factors are evaluated. Overall path latency through the GVN Layer Three GVN10-3 can be calculated as the sum of the latencies of A+B+C for total in milliseconds.
At GVN Layer Three GVN10-3, ASR and other features govern how and where traffic flows through the GVN. This entails determining the best tunnel to send traffic through based on target region and traffic type, QoS of the segments through the GVN and other factors.
At GVN Layer One GVN10-1, the physical conditions of the base network connectivity are monitored and tested to determine best route options on top of which to build GVN tunnels and pathways through them. GVN pathways can transit through joined tunnels passing through SRV_AP, SRV_BBX and other GVN hardware devices. This can also determine which tunnels to make, to continue using and which to deprecate.
Mechanisms, modules and component parts at GVN Layer Two GVN10-2 help to set up, test, manage and otherwise operate the plumbing between Layer Three GVN10-3 and GVN Layer One GVN10-1. Tunnel testing can be done in Layer Three at the EPD 10-100 and at the SRV_AP 10-300 via its tunnel tester 10-312.
The first main routing decision is at a logic gate 104 within the EPOD where traffic either egresses to the local Internet 107 where the EPD is located via path P104 or if it is to go through a secure wrapped and obfuscated tunnel via P107 to the access point server (SRV_AP) 110 offering the best connectivity to the region where SRV_AP 110 is located. Prior to traffic egressing SRV_AP 110, it passes through a routing logic gate 111. Traffic to egress locally to the internet 113 will go via path P111 to either a host client 115 or a host server 116 there. If traffic is not local but rather to be relayed to another region, it will go via path P116 through a tunnel 118 to the next SRV_AP 119.
At SRV_AP 119, three of many possible routing options are illustrated by the paths that traffic can take. There is a logic gate 126 to determine if traffic should remain and egress to the local internet 129 or if it should go through a tunnel via P126 to a SRV_AP in another region 127. Another possibility is illustrated via path P119 which demonstrates a tunnel from SRV_AP 119 to another EPD 121 in a distant region. This is an EPD 103 to EPD 121 bridged via multiple bridged tunnels. A further possibility is for traffic to reach client devices 125126 in the LAN 122 where EPD 121 is located through the EPD's connection P121.
Path 12-CP00 from the Origin A Client C 12-002 to the EPD 12-108 can be used to measure the performance from the client through the LAN to the EPD. Matching of best routes is achieved after tests and evaluating real-time data of available paths. GVN ingress from EPD via first hop 12-CP00 to an access point server (SRV_AP) 12-102, 12-104, 12-106, 12-202, 12-204.
Paths from EPD to first SRV_AP can be defined as the ingress point from the EPD into the GVN and measured accordingly. Internal hops from SRV_AP to SRV_AP follow internal routes which always try to maintain the best path connectivity. These could be OTT internet, over backbone, over dark fiber, or other related routing.
Best egress points out of the GVN are also kept track of locally, in that remote region and also holistically for the entire network segment from origin to destination.
Tests can be run on each segment, combinations of segments, and the total network path from end to end taking into account various factors to evaluate. Traffic type and path determination can be depending on data attributes and profile QoS requirements. The main path choice is always based on best factors for traffic over path. A function of this mechanism is to match paths between destination and origin to flow for best possible bidirectional route. Traffic for target destination flows via the most ideal egress ingress point (EIP) for that specific destination.
Various database tables can be maintained to support and govern route management in the advanced smart routing mechanism:
The above information is described as being stored in database tables as one example of storage to assist in this description. It could also be stored as lists in flat files, in memory or on disk, or in various other formats. Some or all of the routing information can be utilized to determine best route for traffic to take by matching destination to EIP via the best path.
As shown by this example, it is important to understand the characteristics of each segment and how that segment impacts the traffic flow with respect to the complete end-to-end pathway. An internal network or LAN 13-N100 will typically have a reasonable amount of bandwidth (BW) for internal use such as BW 13-B100 which is 10 GigE in size. The bandwidth for an ISP's network 13-N202 will also typically be fairly large as exemplified by BW 13-B202 of 40 GigE. Between those two networks, a last mile connection 13-N200 between the client location and the ISP is a relatively small 13-B200 BW of 100 Mbps. There are numerous drivers behind this but the main one is cost. An ISP will bring a pipe to a neighborhood of a bandwidth of a certain size and then will usually share this amount with many different users to each of their last mile connections. These upstream paths are the beginning segments towards the broader and wider general internet.
A backbone 13-N220 connects ISPs to each other, regions to regions, and more and backbones offer very deep and high bandwidth connectivity such as 13-B220 of 100 GigE. This could represent the carrying capacity of a strand of fiber between two points, and/or the size of the switch's capacity rating or other factors.
The internet 13-N250 in this figure is represented by dual pipes of BW 13-B250 and 13-B252 each at 40 GigE. This is an example of a multi-honed connectivity in an internet. There may be many other large pipes at the core of an internet connected together.
ISP peering 13-N320 between the internet 13-N250 and an IDC network 13-N310 is represented again by multi-honed connectivity BW of 10 GigE each for 13-B320, 13-B322, and 13-B328. This represents dedicated last mile for that data center. There may be many more communication links for an IDC.
The internal IDC network 13-N310 will typically have very high BW 13-B310 distributed amongst various internal networks which each is rated to a certain speed such as 100 GigE. The notation 2*100 GigE represents that this is a network two times 100 GigE BW.
There are several factors which influence the flow of traffic through a hop including the bandwidth of the two network segments, the physical capacity for carrying traffic through Device B 14-020, the current level of traffic flowing through it and corresponding congestion, and other factors.
Another problem 15-Problem 402 such as filtering 15-PR402 on the Device 15-020 could significantly slow down the traffic transiting through the hop 15-H020. Some kinds of filtering may block a traffic type entirely or firewall operations such as deep packet inspection (DPI) require time and resources adding to the latency through a hop.
Congestion related 15-PR404 problems 15-Problem404 have to do with the volume of traffic as measured by bandwidth or could also be related to the problem of too many concurrent connections established by various streams of data through the hop 15-H020, a combination of both, and/or other factors.
Other problem 15-Problem408 issues such as device malfunction 15-PR408 can cause unpredictable and detrimental drags on traffic through the hop 15-H020.
Problems 15-Problem410 such as BDP related issues 15-PR410 occur when one segment is larger than another segment. If inbound traffic from the larger segment enters Device 15-020 the smaller segment cannot accept the entirety of the volume. The device may try buffering the excess traffic in RAM to be sent when the data flow abates. If the RAM or other buffer completely fills up, the result will be packet loss.
There can also be other problems 15-Problem412 which have a direct impact on the efficiency of traffic flow through a hop, however these may be unknown problems 15-PR412 and as such the only viable remedy may be to route traffic around that hop.
Other problems may be possible and occur through a hop. The key point is that the result of problems through a hop are high latency, packet loss, constricted bandwidth and other effects which adversely affect traffic flow. A follow-on consequence of packet loss through a hop is the perverse result of sending devices resending dropped packets which can cause a cascading effect due to even more packets trying to get through an already oversaturated hop.
The tunnel establishment process 16-000 steps from Tunnel State: Down 16-200 through to Tunnel State: Up 16-202. It begins with the first step Begin Tunnel Build 16-100. Prepare Tunnel Info 16-102 begins with the client device gathering information about the server to which it desires to build a tunnel with. If a peer pair relationship exists, and if the information is current, then the client device will use that information. If there does not exist a peer pair relationship, or if there is no tunnel information which could be used by the devices to build a tunnel between them, or if the peer pair relationship info or tunnel info are stale, then an API call to a SR_CNTRL (e.g. SRV_CNTRL 17-200 in
The next step, Secure hand shake C with S 16-104, is initiated by the client with call to the server. The initial server check may validate a finger print and identifiers of client may verify that it is entitled to interact with the server. A TLS handshake may be used for each device to tell the other who it is and to exchange keys with which to use to create an encrypted connection between them so that they can talk with each other. During regular tunnel establishment, there is risk that the tunnel can be sniffed and interfered with such as by the deliberate injecting of a TCP_RST reset packet sent to break the flow of traffic between the two tunnel peers.
The next step, Info Exchange CS↔16-106, includes information specific to the building of the tunnel, including credentials, keys, network parameters, configuration settings, and other information. The settings between both sides must match or there may be problems with tunnel building.
The next step, Construct tunnel+encrypt 16-108, will use the information about the tunnel to construct the encrypted tunnel and to prepare it to send traffic. The traffic begins to flow here.
The next step, Apply routing+hook 16-110, is where routes are applied to the tunnel determining which traffic should go through the traffic and which traffic should stay within the client device to be handled by the next internal interface there.
The next step, Apply on-Up actions 16-112, can include on up triggers to execute scripts, subroutines, or other actions to log tunnel up event in a database, to check routes, and do other housekeeping such as testing, applying routes, and if IP forwarding is required to automatically set that up, or to take other actions.
At a certain point after the tunnel is constructed at the step Construct tunnel+encrypt 16-108, the tunnel is ready and able to carry traffic.
Depending on the size and complexity of the routing table applied at the Apply routing+hook 16-110 step, a relatively significant amount of time may pass between the start and finish of the route building.
Since traffic may already be flowing through the tunnel during route building, an unpredictable, systemic behavior effecting traffic flow may occur. Some traffic may go through the tunnel while other traffic may not go through. Leakage is therefore an unintended consequence of this period of time during route building leading to potential security issues, potential for lost packets in a stream, as well as other issues. For example the reciprocal host device in a stream may get confused on where to send the traffic back to since the start of the stream was flowing from an edge IP address on the first device which is suddenly changed to the IP address on edge of the server device once the tunnel is up.
When a tunnel goes down, it suddenly drops sending all traffic out of the tunnel and inboard tunnel traffic cannot find the end point of the tunnel which no longer exists and new tunnel build process has to wait for cleanup of routes and for the tunnel destruction process 16-040 of the first tunnel to complete. Furthermore, the end result is an issue of gaps in the protections afforded by the tunnel as well as unstable routing leading to broken connections. The new tunnel needs time to build before it can be ready to carry traffic dependably.
The Tunnel Destruction Process 16-040 describes the steps in order from Tunnel State: Up 16-202 back to Tunnel State: Down 16-200. The causes for a tunnel to break may be an intentional clean stop order or an unintentional non-clean stop due to a broken underlying connection, a poor connection with too high latency or too much packet loss, or if there are not enough system resources to maintain the tunnel, or other reason(s).
The Apply on-Down actions 16-142 step execute scripts such as capturing temp log files and saving their data in database tables, in log files, or other forms of permanent storage. An entry into a database log can note the tunnel down event. This step can also communicate via API with ASR managers and tunnel managers to notify state change of the tunnel. Each device can take actions independently or in collaboration with other devices according to need.
The next step, Apply routing changes 16-144, removes routes from the tunnel as well as removal of the tunnel's entrance and exit route entries. Until routes are flushed, then traffic can be effectively blocked as if the tunnel is no longer up but traffic routed to it, then there is nowhere for the traffic to go. Once routes are removed, traffic can flow around the old tunnel.
The orderly break down 16-146 and free up resources 16-148 steps complete the removal of the tunnel.
The steps to build TUN017-CP80 include 17-S1 Handshake, 17-S2 Info Exchange, and 17-S3 Tunnel Build. In order for the Tunnel Manager (Builder) 17-D110 on EPD 17-100 to build the TUN017-CP80, it needs certain information about the SRV_AP 17-300 which it can connect with to build the tunnel, information about the tunnel, and more. In order for the Tunnel Manager (Listener) 17-D310 on SRV_AP 17-300 to accept the handshake 17-S1 from EPD 17-100's Tunnel Manager (Builder) 17-D110, to negotiate information exchange 17-S2, and then to build the tunnel 17-S3, it also requires similar information. For example, the port and IP address assignment on SRV_AP 17-300 should be unique to prevent conflicts. In addition, certificates, credentials such as password, and supporting information for advanced tunnel features such as wrapping and/or capping also need to be known by both peers when building a tunnel.
For non-stable, dynamically changing information used for tunnel building, a client device such as an end point device (EPD) 17-100 will need to share info with a server such as an access point server (SRV_AP) 17-300 prior to the Tunnel Manager (Builder) 17-D110 being able to interact with the Tunnel Manager (Listener) 17-D310 on an SRV_AP 17-300.
Tunnel security involves not just the aspects and attributes of the actual tunnel while up but also covers various stages during a tunnel life cycle. There exists a need to share and to protect keys, credentials, configuration, and other settings. By each device collaborating with an SRV_CNTRL 17-200 to share information pertinent to the other, this can protect the sending, generation, publishing, updating, and more handling of the information. Handshake and key exchange can be protected via encryption and also via capped connections. While up, the tunnel may be protected by encryption and also obfuscation via a cap.
The next process, Plot route options (ASR) 19-200, utilizes sub processes server availability list 19-210 and routes list ranked 19-220 to determine the most optimal server(s) with which to build tunnels if they do not exist.
The next process, Examine network segments 19-300, utilizes sub processes measure segments 19-310 and network statistics per path 19-320 to evaluate the viability of a path to be used to send the type of traffic required. For example for very small sized data which requires the fastest path, then the shortest distance and lowest latency are of most importance and low bandwidth may be tolerated. Conversely for huge sized data which is not time sensitive in terms of delivery of the first bit, the path offering the highest bandwidth is optimal because although first bit delivery is slower than the other path, last bit arrival is expected to happen sooner due to the higher bandwidth.
The next process, Check route status 19-600, utilizes sub processes Compare routes 19-610 and Test: is total path complete 19-620 to ensure the deliverability of data down that path.
The last process, Plot best route for traffic 19-700, utilizes sub processes sub-algo: which is best path? 19-710 and Is this path best for traffic type? 19-720 to determine and set the best route end-to-end.
Each process and sub process are utilized to ensure that each type of traffic is carried most optimally by the tunnel best suited for that traffic type.
Deprecated tunnels to be orderly destroyed 20-340 is where tunnels which had been built and either used or not used and are no longer to be used, are destroyed.
Active tunnels with routed traffic 20-300 is where healthy tunnels are up and connected, able to push traffic to one or more access point servers (SRV_AP). A key advantage of having multiple active tunnels connected to a VIF is that an instantaneous switch of traffic from one tunnel to another tunnel can be made without any lost or leaked data.
Tunnels being built 20-310 is where new tunnels are being built between the EPD 20-100 and an SRV_AP.
Standby tunnels ready for utilization 20-320 is where built tunnels are up and functional between the EPD 20-100 and an SRV_AP, but are not in a production state actively handling traffic. Tunnels in standby mode have periodic tests run on them to assess their viability and their operational state. They also are kept viable by pings or regular sending of keep alive traffic.
The life cycle of tunnels attached to the VIF are that new tunnels get built as needed, these new tunnels are put in standby and tested. When an active tunnel experiences a problem and needs to be deprecated and destroyed, a standby tunnel can be turned active to replace it. Deprecated tunnels are destroyed in an orderly manner freeing resources for future new tunnels to utilize.
If the traffic is not optimal, the logic flows via path No CP304 to a check any other tunnels available? 21-310 to check if there is another tunnel available. If another tunnel does not exist, the logical path No CP320 leads to Tunnel Builder: Create new tunnel 21-320 and once up, the process build routes for TUN 21-330 is executed. Alternatively, if a tunnel does exist, then logical path Yes 21-CP352 leads or path for newly created tunnel from 21-320 are sent to step tunnel test suite to evaluate alt. tunnel(s) 21-350. The process evaluate TUN switch 21-360 compares the quality of service (QoS) for both tunnels.
The decision gate Switch to other TUN? 21-400 evaluates where or not it is worthwhile to switch the flow of traffic via Make TUN switch 21-510 or to keep the traffic flowing through the current TUN via path No CP308.
Parameters governing switch logic include tunnel tolerance which may be set by user preference, or algorithmic analysis of current conditions, or other factors. Tunnel condition logs can be used for comparison of current and historical metrics and can help to make most efficient contextual switch decision making. Metrics of tunnel state also can be used for comparison of sets of tunnels relative to each other.
Type and nature of current traffic flowing through the tunnel such as the volume of traffic, the likelihood that a switch would break the flow of traffic, and other factors are also considered when deciding whether or not to switch to another tunnel.
Each virtual interface has tunnels at various TUN life cycle stages as described in
Two standby VIFs and corresponding tunnels are VIF06 Alt. Region A 23-116 and VIF08 Alt. Region B 23-126. The difference between VIF00 and VIF06 is that the alternative standby VIF06 has only building 23-316 and standby tunnels Standby 23-318.
For example—time consuming, rare, and slow procedures 23-540 and 23-520 of building virtual interfaces, adding routes, and related processes take a lot of time but do not happen very often.
And since tunnel routing has been shifted upstream to the VIF, the tunnel operations are relatively extremely fast and often procedures 23-530 and 23-500.
When one virtual interface such as VIF00 Region A 23-110 becomes unviable, then the logical flow of traffic 23-P110 can be shifted to path 23-P116 to the a standby VIF VIF06 Alt. Region A 23-116 in operation with tunnels to that VIF's target region up and ready. The shift from one VIF to another is an extremely fast and rare procedure 23-510.
Traffic at VIF02 Region B 24-120 is then checked against a List of IP Addresses for Region B 24-620. If there is a match, then traffic is sent down an Active 24-302 tunnel. If no match, then the traffic continues along sequential path via 24-122 to the next VIF and so on.
If there is no match for traffic for Region A, Region B, or Region C, then it continues along the sequential path to Other traffic 24-140 where it can either egress on the open internet, be captured in a buffer, blackholed, or otherwise routed.
Total Time: Regular Tunnel—to be built or rebuilt 26-180 outlines the time and steps required to build and bring up a tunnel TUN026-100.
Total Time: VIF to be built or rebuilt and at least one TUN to be added 26-280 outlines the time and steps required to build and bring up a virtual interface VIF026-200 and attach a first tunnel ready to push traffic.
Total Time: Tunnel on VIF—to be built or rebuilt 26-380 outlines the time and steps required to build a subsequent tunnel TUN226-300 on to a VIF.
Total Time: Tunnel on VIF—switch traffic to 26-880 outlines the time and one step required to switch traffic from one tunnel to another tunnel TUN826-800 attached to a VIF.
Total Time: Tunnel on VIF—to be destroyed 26-380 outlines the time and step required to deprecate a tunnel TUN426-400.
This figure is not to scale but shows the relative the time advantages of building tunnels on to virtual interfaces with routing applied to the VIF upstream from the TUNs.
For the VIF08 to be activated, the flow of traffic has to be routed via 28-P120 to it. And from VIF08 Region B 28-126 to VIF04 Region C 28-130 via path 28-P130.
As noted in
It also ensures that an alternative VIF is available 29-116 and that this alternative VIF is available 29-210, connected 29-250 and if so via path 29-CP260, then the process of destroying the VIF begins at 29-260. A final check is made to ensure that the VIF has actually been removed 29-278.
If an alternative VIF is not available 29-210, the logic flows via path 29-CP220 to a process to build 29-220 and to test the new VIF 29-230.
In this example, 32-ATTK02 results in the interception of Scrambled Data 32-444. The scrambler for the CAP can be based on exclusive disjunction using rotating keys and other logic to scramble the data payloads.
This figure also describes packet bloat due to the extra layers of security which has the effect of reducing the payload's carry size.
This mechanism can be used both to calculate IP addresses, IP address range assignments and other factors which can be used either by automated systems, or can be the basis of messaging to network administrators for them to make manual configuration or to take other actions.
In this figure, EPD 40-100 builds tunnels with SRV_APs 40-300, 40-302 and 40-306. EPD 40-102 builds tunnels with SRV_APs 40-300, 40-304, and 40-308.
This example demonstrates how the internal IP range 10.10.191.0 through 10.10.191.255 can be used on two SRV_APs 40-302 and 40-304, and IP range 10.10.192.0 through 10.10.192.255 can be used on both SRV_AP 40-306 and 40-308.
Therefore for example, 10.10.191.18 can but used by EPD 40-100 to build a tunnel to SVR_AP 40-302 and at the same time 10.10.191.18 can also be used by EPD 40-102 to connect with SRV_AP 40-304.
EPD 40-100 and EPD 40-102 do not have to directly interact with each other to avoid conflicts because the server availability list published for each EPD in coordination with the TUN manager will assign IP address (internal and external) combinations for EPDs to connect with SRV_APs without any conflicts.
Sending parallel streams consumes more traffic and bandwidth. However, during periods of unstable network connectivity, the traffic still gets through due to the redundancy. So in the event that a user has a 20 Mbps last mile connection, if there is a high amount of packet loss on a single stream the user experience (UX) may be less than idea due to timeouts, broken video streams, and other undesirable effects.
If a stream is duplicated, the effective size of the last mile pipe is reduced to 10 Mbps or less, however the data will get through improving UX. As an extension of this, a for example if duplication of a stream is quadrupled, the bandwidth reduction is decreased fourfold. So a 20 Mbps condition could be reduced to 5 Mbps or less, however, the link will continue to perform.
If during periods of micro-outages 43-P330, the SWM can recognize the situation, and keep the VIFs and TUNs up. Traffic may be buffered, connectivity kept alive, and when the outage is over, an orderly catch up with the stream by gently releasing content from the buffer.
The key to stormy weather mode taking action is to correctly understand the conditions and to take appropriate remedial actions.
When a server begins to serve a stream of data or a file, it will blast many packets per second based on what it assumes to be the high bandwidth of a network segment 45-100. The server is connected to this large pipe network segment.
If the data stream is constricted at 45-300, it forces the server to aggressively throttle down the stream slowing transfer, and due to the need to retransmit the lost packets, the server may reduce rate of transfer overly aggressively slowing down the total process.
After testing, other processes are run at post-running of tests to clean up, and free resources 48-300. At the end of testing, log test results 48-320 saves pertinent information.
The next step allocates and uses free capacity to run tests 49-1200 so that the tests do not steal bandwidth from users which could have a detrimental effect on their UX.
At the analyze connectivity 49-1300 step, both the connectivity tests and real user usage are taken into account in aggregate and individually to analyze connectivity.
Tests run during work hours when a “production” network is busy will be run in a manner where they do not effect work flow. Test runs during off hours may not provide accurate information of a broader network under load because they can't detect individual congestion issues which occur when multiple parties are also using network resources.
Tests run on a busy network may interrupt workflow and while necessary to diagnose problems, if run too often and given right to monopolize too many resources, then the test could become a contributing factor to the problem.
Total network usage can be measured by analyzing traffic down path 49-CP306.
Local only traffic may be ascertained by totaling all tunnel traffic and subtracting that sum from the traffic through 49-CP306 with the remainder being local traffic.
In order for tunnel TUN 50-100300 to be built, certain information about the tunnel, about the peers in the pairing, and other information can be shared by the API.
Information about which SRV_AP 50-300 an EPD 50-100 should connect with is available via a server availability list which is generated on the SRV_CNTRL 50-200.
The tunnel is initiated on the EPD 50-100 by the Tunnel Builder 50-112. It is governed by the Tunnel Manager which in turn gathers information from Tunnel Info 50-116 for settings, Index of tunnels 50-118, and save tunnel information 50-122.
The tunnel listener 50-312 operates on the SRV_AP 50-300 and is governed by the tunnel manager 50-310. Information on each device can be stored in RAM, in a database 50-B100, 50-B300, and 50-B200, or on a disk 50-H100 or 50-H300, or other form of storage (not shown).
This figure illustrates the connection from devices to the SRV_AP 52-300, such as EPD 52-100 to port 26158 via 52-P100, EPD 52-102 to port 9836 via 52-P102, from PEPD 52-110 to port 45373 via 52-P110, EPD 104 to port 33172 via 52-P104, PEPD 52-112 to port 15942, and EPD 52-106 to port 51625 via 52-P106.
The tunnel listener 52-312 will only open those ports to which it expects tunnels to be built upon and will close the rest. Furthermore, only connections from known peers will be accepted. The ports assigned to TUNs via the server availability mechanism are unique and random. The type of tunnel cannot be identified by the port used. Unique, non-conflicting subnets will also be assigned via the tunnel listener governed by the server availability listing and tunnel manager 52-310.
The first step is to gather parameters 53-010 for the port to IP address assignment by checking to see if desired port and IP_Address have been specified to be used by a specific device by its Device_ID, and other factors. The parameters also delineate a floor value and a roof value for port number, and more governing settings.
The logic gate IP+Port specified? 53-020 step checks to see if there is a request for a specific port attached to a specific IP address for a server device by Device_IP.
If the port and IP address have been specified, then the availability for their use is accepted and logic follows path Yes 53-P022. If a preferential port and IP are not specified then logic follows path No 53-P030 to random number generator for a random port to be generated within range 53-030.
A lookup is done at step 53-050 to check against current and historical use (via path 53-B102 to Db Registry 53-B100) for that port to IP address mapping to see if the port is free or if it is currently in use. A secondary check is done by looking at historical use to see if it indicates if that port and IP combination has been used in the past by this device or other devices, and if so, if that use proved to be relatively problematic. Some unstable or unreliable ports due to filtering or congestion through devices or other reasons can be marked as being problematic. If there is also a trend for blocking of problematic ports for other devices, then the port to IP address combination can be marked as unavailable.
If the port is not available at step 53-060, the process of generating a port to IP address mapping is restarted via junction point 53-012.
If the port is available, then the port to IP address will be assigned for use at step 53-100. This assignment will be saved in the Db registry 53-B100 via path 53-B112. Next, the Port to IP Address assignment is published via an API call 53-120 so that relevant devices know about the availability status of the port. The last step is to log the assignment 53-130 of port to IP address including the logic used and other factors which could assist in improving the efficiency of future port assignments.
At the process results, add to results array, prep for log 54-090 step, ongoing statistical analysis can be run on the current test compared with the other tests run in the series.
The egress ingress point (EIP) 57-212 on an access point server (SRV_AP) 57-202 will carry traffic received at the specific port on the IP address via path 57-CP010 through the tunnel TUN 57-202 to EPD 57-100 via LAN 57-102 to the LAN Device 57-108.
If no port is specified, the traffic via 57-CP012 Dedicated IP address can be forwarded to the EPD 57-100 and can be handled via 57-118.
gTLD stands for global top level domain. The registry further stores information for individual devices located in the local area network (LAN) behind an EPD or a personal area network (PAN) behind a PEPD. For example PC.domain100.gTLD will find PC 60-128 via path 60-P128 which is in the internal network behind EPD 60-100. Security settings can also govern whether or not devices within a LAN are reachable from the open internet, or only from known source IP addresses, or only from within the GVN, or from known EPD's, or via other rules.
The list of domains.gTLD and associated subdomains is managed and upon “saving” or “committing”, the changes are shared to SRV_CNTRL (Internal) Repository 62-200 via its API 62-222 to be saved in the database there 62-B300. The VEP Manager 62-380 publishes this information to the domain registrar server (SRV_DREG) 62-026, the domain name server (DNS) server (SRV_DNS) 62-022, and to the nameserver server (SRV_NS) 62-028.
The GVN can include plug-in and/or stand-alone GVN modules G100 including but not limited to: Neutral API Mechanism (“NAPIM”) G102, described in PCT/US16/12178; Geodestination (“Geo-D”) G104, described in PCT/US15/64242, Advanced Smart Routing (“ASR”) G106, Connect G108, and other modules G110 described in U.S. Provisional Application 62/151,174.
The GVN also provides a platform which can enable other technologies including but not limited to: Network Tapestry G202; MPFWM G204; Network Slingshot G206; Network Beacon G208, Granularity of a tick G210, and other technologies G212. These are described in in U.S. Provisional Application 62/174,394, U.S. Provisional Application 62/266,060.
GVN Modules (G100) and Technology (G200) enabled by GVN can operate on top of an existing GVN, as a component part of a GVN, or can be independent and utilize all or some isolated parts of a GVN to support their own stand-alone operations.
RAM stands for random access memory, CPU for central processing unit (which can also include sub-processors), NIC for network interface card, Db for database software, DNS for domain name system, HOST for hosting software, API for application programming interface, ASR for advanced smart routing, GeoD for geodestination, GVN for global virtual network, CDA for content delivery agent, CPA for content pulling agent, and RF BOT for remote fetcher bot. There may be additional modules, mangers, systems, or software components.
This application is a continuation of U.S. patent application Ser. No. 15/563,246, filed Sep. 29, 2017, which is a U.S. National Stage application under 35 U.S.C. § 371 of International Patent Application No. PCT/IB2016/000531, filed, Apr. 7, 2016, which claims priority to U.S. Provisional Application No. 62/144,293 filed on Apr. 7, 2015 and U.S. Provisional Application No. 62/151,174 filed on Apr. 22, 2015. The entire content of each application is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4890281 | Balboni | Dec 1989 | A |
5828847 | Gehr et al. | Oct 1998 | A |
5893089 | Kikinis | Apr 1999 | A |
5940838 | Schmuck et al. | Aug 1999 | A |
6209039 | Albright et al. | Mar 2001 | B1 |
6289201 | Weber et al. | Sep 2001 | B1 |
6374302 | Glasso et al. | Apr 2002 | B1 |
6463465 | Nieuwejaar | Oct 2002 | B1 |
6477166 | Sanzi et al. | Nov 2002 | B1 |
6593863 | Pitio | Jul 2003 | B2 |
6611587 | Brown et al. | Aug 2003 | B2 |
6671361 | Goldstein | Dec 2003 | B2 |
6678241 | Gai et al. | Jan 2004 | B1 |
6693876 | Zey | Jan 2004 | B1 |
6690223 | Wan | Feb 2004 | B1 |
6735207 | Prasad et al. | May 2004 | B1 |
6785295 | Graf et al. | Aug 2004 | B1 |
6879995 | Chinta et al. | Apr 2005 | B1 |
6973048 | Pitio | Dec 2005 | B2 |
6996117 | Lee et al. | Feb 2006 | B2 |
7006505 | Bleszynski et al. | Feb 2006 | B1 |
7039701 | Wesley | May 2006 | B2 |
7069318 | Burbeck et al. | Jun 2006 | B2 |
7145882 | Limaye et al. | Dec 2006 | B2 |
7145922 | Pitio | Dec 2006 | B2 |
7161899 | Limaye et al. | Jan 2007 | B2 |
7161965 | Pitio | Jan 2007 | B2 |
7173902 | Daniell et al. | Feb 2007 | B2 |
7177929 | Burbeck et al. | Feb 2007 | B2 |
7221687 | Shugard | May 2007 | B2 |
7224706 | Loeffler-Lejeune | May 2007 | B2 |
7254833 | Cornelius et al. | Aug 2007 | B1 |
7269130 | Pitio | Sep 2007 | B2 |
7310348 | Trinh et al. | Dec 2007 | B2 |
7349403 | Lee et al. | Mar 2008 | B2 |
7349411 | Pitio | Mar 2008 | B2 |
7349435 | Giacomini | Mar 2008 | B2 |
7389312 | Ohran | Jun 2008 | B2 |
7433964 | Raguram et al. | Oct 2008 | B2 |
7551623 | Feroz et al. | Jun 2009 | B1 |
7577691 | Novik et al. | Aug 2009 | B2 |
7584285 | Hudson | Sep 2009 | B2 |
7587487 | Gunturu | Sep 2009 | B1 |
7633909 | Jones et al. | Dec 2009 | B1 |
7689722 | Timms et al. | Mar 2010 | B1 |
7742405 | Trinh et al. | Jun 2010 | B2 |
7742411 | Trinh et al. | Jun 2010 | B2 |
7801030 | Aggarwal | Sep 2010 | B1 |
7822877 | Chong et al. | Oct 2010 | B2 |
7870418 | Sekaran et al. | Jan 2011 | B2 |
7886305 | Ahmed et al. | Feb 2011 | B2 |
7930339 | Tobita et al. | Apr 2011 | B2 |
7957311 | Trinh et al. | Jun 2011 | B2 |
8010751 | Yang et al. | Aug 2011 | B2 |
8064909 | Spinelli et al. | Nov 2011 | B2 |
8069258 | Howell | Nov 2011 | B1 |
8069435 | Lai | Nov 2011 | B1 |
8073777 | Barry et al. | Dec 2011 | B2 |
8107363 | Saluja | Jan 2012 | B1 |
8239915 | Satish et al. | Aug 2012 | B1 |
8259571 | Raphel et al. | Sep 2012 | B1 |
8266672 | Moore | Sep 2012 | B2 |
8401028 | Mihaly et al. | Mar 2013 | B2 |
8422397 | Ansari et al. | Apr 2013 | B2 |
8437641 | Lee et al. | May 2013 | B2 |
8458786 | Kailash | Jun 2013 | B1 |
8544065 | Archer et al. | Sep 2013 | B2 |
8611335 | Wu et al. | Dec 2013 | B1 |
8611355 | Sella et al. | Dec 2013 | B1 |
8625411 | Srivivasan et al. | Jan 2014 | B2 |
8687791 | Cordell et al. | Apr 2014 | B1 |
8699683 | Jackson | Apr 2014 | B1 |
8769057 | Breau et al. | Jul 2014 | B1 |
8798060 | Vautrin et al. | Aug 2014 | B1 |
8838823 | Guo | Sep 2014 | B2 |
8854965 | Richards | Sep 2014 | B1 |
8861344 | Trinh et al. | Oct 2014 | B2 |
8874680 | Das | Oct 2014 | B1 |
8966075 | Chickering et al. | Feb 2015 | B1 |
8976798 | Border et al. | Mar 2015 | B2 |
9015310 | Ochi | Apr 2015 | B2 |
9038151 | Chua et al. | May 2015 | B1 |
9110820 | Bent et al. | Aug 2015 | B1 |
9164702 | Nesbit et al. | Oct 2015 | B1 |
9164795 | Vincent | Oct 2015 | B1 |
9167501 | Kempf et al. | Oct 2015 | B2 |
9172603 | Padmanabhan et al. | Oct 2015 | B2 |
9213594 | Strasser et al. | Dec 2015 | B2 |
9241004 | April | Jan 2016 | B1 |
9253028 | DeCusatis et al. | Feb 2016 | B2 |
9277452 | Aithal et al. | Mar 2016 | B1 |
9294304 | Sindhu | Mar 2016 | B2 |
9294497 | Ben-Or et al. | Mar 2016 | B1 |
9298719 | Noronha et al. | Mar 2016 | B2 |
9350644 | Desai et al. | May 2016 | B2 |
9350710 | Herle et al. | May 2016 | B2 |
9351193 | Raleigh et al. | May 2016 | B2 |
9369433 | Paul et al. | Jun 2016 | B1 |
9432258 | Van der Merwe et al. | Aug 2016 | B2 |
9432336 | Ostrowski | Aug 2016 | B2 |
9450817 | Bahadur et al. | Sep 2016 | B1 |
9455924 | Cicic et al. | Sep 2016 | B2 |
9461996 | Hayton et al. | Oct 2016 | B2 |
9525663 | Yuan et al. | Dec 2016 | B2 |
9525696 | Kapoor et al. | Dec 2016 | B2 |
9544137 | Brandwine | Jan 2017 | B1 |
9554061 | Proctor et al. | Jan 2017 | B1 |
9565117 | Dahod et al. | Feb 2017 | B2 |
9569587 | Ansari et al. | Feb 2017 | B2 |
9590820 | Shukla | Mar 2017 | B1 |
9590902 | Lin et al. | Mar 2017 | B2 |
9609003 | Chmielewski et al. | Mar 2017 | B1 |
9609482 | Want et al. | Mar 2017 | B1 |
9641612 | Yu | May 2017 | B2 |
9661050 | Killick | May 2017 | B2 |
9699001 | Addanki et al. | Jul 2017 | B2 |
9699135 | Dinha | Jul 2017 | B2 |
9729539 | Agrawal et al. | Aug 2017 | B1 |
9858559 | Raleigh et al. | Jan 2018 | B2 |
9888042 | Annamalaisami et al. | Feb 2018 | B2 |
9898317 | Nakil | Feb 2018 | B2 |
9948649 | Zhao et al. | Apr 2018 | B1 |
10044678 | Van der Merwe et al. | Aug 2018 | B2 |
10061664 | Verkaik et al. | Aug 2018 | B2 |
10070369 | Lynn, Jr. et al. | Sep 2018 | B2 |
10078754 | Brandwine et al. | Sep 2018 | B1 |
10079839 | Bryan et al. | Sep 2018 | B1 |
10084838 | Gordon | Sep 2018 | B2 |
10091304 | Hoffmann | Oct 2018 | B2 |
10142390 | Seedorf | Nov 2018 | B2 |
10237253 | Chen | Mar 2019 | B2 |
10275267 | De Kadt et al. | Apr 2019 | B1 |
10331472 | Wang | Jun 2019 | B2 |
10423481 | Iturralde | Sep 2019 | B2 |
10574482 | Ore et al. | Feb 2020 | B2 |
10659512 | Nielsen | May 2020 | B1 |
10673712 | Gosar et al. | Jun 2020 | B1 |
10708667 | Waggoner | Jul 2020 | B1 |
10756929 | Knutsen et al. | Aug 2020 | B2 |
10904201 | Ermagan et al. | Jan 2021 | B1 |
10922286 | Rubenstein | Feb 2021 | B2 |
11032187 | Hassan | Jun 2021 | B2 |
11038942 | Nielsen | Jun 2021 | B2 |
11092447 | Aiello | Aug 2021 | B2 |
11108595 | Rubenstein | Dec 2021 | B2 |
11403849 | Weerasinghe | Aug 2022 | B2 |
11418366 | Rubenstein | Aug 2022 | B2 |
20020007350 | Yen | Jan 2002 | A1 |
20020029267 | Sankuratripati et al. | Mar 2002 | A1 |
20020046253 | Uchida et al. | Apr 2002 | A1 |
20020049901 | Carvey | Apr 2002 | A1 |
20020087447 | McDonald et al. | Jul 2002 | A1 |
20020186654 | Tornar | Dec 2002 | A1 |
20030023351 | Fukui | Jan 2003 | A1 |
20030046529 | Loison et al. | Mar 2003 | A1 |
20030110214 | Sato | Jun 2003 | A1 |
20030072433 | Brown et al. | Aug 2003 | A1 |
20030147403 | Border et al. | Aug 2003 | A1 |
20030195973 | Savarda | Oct 2003 | A1 |
20030233551 | Kouznetsov et al. | Dec 2003 | A1 |
20040205339 | Medin | Oct 2004 | A1 |
20040268151 | Matsuda | Dec 2004 | A1 |
20050180319 | Hutnik et al. | Aug 2005 | A1 |
20050203892 | Wesley et al. | Sep 2005 | A1 |
20050208926 | Hamada | Sep 2005 | A1 |
20050235352 | Staats et al. | Oct 2005 | A1 |
20060020793 | Rogers et al. | Jan 2006 | A1 |
20060031407 | Dispensa et al. | Feb 2006 | A1 |
20060031483 | Lund | Feb 2006 | A1 |
20060047944 | Kilian-Kehr | Mar 2006 | A1 |
20060075057 | Gildea et al. | Apr 2006 | A1 |
20060179150 | Farley et al. | Aug 2006 | A1 |
20060195896 | Fulp et al. | Aug 2006 | A1 |
20060225072 | Lari et al. | Oct 2006 | A1 |
20060288397 | Uchida | Dec 2006 | A1 |
20070083482 | Rathi et al. | Apr 2007 | A1 |
20070112812 | Harvey et al. | May 2007 | A1 |
20070165672 | Keels et al. | Jul 2007 | A1 |
20070168486 | McCoy et al. | Jul 2007 | A1 |
20070168517 | Weller et al. | Jul 2007 | A1 |
20070226043 | Pietsch et al. | Sep 2007 | A1 |
20080010676 | Dosa Racz et al. | Jan 2008 | A1 |
20080043742 | Pong et al. | Feb 2008 | A1 |
20080091598 | Fauleau | Apr 2008 | A1 |
20080117927 | Donhauser et al. | May 2008 | A1 |
20080130891 | Sun et al. | Jun 2008 | A1 |
20080168377 | Stallings et al. | Jul 2008 | A1 |
20080240121 | Xiong | Oct 2008 | A1 |
20080247386 | Wildfeuer | Oct 2008 | A1 |
20080256166 | Branson | Oct 2008 | A1 |
20080260151 | Fluhrer et al. | Oct 2008 | A1 |
20080301794 | Lee | Dec 2008 | A1 |
20090003223 | McCallum et al. | Jan 2009 | A1 |
20090092043 | Lapuh | Apr 2009 | A1 |
20090100165 | Wesley, Sr. et al. | Apr 2009 | A1 |
20090106569 | Roh et al. | Apr 2009 | A1 |
20090122990 | Gundavelli | May 2009 | A1 |
20090129386 | Rune | May 2009 | A1 |
20090132621 | Jensen et al. | May 2009 | A1 |
20090141734 | Brown et al. | Jun 2009 | A1 |
20090144416 | Chatley et al. | Jun 2009 | A1 |
20090144443 | Vasseur | Jun 2009 | A1 |
20090193428 | Dalberg et al. | Jul 2009 | A1 |
20090213754 | Melamed | Aug 2009 | A1 |
20090217109 | Sekaran et al. | Aug 2009 | A1 |
20090259798 | Wang et al. | Oct 2009 | A1 |
20100017603 | Jones | Jan 2010 | A1 |
20100131616 | Walter et al. | May 2010 | A1 |
20100250700 | O'Brien et al. | Sep 2010 | A1 |
20100316052 | Petersen | Dec 2010 | A1 |
20100325309 | Cicic et al. | Dec 2010 | A1 |
20110007652 | Bai | Jan 2011 | A1 |
20110170613 | Tanaka | Jul 2011 | A1 |
20110185006 | Raghav et al. | Jul 2011 | A1 |
20110231917 | Chaturvedi et al. | Sep 2011 | A1 |
20110247063 | Aabye et al. | Oct 2011 | A1 |
20110268435 | Mizutani et al. | Nov 2011 | A1 |
20110314473 | Yang et al. | Dec 2011 | A1 |
20120005264 | McWhirter et al. | Jan 2012 | A1 |
20120005307 | Das et al. | Jan 2012 | A1 |
20120082057 | Welin | Apr 2012 | A1 |
20120105637 | Yousefi et al. | May 2012 | A1 |
20120158882 | Oehme et al. | Jun 2012 | A1 |
20120179904 | Dunn et al. | Jul 2012 | A1 |
20120185559 | Wesley, Sr. et al. | Jul 2012 | A1 |
20120188867 | Fiorone et al. | Jul 2012 | A1 |
20120196646 | Crinon et al. | Aug 2012 | A1 |
20120210417 | Shieh | Aug 2012 | A1 |
20120210434 | Curtis et al. | Aug 2012 | A1 |
20120270580 | Anisimov et al. | Oct 2012 | A1 |
20120320916 | Sebastian | Dec 2012 | A1 |
20130032990 | Hattori | Feb 2013 | A1 |
20130070751 | Atwal et al. | Mar 2013 | A1 |
20130110787 | Garimella et al. | May 2013 | A1 |
20130173900 | Liu | Jul 2013 | A1 |
20130246623 | Seth | Sep 2013 | A1 |
20130247167 | Paul et al. | Sep 2013 | A1 |
20130259465 | Blair | Oct 2013 | A1 |
20130283118 | Rayner | Oct 2013 | A1 |
20130286835 | Plamondon et al. | Oct 2013 | A1 |
20130287037 | Bush | Oct 2013 | A1 |
20130308471 | Krzanowski et al. | Nov 2013 | A1 |
20130318233 | Biswas et al. | Nov 2013 | A1 |
20130322255 | Dillon | Dec 2013 | A1 |
20130343180 | Kini et al. | Dec 2013 | A1 |
20140020942 | Cho et al. | Jan 2014 | A1 |
20140026179 | Deverajan et al. | Jan 2014 | A1 |
20140071835 | Sun et al. | Mar 2014 | A1 |
20140086253 | Yong | Mar 2014 | A1 |
20140101036 | Phillips et al. | Apr 2014 | A1 |
20140108665 | Arora et al. | Apr 2014 | A1 |
20140149549 | Fu | May 2014 | A1 |
20140149552 | Carney et al. | May 2014 | A1 |
20140169214 | Nakajima | Jun 2014 | A1 |
20140181248 | Deutsch et al. | Jun 2014 | A1 |
20140199962 | Mohammed et al. | Jul 2014 | A1 |
20140210693 | Bhamidipati et al. | Jul 2014 | A1 |
20140215059 | Astiz Lezaun et al. | Jul 2014 | A1 |
20140226456 | Khan et al. | Aug 2014 | A1 |
20140229945 | Barkai et al. | Aug 2014 | A1 |
20140237464 | Waterman et al. | Aug 2014 | A1 |
20140250066 | Calkowski et al. | Sep 2014 | A1 |
20140269712 | Kidambi | Sep 2014 | A1 |
20140269728 | Jalan et al. | Sep 2014 | A1 |
20140278543 | Kasdon | Sep 2014 | A1 |
20140280911 | Wood et al. | Sep 2014 | A1 |
20140289826 | Croome | Sep 2014 | A1 |
20140304728 | Wendling | Oct 2014 | A1 |
20140310243 | McGee et al. | Oct 2014 | A1 |
20140324931 | Grube et al. | Oct 2014 | A1 |
20140331309 | Spiers et al. | Nov 2014 | A1 |
20140337459 | Kuang et al. | Nov 2014 | A1 |
20140341023 | Kim et al. | Nov 2014 | A1 |
20140351939 | Moore et al. | Nov 2014 | A1 |
20140359704 | Chen | Dec 2014 | A1 |
20140362712 | Agrawal et al. | Dec 2014 | A1 |
20140366119 | Floyd et al. | Dec 2014 | A1 |
20140369230 | Nallur | Dec 2014 | A1 |
20150006596 | Fukui et al. | Jan 2015 | A1 |
20150056960 | Egner et al. | Feb 2015 | A1 |
20150063117 | DiBurro et al. | Mar 2015 | A1 |
20150063360 | Thakkar et al. | Mar 2015 | A1 |
20150086018 | Harjula et al. | Mar 2015 | A1 |
20150089582 | Dilley et al. | Mar 2015 | A1 |
20150095384 | Antony et al. | Apr 2015 | A1 |
20150121532 | Barel | Apr 2015 | A1 |
20150128246 | Feghali | May 2015 | A1 |
20150207812 | Back et al. | Jul 2015 | A1 |
20150222633 | Smith et al. | Aug 2015 | A1 |
20150222637 | Hung et al. | Aug 2015 | A1 |
20150248434 | Avati et al. | Sep 2015 | A1 |
20150271104 | Chikkamath et al. | Sep 2015 | A1 |
20150281176 | Banfield | Oct 2015 | A1 |
20150326588 | Vissamsetty et al. | Nov 2015 | A1 |
20150334041 | Hedbor | Nov 2015 | A1 |
20150341223 | Shen et al. | Nov 2015 | A1 |
20150363230 | Kasahara et al. | Dec 2015 | A1 |
20160006695 | Prodoehl et al. | Jan 2016 | A1 |
20160028586 | Blair | Jan 2016 | A1 |
20160028770 | Raleigh et al. | Jan 2016 | A1 |
20160048938 | Jones et al. | Feb 2016 | A1 |
20160055323 | Stuntebeck et al. | Feb 2016 | A1 |
20160077745 | Patel et al. | Mar 2016 | A1 |
20160105530 | Shribman et al. | Apr 2016 | A1 |
20160117277 | Raindel et al. | Apr 2016 | A1 |
20160119279 | Maslak et al. | Apr 2016 | A1 |
20160127492 | Malwankar et al. | May 2016 | A1 |
20160134528 | Lin et al. | May 2016 | A1 |
20160134543 | Zhang et al. | May 2016 | A1 |
20160165463 | Zhang | Jun 2016 | A1 |
20160224460 | Bryant et al. | Aug 2016 | A1 |
20160226755 | Hammam | Aug 2016 | A1 |
20160255556 | Michel et al. | Sep 2016 | A1 |
20160261575 | Maldaner | Sep 2016 | A1 |
20160285977 | Ng | Sep 2016 | A1 |
20160308762 | Teng | Oct 2016 | A1 |
20160330736 | Polehn et al. | Nov 2016 | A1 |
20160337223 | Mackay | Nov 2016 | A1 |
20160337484 | Tola | Nov 2016 | A1 |
20160352628 | Reddy et al. | Dec 2016 | A1 |
20160364158 | Narayanan et al. | Dec 2016 | A1 |
20160366233 | Le et al. | Dec 2016 | A1 |
20170063920 | Thomas et al. | Mar 2017 | A1 |
20170078922 | Raleigh et al. | Mar 2017 | A1 |
20170105142 | Hecht | Apr 2017 | A1 |
20170201556 | Fox et al. | Jul 2017 | A1 |
20170230821 | Chong | Aug 2017 | A1 |
20170344703 | Ansari et al. | Nov 2017 | A1 |
20180013583 | Rubenstein et al. | Jan 2018 | A1 |
20180024873 | Milliron et al. | Jan 2018 | A1 |
20180034889 | Rubenstein | Feb 2018 | A1 |
20180091417 | Ore et al. | Mar 2018 | A1 |
20180198756 | Dawes | Jul 2018 | A1 |
20200145375 | Rubenstein | May 2020 | A1 |
20200213153 | Rubenstein | Jul 2020 | A1 |
20200382341 | Ore | Dec 2020 | A1 |
20210044453 | Knutsen et al. | Feb 2021 | A1 |
20210165769 | Rubenstein | Jun 2021 | A1 |
20210227026 | Rubenstein | Jul 2021 | A1 |
20210342725 | Marsden | Nov 2021 | A1 |
20210345188 | Shaheen | Nov 2021 | A1 |
20220027329 | Rubenstein | Jan 2022 | A1 |
Number | Date | Country |
---|---|---|
2014381693 | Aug 2016 | AU |
1315088 | Sep 2001 | CN |
1392708 | Jan 2003 | CN |
1536824 | Oct 2004 | CN |
1754161 | Mar 2006 | CN |
1829177 | Sep 2006 | CN |
101079896 | Nov 2007 | CN |
101282448 | Oct 2008 | CN |
101478533 | Jul 2009 | CN |
101599888 | Dec 2009 | CN |
101765172 | Jun 2010 | CN |
101855865 | Oct 2010 | CN |
101969414 | Feb 2011 | CN |
102006646 | Apr 2011 | CN |
102209355 | Oct 2011 | CN |
102340538 | Feb 2012 | CN |
102457539 | May 2012 | CN |
102687480 | Sep 2012 | CN |
102739434 | Oct 2012 | CN |
103118089 | May 2013 | CN |
103384992 | Nov 2013 | CN |
103828297 | May 2014 | CN |
102255794 | Jul 2014 | CN |
104320472 | Jan 2015 | CN |
1498809 | Jan 2005 | EP |
1530761 | May 2005 | EP |
1635253 | Mar 2006 | EP |
2154834 | Feb 2010 | EP |
2357763 | Aug 2011 | EP |
6430499 | Nov 2018 | JP |
WO-0233551 | Apr 2002 | WO |
WO-2003025709 | Mar 2003 | WO |
WO-03041360 | May 2003 | WO |
WO-2003090018 | Oct 2003 | WO |
WO-2003088047 | Oct 2003 | WO |
WO-2003090017 | Oct 2003 | WO |
WO-2005065035 | Jul 2005 | WO |
WO-2006055838 | May 2006 | WO |
WO-2008058088 | May 2008 | WO |
WO-2008067323 | Jun 2008 | WO |
WO-2010072030 | Jul 2010 | WO |
WO-2012100087 | Jul 2012 | WO |
WO-2013068530 | May 2013 | WO |
WO-2013120069 | Aug 2013 | WO |
WO-2013135753 | Sep 2013 | WO |
WO-2015021343 | Feb 2015 | WO |
WO-2016073361 | May 2016 | WO |
WO-2016094291 | Jun 2016 | WO |
WO-2016110785 | Jul 2016 | WO |
WO-2016123293 | Aug 2016 | WO |
WO-2016162748 | Oct 2016 | WO |
WO-2016162749 | Oct 2016 | WO |
WO-2016164612 | Oct 2016 | WO |
WO-2016198961 | Dec 2016 | WO |
WO-2018049649 | Mar 2018 | WO |
Entry |
---|
Baumgartner, A., et al., “Mobile core network virtualization: A model for combined virtual core network function placement and topology optimization,” Proceedings of the 2015 1st IEEE Conference on Network Softwarization (NetSoft), London, UK, 2015, pp. 1-9, doi: 10.1109/NETSOFT, 2015 (9 pages). |
Chen, Y., et al., “Resilient Virtual Network Service Provision in Network Virtualization Environments,” 2010 IEEE 16th International Conference on Parallel and Distributed Systems, Shanghai, China, 2010, pp. 51-58, doi: 10.1109/ICPADS.2010.26., 2010 (8 pages). |
Definition of “backbone” in Microsoft Computer Dictionary, 2002, Fifth Edition, Microsoft Press (2 pages). |
Definition of “server” in Microsoft Computer Dictionary, 2002, Fifth Edition, Microsoft Press (3 pages). |
Examination Report, dated Aug. 2, 2018, for European Patent Application No. 16734942.2 (8 pages). |
Examination Report, dated Jul. 20, 2017, for Chinese Application No. 201680004969.3 (1 page). |
Examination Report, dated Mar. 3, 2020, for Chinese Application No. 201680020937.2 (9 pages). |
Examination Report, dated Mar. 5, 2020, for Chinese Patent Application No. 201580066318.2 (10 pages). |
Examination Report, dated Oct. 19, 2018, for European Patent Application No. 16727220.2 (11 pages). |
Extended European Search Report, dated Aug. 2, 2018, for European Patent Application No. 15866542.2 (8 pages). |
Extended European Search Report, dated Sep. 7, 2018, for European Patent Application No. 16777297.9 (4 pages). |
Extended Search Report, dated Nov. 29, 2018, for European Patent Application No. 16806960.7 (10 pages). |
Figueiredo, R. J., et al., “Social VPNs: Integrating Overlay and Social Networks for Seamless P2P Networking,” 2008 IEEE 17th Workshop on Enabling Technologies: Infrastructure for Collaborative Enterprises, Rome, Italy, 2008, pp. 93-98, doi: 10.1109/WETICE.2008.43, 2008 (6 pages). |
International Search Report and Written Opinion, dated Apr. 8, 2016, for International Application No. PCT/US2016/015278 (9 pages). |
International Search Report and Written Opinion, dated Aug. 10, 2016, for international Application No. PCT/IB2016/000531 (20 pages). |
International Search Report and Written Opinion, dated Aug. 23. 2017, for International Application No. PCT/IB2017/000580 (6 pages). |
International Search Report and Written Opinion, dated Dec. 28, 2016, for International Application No. PCT/IB2016/001161 (7 pages). |
International Search Report and Written Opinion, dated Feb. 12, 2016, for International Application No. PCT/US2015/064242 (9 pages). |
International Search Report and Written Opinion, dated Jul. 28, 2017, for International Application No. PCT/IB2017/000557 (6 pages). |
International Search Report and Written Opinion, dated Jun. 7, 2016, for International Application No. PCT/IB2016/000110 (8 pages). |
International Search Report and Written Opinion, dated May 11, 2017, for International Application No. PCT/IB2016/001867 (13 pages). |
International Search Report and Written Opinion, dated Sep. 1, 2017, for International Application No. PCT/IB2017/000613 (7 pages). |
International Search Report and Written Opinion, dated Sep. 23, 2016, for International Application No. PCT/IB2016/000528 (11 pages). |
Gong, Long, et al., “Revenue-Driven Virtual Network Embedding Based on Global Resource Information”, Globecom 2013, Next Generation Networking Symposium, pp. 2294-2299. (Year: 2013) (6 pages). |
Chowdhury, N.M.M.K., et al., “Virtual Network Embedding with Coordinated Node and Link Mapping”, IEEE Communications Society Subject Matter Experts for Publication in the IEEE INFOCOM 2009, pp. 783-791. (Year: 2009) (9 pages). |
Office Action, dated Jun. 3, 2020, for Chinese Patent Application No. 201680066545.X (11 pages). |
Office Action, dated Mar. 12, 2020, for Chinese Patent Application No. 201680032657.3 (5 pages). |
Office Action, dated Mar. 13, 2020, received in related Chinese Patent Application No. 201680021239.4 (9 pages). |
Office Action, dated May 7, 2020, for Chinese Patent Application No. 201680020878.9 (7 pages). |
Haeri, Soroush, et al., “Global Resource Capacity Algorithm with Path Splitting for Virtual Network Embedding”, 2016 IEEE, pp. 666-669. (Year: 2016) (4 pages). |
Supplementary Partial European Search Report, dated May 20, 2019, for European Patent Application No. 16872483.9 (8 pages). |
Szeto, W. et al., “A multi-commodity flow based approach to virtual network resource allocation,” GLOBECOM' 03. IEEE Global Telecommunications Conference (IEEE Cat. No. 03CH37489), San Francisco, CA, USA, 2003, pp. 3004-3008, vol. 6, doi: 10.1109/GLOCOM.2003.1258787, 2003 (5 pages). |
International Search Report and Written Opinion, dated Jul. 7, 2016, for International Application No. PCT/US2016/026489 (7 pages). |
“Operations and Quality of Service Telegraph Services, Global Virtual Network Service,” ITU-T Standard, International Telecommunication Union, Geneva, Switzerland, No. F.16, Feb. 21, 1995, pp. 1-23 (23 pages). |
Extended European Search Report dated Sep. 7, 2018 received in related European Patent Application No. 16744078.3 (7 pages). |
Robert Russell, “Introduction to RDMA Programming,” retrieved from the Internet: URL:web.archive.org/web/20140417205540/http://www.cs.unh.edu/˜rdr/rdma-intro-module.ppt. |
“Open Radio Equipment Interface (ORI); ORI Interface Specification; Part 2: Control and Management (Release 4),” Group Specification, European Telecommunications Standards Institute (ETSI), 650, Route des Lucioles; F-06921 Sophia-Antipolis; France, vol. ORI, No. V4.1.1, Oct. 1, 2014 (185 pages). |
“Cisco Hyperflexes its muscles,” posted on Mar. 1, 2016 by UCSguru.com https://ucsguru.com/2016/03/01/cisco-hyperflexes-its-muscles/ (10 pages). |
Gkantsidis, et al., “Network Coding for Large Scale Content Distribution”, INFOCOM 2005, Miami, Florida, Mar. 13-17, pp. 2235-2245, 2005 (11 pages). |
Marinos, et al., “Network Stack Specialization for Performance”, SIGCOMM '14 Chicago Illinois, Aug. 17-22, 2014, pp. 175-186 (12 pages). |
Supplementary European Search Report, dated Dec. 11, 2019, for European Patent Application No. 17788882.3 (8 pages). |
Number | Date | Country | |
---|---|---|---|
20200382341 A1 | Dec 2020 | US |
Number | Date | Country | |
---|---|---|---|
62151174 | Apr 2015 | US | |
62144293 | Apr 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15563246 | US | |
Child | 16872148 | US |