Facilitating network routing using virtualization
First Claim
1. A method of facilitating network routing using virtualization, comprising the steps of:
- (a) detecting, at a first device, a request for a network connection from an application running on the first device;
(b) spawning, at the first device in response to the request for a network connection, a first virtual machine that runs on the first device and that virtualizes network capabilities of the first device such that a first virtual network connection is provided;
(c) determining application-specific information associated with the application;
d) using the application-specific information associated with the application, selecting, at the first device, a routing protocol from among a plurality of available routing protocols for communicating data from the application over a network using the first virtual network connection; and
(e) determining, at the first device, a first intermediate node to transmit a plurality of packets to, the determination being based on(i) the selected routing protocol, and(ii) a routing table maintained at the first device;
(f) transmitting, from the first device using the first virtual network connection, the plurality of packets to a second device corresponding to the first intermediate node for communication to a destination node, the packets including(i) an indication of the destination node, and(ii) an indication of the selected routing protocol;
(g) spawning, at the second device, a second virtual machine that runs on the second device and that virtualizes network capabilities of the second device such that a second virtual network connection is provided;
(h) receiving, at the second device via the second virtual network connection that virtualizes network capabilities of the second device, one of the packets transmitted by the first device;
(i) loading, at the second device, information from the packet into memory of the second device;
(j) appending, at the second device, to a payload of the packet, information associated with the second device;
(k) determining, at the second device, a second intermediate node to transmit the packet to, the determination being based on(i) the indication of the destination node contained in the packet,(ii) the indication of the routing protocol contained in the packet, and(iii) a routing table maintained at the second device; and
(l) transmitting, from the second device using the second virtual network connection, the packet to a third device corresponding to the second intermediate node for communication to the destination node;
(m) wherein the application runs outside of the first virtual machine.
7 Assignments
0 Petitions
Accused Products
Abstract
A method of facilitating network routing using virtualization includes receiving, at a second device via a virtual machine for a network connection that virtualizes network capabilities of the second device, a packet transmitted by a first device, the packet including a header and a payload, the virtual machine being spawned and managed by virtual dispersive routing (VDR) software; loading, by the VDR software, information from the packet into memory of the second device; appending, by the VDR software, to the payload of the packet, information associated with the second device; and transmitting the packet to a third device using the virtualized network capabilities of the virtual machine.
-
Citations
20 Claims
-
1. A method of facilitating network routing using virtualization, comprising the steps of:
-
(a) detecting, at a first device, a request for a network connection from an application running on the first device; (b) spawning, at the first device in response to the request for a network connection, a first virtual machine that runs on the first device and that virtualizes network capabilities of the first device such that a first virtual network connection is provided; (c) determining application-specific information associated with the application; d) using the application-specific information associated with the application, selecting, at the first device, a routing protocol from among a plurality of available routing protocols for communicating data from the application over a network using the first virtual network connection; and (e) determining, at the first device, a first intermediate node to transmit a plurality of packets to, the determination being based on (i) the selected routing protocol, and (ii) a routing table maintained at the first device; (f) transmitting, from the first device using the first virtual network connection, the plurality of packets to a second device corresponding to the first intermediate node for communication to a destination node, the packets including (i) an indication of the destination node, and (ii) an indication of the selected routing protocol; (g) spawning, at the second device, a second virtual machine that runs on the second device and that virtualizes network capabilities of the second device such that a second virtual network connection is provided; (h) receiving, at the second device via the second virtual network connection that virtualizes network capabilities of the second device, one of the packets transmitted by the first device; (i) loading, at the second device, information from the packet into memory of the second device; (j) appending, at the second device, to a payload of the packet, information associated with the second device; (k) determining, at the second device, a second intermediate node to transmit the packet to, the determination being based on (i) the indication of the destination node contained in the packet, (ii) the indication of the routing protocol contained in the packet, and (iii) a routing table maintained at the second device; and (l) transmitting, from the second device using the second virtual network connection, the packet to a third device corresponding to the second intermediate node for communication to the destination node; (m) wherein the application runs outside of the first virtual machine. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 19)
-
-
10. A method of facilitating network routing using virtualization, comprising the steps of:
-
(a) detecting, at a first device, a request for a network connection from an application running on the first device; (b) spawning, at the first device in response to the request for a network connection, a first virtual machine that runs on the first device and that virtualizes network capabilities of the first device such that a first virtual network connection is provided; (c) determining application-specific information associated with the application; d) using the application-specific information associated with the application, selecting, at the first device, a routing protocol from among a plurality of available routing protocols for communicating data from the application over a network using the first virtual network connection; and (e) determining, at the first device, a first intermediate node to transmit a plurality of packets to, the determination being based on (i) the selected routing protocol, and (ii) a routing table maintained at the first device; (f) transmitting, from the first device using the first virtual network connection, the plurality of packets to a second device corresponding to the first intermediate node for communication to a destination node, the packets including (i) an indication of the destination node, and (ii) an indication of the selected routing protocol; (g) spawning, at the second device, a second virtual machine that runs on the second device and that virtualizes network capabilities of the second device such that a second virtual network connection is provided; (h) receiving, at the second device via the second virtual network connection that virtualizes network capabilities of the second device, one of the packets transmitted by the first device; (i) loading, at the second device, information from the packet into memory of the second device; (j) appending, at the second device, to a payload of the packet, information associated with the second device; (k) selecting, at the second device based on the indication of the application contained in the packet, a second routing protocol from among a plurality of available routing protocols for communicating data over the network using the second virtual network connection; (l) determining, at the second device, a second intermediate node to transmit the packet to, the determination being based on (i) the indication of the destination node contained in the packet, (ii) the selected second routing protocol, and (iii) a routing table maintained at the second device; and (m) transmitting, from the second device using the second virtual network connection, the packet to a third device corresponding to the second intermediate node for communication to the destination node; (n) wherein the application runs outside of the first virtual machine. - View Dependent Claims (11, 12, 13, 14, 15, 16, 17, 18)
-
-
20. A method of facilitating network routing using virtualization, comprising the steps of:
-
(a) detecting, at a first device, a request for a network connection from an application running on the first device; (b) spawning, at the first device in response to the request for a network connection, a first virtual machine that runs on the first device and that virtualizes network capabilities of the first device such that a first virtual network connection is provided; (c) determining application-specific information associated with the application; (d) using the application-specific information associated with the application, selecting, at the first device, a first routing protocol from among a plurality of available routing protocols for communicating data from the application over a network using the first virtual network connection; and (e) determining, at the first device, a first intermediate node to transmit a plurality of packets to, the determination being based on (i) the selected first routing protocol, and (ii) a routing table maintained at the first device; (f) transmitting, from the first device using the first virtual network connection, the plurality of packets to a second device corresponding to the first intermediate node for communication to a first destination node, the packets including (i) an indication of the first destination node, and (ii) an indication of the selected first routing protocol; (g) spawning, at the first device, a second virtual machine that runs on the first device and that virtualizes network capabilities of the first device such that a second virtual network connection is provided; (h) receiving, at the first device via the second virtual network connection that virtualizes network capabilities of the first device, a first packet transmitted by a second device, the first packet containing; (i) an indication of a second destination, and (ii) an indication of a second routing protocol; (i) loading, at the first device, information from the first packet into memory of the first device; (j) appending, at the first device, to a payload of the first packet, information associated with the first device; (k) determining, at the second device, a second intermediate node to transmit the packet to, the determination being based on (i) the indication of the second destination node contained in the first packet, (ii) the indication of the second routing protocol contained in the first packet, and (iii) the routing table maintained at the first device; (l) transmitting, from the first device using the second virtual network connection, the packet to a third device corresponding to the second intermediate node for communication to the second destination node; (m) spawning, at the first device, a third virtual machine that runs on the first device and that virtualizes network capabilities of the first device such that a third virtual network connection is provided; (n) receiving, at the first device via the third virtual network connection that virtualizes network capabilities of the first device, a second packet transmitted by a fourth device, the first packet containing (i) an indication of a third destination node, and (ii) an indication of a third routing protocol; (o) loading, at the first device, information from the second packet into memory of the first device; (p) appending, at the first device, to a payload of the second packet, information associated with the first device; (q) determining, at the first device, a third intermediate node to transmit the packet to, the determination being based on (i) the indication of the third destination node contained in the second packet, (ii) the indication of the third routing protocol contained in the second packet, and (iii) the routing table maintained at the first device; and (r) transmitting, from the first device using the third virtual network connection, the packet to a fifth device corresponding to the third intermediate node for communication to the third destination node; (s) wherein the application runs outside of the first virtual machine.
-
Specification