×

Network communications of applications running on devices utilizing virtual network connections with asymmetrical network paths

  • US 9,241,025 B2
  • Filed: 09/23/2011
  • Issued: 01/19/2016
  • Est. Priority Date: 10/17/2007
  • Status: Active Grant
First Claim
Patent Images

1. A method of providing network communications using virtualization, comprising the steps of:

  • (a) detecting, at a first device, a plurality of requests for network connections and, for each respective request, spawning, in response thereto, a respective virtual machine that virtualizes network capabilities of the first device such that a respective virtual network connection is provided;

    (b) detecting, at the first device, a request for a network connection from an application running on the first device;

    (c) spawning, at the first device, a first virtual machine that virtualizes network capabilities of the first device such that a first virtual network connection is provided to the application, the application running external to the first virtual machine;

    (d) spawning, at a second device, a second virtual machine that virtualizes network capabilities of the second device such that a second virtual network connection is provided;

    (e) selecting, at the first device, a first routing protocol for the first virtual network connection from among a plurality of available routing protocols for communicating data using the first virtual network connection;

    (f) determining, at the first device, a third device corresponding to a first node for a first path to a second device over which to communicate data from the application using the first virtual network connection, said determination being based on the selected routing protocol and network information stored at the first device;

    (g) using the selected first routing protocol, communicating data from the application in a plurality of packets over the first path to the second device, the method involving, for each packet,(i) transmitting, from the first device using the first virtual network connection and the selected first routing protocol, the packet to the third device for communication to the second device,(ii) receiving, at a third virtual machine that runs on the third device and that virtualizes network capabilities of the third device such that a third virtual network connection is provided, the packet,(iii) transmitting, from the second device using the third virtual network connection and the selected first routing protocol, the packet for communication to the second device, and(iv) receiving, at the second virtual machine that runs on the second device and that virtualizes network capabilities of the second device, the packet;

    (h) communicating data intended for the application of the first device from the second device in a plurality of packets to the first device over a second path, the second path being different from the first path, the method involving, for each packet,(i) transmitting, from the second device using a virtual network connection and the selected first routing protocol, the packet for communication to the first device,(ii) receiving, at a fourth virtual machine that runs on a fourth device and that virtualizes network capabilities of the fourth device such that a third virtual network connection is provided, the packet,(iii) transmitting, from the fourth device using the fourth virtual network connection, the packet for communication to the first device, and(iv) receiving, at a virtual machine that runs on the first device and that virtualizes network capabilities of the first device, the packet.

View all claims
  • 7 Assignments
Timeline View
Assignment View
    ×
    ×