Local resource delivery network

Information

  • Patent Grant
  • 10021179
  • Patent Number
    10,021,179
  • Date Filed
    Tuesday, February 21, 2012
    12 years ago
  • Date Issued
    Tuesday, July 10, 2018
    6 years ago
Abstract
A local area network (LAN) may contain several local computing devices that are in communication with a remote network storage provider that is not part of the LAN. Resources may be available from the remote network storage provider. When a user requests a resource using a first local computing device in the LAN, the first local computing device may check the other local computing devices on that are in the LAN for the resource before requesting the resource from the remote network storage provider. If the resource is available within the LAN, the resource is not requested from the remote network storage provider.
Description
BACKGROUND

Generally described, computing devices and communication networks can be utilized to exchange information. In a common application, a computing device can request content from another computing device via the communication network. For example, a user at a personal computing device can utilize a software browser application to request a Web page from a server computing device via the Internet.


A user may have own several digital resources (such as, photos, videos, document files, audio files, for example) that they store on one or more computing devices under the user's control. The storage available on the user's computing device is limited and as a result, they user may not be able to store a large volume of resources, or store resources that are large in size. In addition, the user may wish to access the same resource across multiple computing devices. For example, the user may desire to access a file from his work computer, his home computer, or his mobile computing device. As a result, a user may decide to store some resources remotely using a network storage provider. The user may be able to upload or store the resource to the remote network storage provider using a first computing device and access the resource using a second computing device. In addition, a user may store infrequently accessed resources on the remote network storage device to make room for frequently accessed resources on his computing devices.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates one embodiment of a resource delivery environment containing a network storage provider in communication with two local area networks.



FIG. 2 illustrates one embodiment of a user computer device including a resource manager client, resource manager server, pre-fetch module and resource manager data.



FIG. 3A illustrates one embodiment of the flow of data for uploading and requesting a resource.



FIG. 3B illustrates one embodiment of the flow of data for editing and uploading a resource.



FIG. 3C illustrates another embodiment of the flow of data for editing and uploading a resource.



FIG. 4A illustrates one embodiment of the flow of data for requesting a resource.



FIG. 4B illustrates one embodiment of the flow of data for requesting a resource available on a local area network.



FIG. 5A illustrates one embodiment of the flow of data for pre-fetching a resource.



FIG. 5B illustrates one embodiment of the flow of data for requesting a pre-fetched resource available on a local area network.



FIG. 6A is a flowchart illustrating one embodiment of the flow of data for initiating a resource manager server instance and listening for requests for resources.



FIG. 6B is a flowchart illustrating one embodiment of the flow of data for providing a resource in response to a request for the resource.



FIG. 6C is a flowchart illustrating another embodiment of the flow of data for initiating a resource manager server instance and listening for requests for resources.





DETAILED DESCRIPTION

Overview


Use of a remote network storage provider enables a user to store infrequently used resources or large resources, or to share resources among several computing devices. Current use of a remote network storage provider typically requires a computing device to request a resource from the remote network storage provider which is not associated with its local area network (LAN). In some cases, a user may be sharing a resource among several computing devices that are nodes of the same LAN. For example, a resource may be shared between a desktop computer and a tablet within the same LAN. In such cases, the retrieval of the resource from the remote network storage provider may be unnecessary and inefficient. For example, if the resource is available from another node computer within the LAN, it can be retrieved easier and more efficiently locally.


Accordingly, the present disclosure is directed to the management of resources within a LAN. In one embodiment, a user computing device is associated with a LAN and may be in communication with a remote network storage provider. A user operating the user computing device may request a resource. The user computing device may, in some embodiments, detect other computing devices connected to the LAN. The user computing device may also determine if any of the detected computing devices have the resource requested by the user. If none of the detected computing devices have the resource, or if the detected computing devices have an outdated version of the resource, the user computing device may request the resource from the remote network storage provider. Alternatively, if one of the detected computing devices has the resource, the user computing device may obtain the resource from the detected computing device storing the resource. In some embodiments, the user may upload to and request resources from the remote storage computing device using a resource manager client.


For example and illustrative purposes only, suppose a user uses a remote network storage provider to store photos. The user may utilize a resource manager client executing on his laptop to upload “photo1.jpg” to the remote network storage provider. The laptop may be connected and part of the user's home wireless network (e.g., the user's LAN), but the remote network storage provider may not be connected to the LAN and is accessible only through a wide-area network such as the Internet. Once uploaded, a first copy of “photo1.jpg” is stored at the laptop, and a second copy of “photo1.jpg” is stored at the network storage provider. In addition to the laptop, the user may also have a mobile phone connected, and part of, the LAN. The user may want to view “photo1.jpg” on the mobile phone. Typically, the mobile phone would request “photo1.jpg” from the remote network storage provider through a website or mobile application. In the embodiments disclosed herein, however, the mobile phone may first check to see if “photo1.jpg” is available from a computing device within its LAN. If the photo is available, the mobile phone may request it from the computing device within its LAN. For example, when the user requests “photo1.jpg” from the mobile phone, the mobile phone may determine that it is available from the laptop. The laptop may then provide “photo1.jpg” to the mobile phone.


More generally, in one embodiment, a first computer system on a LAN determines one or more computer systems that are also connected to the LAN. The first computer system may receive a request from a user for a resource and may also access metadata associated with the resource to determine if a second computer system locally associated with the LAN has a version of the resource. If the resource is available from the second computer system on the LAN, the first computer system retrieves the resource from the second computer system. If the resource is not available from a computer system on the LAN, the first computer system may retrieve the resource from a remote network storage provider. In some embodiments, the accessed metadata may be stored on the first computer system or in other embodiments, the accessed metadata may be stored on another computer within the local area network or on the remote network storage provider. Embodiments may also include the first computer system monitoring metadata stored on the remote network storage provider for updates to the resource and pre-fetching the resource based in part on the metadata. Other embodiments may also include a remote network storage provider or a second computer system on the LAN storing a resource having a first attribute or characteristic and providing the resource to the first computer system with a second attribute or characteristic. For example, the remote network storage provider (or second computer system on the LAN) may store a resource with the file name “FileFromNetworkStorageProivder156664.txt” (first attribute or characteristic) and it may provide the resource with a second file name, “File1.txt” (second attribute or characteristic) to the first computer system. By way of further example, the remote network storage provider (or second computer system on the LAN) may store a resource in a first format (first attribute or characteristic) and provide the resource in a second format (second attribute or characteristic) to the first computer system.


Embodiments of the disclosure will now be described with reference to the accompanying figures, wherein like numerals refer to like elements throughout. The terminology used in the description presented herein is not intended to be interpreted in any limited or restrictive manner, simply because it is being utilized in conjunction with a detailed description of certain specific embodiments of the disclosure. Furthermore, embodiments of the disclosure may include several novel features, no single one of which is solely responsible for its desirable attributes or which is essential to practicing the embodiments of the disclosure herein described. Further, although various aspects of the disclosure will be described with regard to illustrative examples and embodiments, it can be appreciated that the disclosed embodiments and examples should not be construed as limiting. For example, although the present application will be discussed with respect to certain computing devices, it can be appreciated that the systems, methods, and process described for managing resources may be applied to any computing device that may share resources within a network.


Example Resource Delivery Environment



FIG. 1 illustrates one embodiment of a resource delivery environment 100 containing a network storage provider (NSP) 105 in communication with two local area networks (LANs) 115, 125. In the illustrative embodiment of FIG. 1, the NSP communicates with the LANs via network 180. The NSP may store resources of user computing devices 110, 111, 112, 120, 121, 122 that communicate with the NSP through router/access point 113, 123 and network 180. In one embodiment, a user may upload a resource comprising digitized data (such as a document, video, audio file, image, or the like) to the NSP 105 thereby storing the resource at the NSP. After uploading the resource, the user may access the uploaded resource with any one of its user computing devices 110, 120. Thus, the NSP may act as a means to share resources among the user's computing devices and networks. In addition, the NSP may serve the function of providing additional storage to the user. For example, the NSP may provide storage for the user to archive multiple versions of a document, serve as storage for infrequently used files, or provide storage for backups.


The resource delivery environment 100 in FIG. 1 may be computerized, wherein each of the illustrated components comprises a computing device that is configured, amongst other things, to communicate with other computer devices via network 180. For example, each of the user computing devices 110, 111, 112, 120, 121, 122 may comprise a computing device, such as a desktop, notebook, mobile device, cell phone, tablet, handheld computing device, or other general purpose computing device that may be configured to transmit and receive data to/from other computing devices and LANs via network 180. Depending on the embodiment, network 180 may comprise one or more of any type of network, such as one or more wide area networks, personal area networks, telephone network, and/or the Internet, which may be accessed via any available wired and/or wireless communication protocols. Any other combination of networks, including secured and unsecured network communication links, are contemplated for use in the systems described herein.


In some embodiments, a user may connect his/her user computing devices 110, 120 to a local area network, or LAN. Generally, a LAN is a computer network that interconnects computers in a limited area such as a home, school, office, computer laboratory or shopping area. As is known in the art, one of the defining characteristics of a LAN is relatively high data transfer rates between computing devices that are part of the LAN due to the close proximity of the computing devices. In some embodiments, the LAN may be a wireless LAN, thereby permitting computing devices to connect to the LAN without the use of a cable or wire. In other embodiments, the LAN may be implemented in a wired fashion where computing devices may be connected through the use of a cable or wire.


In some embodiments, the LAN 115, 125 may include a router/access point 113, 123. The router/access point may facilitate communications between the nodes of the LAN such as user computing devices 110, 111, 112. The router/access point may also facilitate communicates between the nodes of the LAN and other computers connected through a wide area network (WAN). For example, in the illustrative embodiment of FIG. 1, router/access point 111 may facilitate communication between user computing device I-A 110A and network storage provider 105. The router/access point 113 may facilitate communication by forwarding data packets using a standard networking protocol such as TCP/IP, for example. In some embodiments, the router/access point 113 may also comprise a modem for connecting nodes of the LAN with computing devices that are not part of the LAN.


As shown in FIG. 1, in some embodiments, the resource delivery environment 100 may include more than one LAN. Each LAN may be geographically or logically separate. For example, LAN A 115 may be the user's home computer network while LAN B 125 may be the user's computer network at her office. Alternatively, the LANs may be geographically co-located but logically separated. For example, LAN A 115 and LAN B 125 may be located within the same office building, but may be separated for security reasons, bandwidth considerations, or other organizational criteria.


With continued reference to FIG. 1, the resource delivery environment 100 can also include a network storage provider 105 in communication with the one or more LANs 115, 125. The network storage provider 105 illustrated in FIG. 1 also corresponds to a logical association of one or more computing devices associated with a network storage provider. Specifically, the network storage provider 110 can include a number of network storage provider Point of Presence (“NSP POP”) locations 106, 108 that correspond to nodes on the communication network 180. Each NSP POP 106, 108 includes a storage component 107, 109 made up of a number of storage devices for storing resources which will be managed and processed by the network storage provider 110 and transmitted to various LANs, such as LAN 115, 125. The storage components 107, 108 may further include additional software and/or hardware components that facilitate communications including, but not limited to, load balancing or load sharing software/hardware components. In addition, the storage components 107, 108 may include a scalable, resizable compute capacity.


In some embodiments, the storage components 107, 108 may store resources uploaded by user computing devices 110, 120 to the NSP. The NSP 105 may allocate a portion storage space for a user to store resources (“user's NSP allocation”). The NSP 105 may restrict access to the user's NSP allocation to other users, thereby making the user's NSP allocation secure. For example, the NSP may allocate 20 GB of storage space to a designated user for the storage of resources. Additionally, the NSP may restrict access to the designated user's allocation of storage space to other users of the NSP. The NSP may, in some embodiments, require verification of user credentials, such as a user name and password. A user may upload a resource from a user computer device 110 to the user's NSP allocation of storage 107, 109 or the user may request a resource stored on the user's NSP allocation. The storage components 107, 108 may also store metadata describing the resources, thereby facilitating efficient management of resources. The content and format of the metadata is described in more detail below with respect to FIG. 2.


In an illustrative embodiment, the storage components 107, 108 are considered to be logically grouped, regardless of whether the components, or portions of the components, are physically separate. Additionally, although the NSP POPs 106, 108 are illustrated in FIG. 1 as logically associated with the network storage provider 110, the NSP POPs may be geographically distributed throughout the communication network 180 in a manner to best serve various demographics of user computing devices and LANs. Additionally, the network storage provider 105 can be associated with various additional computing resources, such additional computing devices for administration of content and resources, DNS name servers, and the like.


Example Components of User Computing Devices



FIG. 2 illustrates one embodiment of a user computing device 110 including a resource manager client 210, a resource manager server 220, a pre-fetch module 230 and resource manager data 240, which may be modules or components of software code that when executed perform the processes described in FIGS. 3-6. Although the functionality of each module will be discussed with reference to particular functions, each module may perform additional functions, and in some embodiments some modules may perform the functionality of other modules herein described. For example, in some embodiments, functionality described herein as being preformed by the resource manager client 210 may be performed by the resource manager server 220. In addition to the resource manager client 210, resource manager server 220, pre-fetch module 230 and resource manager data 240, the user computer device 110 may also have a CPU 201, a memory 202, input-output (I/O) devices 203, and a data store 204. However, generally, the configuration of each user computing device may vary. For example, each computing device may have different CPU capacities or configurations. Additionally, one or more of the above illustrated components, such as a data store, may be omitted.


In some embodiments, the resource manager client 210 is a module or component that facilitates the management of resources for a user. The resource manager client 210 may be an executable application, or “front-end”, that provides a mechanism for the user to interact with the user computing device 110 to upload resources to the NSP and request resources from the NSP or other user computer devices. The resource manager client 210 may be, in some embodiments, an application capable of being displayed in a web browser such as a dynamic web page or web application. In other embodiments, it may be a separate executable with a graphic user interface (GUI) for choosing which resources to upload to the NSP or which resources to request from the NSP or the other user computing devices within the user computing device's LAN. In some embodiments, the resource manager client 210 may integrate with the existing file browser of the user computing device nd provide the user with the ability to manage resources through the use of context sensitive menus. In other embodiments, the resource manager client 210 may be a command line tool allowing the user to manage resources through the use of commands or scripts. Some embodiments may combine elements of a command line tool, integrated tool or stand alone tool.


The resource manager client 210 may provide, among other things, the basic functionality to manage resources which may include uploading resources, retrieving resources, providing status of resources, providing version information and location information of resources, and providing an list of resources available in the user's NSP allocation. For example, the resource manager client 210 may provide the basic functionality through a list interface, tree interface or command line prompt. For example, a user may be able to upload a resource using a file chooser user interface component that is displayed by the resource manager client 210. In a command line embodiment, a user may be able to access the basic functionality through the use of command line prompts. In some embodiments, the resource manager client 210 may interact or interface with another application. For example, the resource manger client 210 may be a plug-in to a web or file browser, or may integrate with applications that create or edit resources such as word processing applications, photo editing applications, or video editing applications, for example.


The resource manager client 210 may also facilitate the retrieval of resources. For example, after displaying the list of available resources to the user, the user may be able to select a particular resource for retrieval by clicking on the resource or otherwise selecting it. In other embodiments, resource retrieval may be facilitated by the resource manager client 210 through the use of a command whereby the user provides the name or unique identifier of the resource for retrieval. For example, this may be done through the use of a command line tool or text box. In some embodiments, the resource manager client 210 may allow the user to allocate space in the local data store 204 (“user's local allocation”) to mirror the resources, or a subset of the resources, available from the NSP 105. In such embodiments, the resource manger client 210 may allow the user to perform a “Get All” operation which will retrieve all of the available resources from the user's NSP allocation or all the resources of a particular group or subset available from the NSP 105 within the user's NSP allocation.


In some embodiments, the resource manager client 210 may communicate with the resource manger server 220 to determine the current status of resources, or to perform resource put (upload) or get (retrieval) operations. The resource manager server 220 may be a background process, or daemon, executing in the background of the user computing device. In other embodiments, the resource manager server 220 may execute as a daemon on a dedicated server located on the LAN of the user computing device 110. The resource manger server 220 may expose a network socket allowing the resource manager client 210, or other resource manager server instances within the LAN to connect to it in order to request a resource, get status on a resource, or upload a resource to the NSP. The resource manager server 220 may also establish connections to the NSP or other resource manager server instances within the LAN to request resources, receive resources, request and receive status, and receive and request resource availability data.


The resource manager server 220 may manage resources with the assistance of metadata describing the resources, which will be generally referred to as “metadata”. Illustratively, metadata may include data that describes a resource and facilitates the management of resources without the need to manipulate the resource itself. Since the metadata is likely smaller than the resource, it can be transferred more efficiently throughout the resource delivery environment thereby minimizing network bandwidth. The metadata may include, among other things: a unique resource identifier that uniquely identifies the resource, status information pertaining to the resource (such as whether the resource is locally available or whether a locally available resource is synched with the version of the resource stored at the NSP), version information, whether the resource has been edited locally and/or the computing devices from which the resource may be available. In some embodiments, the resource manager server 220 may store the metadata in the resource manager data store 240.


In some embodiments, the metadata may also include authentication information related to the resource. For example, the metadata may include an encrypted token that restricts access to the resource to only those resource manager server instances capable of decrypting the token. In other embodiments, the metadata may include authentication information that describes the identity of the resource manager server instances that may access the resource. For example, upon installation, each resource manager instance may generate a unique key that is encrypted and registered with the NSP 105. A user may be able to grant permission to a resource manager instance to access a resource. At that time, the metadata of the resource may be updated to include the encrypted unique key of the resource manager server instance. In other embodiments, the metadata may be encrypted so that only those authorized resource manager service instances may access the metadata. Encryption of tokens, unique identifiers, and metadata may be done using any known encryption algorithm.


In some embodiments, the resource manager client 210 may display some or all of the metadata in a GUI so that the user may know the status of resources. In other embodiments, the metadata may be hidden from the user so that from the user's perspective all resources from the user's NSP allocation appear to be locally available. In such embodiments, when the user selects a resource for viewing or modifying, the resource manager server 220 may use the metadata to determine if the resource needs to be retrieved, and if so, from which computing device to retrieve the resource.


The resource manger server 220 may perform some resource management functions periodically. For example, the resource manager server 220 may periodically request metadata updates from the NSP. The resource manager server 220 may request from the NSP an updated metadata set for the resources in the user's NSP allocation. The NSP, in response, may provide an updated metadata set to the resource manager server 220, which may then notify the resource manager client 210 with updates if needed.


In some embodiments, the resource manager server 220 may periodically broadcast on the LAN a notification data packet that may notify other resource manager servers on the LAN that it is participating in the resource delivery environment 100. The resource manager server 220 may also check for other resource manager server instances that are executing in the user computing device's LAN by executing a packet analyzer or network sniffer configured to detect the broadcast of notification data packets originating from other resource manager server instances. In one embodiment, the notification data packet may provide enough data to notify the resource manager server 220 of the other instances of the resource manager server. In other embodiments, the notification data packet may include additional data, such as metadata related to the resources that could be served from the resource manager server.


In some embodiments, the resource manager server 220 may also maintain a list or data structure tracking the available computing devices on its LAN as well as those participating in the resource delivery environment 100 (that is, those computing devices running a resource manager server instance). The list or data structure may contain, for example, the IP address of the participating computing device, a device identifier used by the resource delivery environment 100 to identify the computing device, or resources available from the participating computing device. In some embodiments, the resource manager server 210 may access or consult the list or data structure before it requests a resource from the NSP 105. For example, the resource manager server 220 may use the list or data structure to determine which computing devices to poll for a resource request (see FIGS. 4A-4B) or it may use the list to determine which computing device has the most recent version of a resource. In some embodiments, the list or data structure is stored in the resource manager data store 240.


In some embodiments, user computing devices may not be optimized to, capable of, or configured to process resources having particular attributes or characteristics. In such embodiments, the resource manager server 220 may, for example, change an attribute or characteristic of a resource, or otherwise create a new version of a resource having the preferred attribute or characteristic, before providing it to a requester. This may occur in embodiments where a first user computing device on the LAN stores and processes resources having a first attribute or characteristic, while a second user computing device on the LAN processes resources more efficiently when they have a second differing attribute or characteristic. For example, a first user computing device that is a desktop might store a video resource in an uncompressed video format. A second user computing device, such as mobile phone, may request the resource. Due to the limited storage capacity of the mobile phone, the mobile phone may process the video more efficiently in a compressed format. When the mobile phone requests the video resource from the desktop, it may request the desktop to reformat the video into the compressed format. In others embodiments, the resource manger server 220 may also contain a module that allows for streaming of video or audio resources. That is, as opposed to converting the resource to a different format before delivery, the resource manager server 220 may stream it to the requester. In other embodiments, an attribute of the resource may be changed. For example, the resource manager server 220 may provide a resource in a read-only format, or it may truncate or shorten a file name before providing the resource to the requester.


The resource manager server 220 may also contain or communicate with pre-fetch module 230. The pre-fetch module 230 may analyze metadata describing the resources available (“resource availability data”) on the user's NSP allocation and determine whether any of the data should be requested before the user requests the resource. For example, the pre-fetch module 230 may analyze the resource availability data and obtain the most recently added or updated resource. In other embodiments, a user may be able to configure the pre-fetch module through the use of pre-fetch preferences. A user may, for example, set a preference to pre-fetch resources of a particular file type or with file names containing particular strings of characters. For example, a user may define pre-fetch preferences on his work computing device to pre-fetch any resources available from the user's NSP allocation that is a word processing file or any file with the string “work” in the filename. To facilitate pre-fetching, the resource manager server 220 may periodically request updated metadata from the NSP, extract the resource availability data from the metadata, and then feed the pre-fetch module the resource availability data. The pre-fetch module may then analyze the resource availability data in light of the pre-fetch preferences and pre-fetch resources accordingly.


In some embodiments, the resource manager server 220 accesses the data store 204 of the user computing device to store resources retrieved from the NSP or from other user computing devices executing a resource manager server instance on the LAN. In some embodiments, the resource manager server 220 may be configured to utilize a portion of the data store 204 for resources (“user's local allocation”). The user's local allocation may be smaller than the user's NSP allocation. For example, the user's local allocation may be 5 GB of storage while the user's NSP allocation may be 100 GB of storage. In such embodiments, the resource manager server 220 may manage the resources in the user's local allocation so that the user's local allocation is not exceeded. In some embodiments, the resource manager server 220 may utilize a first-in-first-out (FIFO) algorithm for managing the resources, thereby removing those resources that are likely to be out of date or less frequently used. In other embodiments, the resource manager server 220 may remove the less frequently accessed resources first.


Examples of Data Flow Between Components


With reference now to FIGS. 3-5 the interaction between various components of the resource delivery environment 100 of FIG. 1 will be illustrated. For purposes of the example, however, the illustration has been simplified such that many of the components utilized to facilitate communications are not shown. It can be appreciated that such components can be utilized and that additional interactions would accordingly occur without departing from the spirit and scope of the present disclosure. In addition, for the purposes of simplicity, communications between user computing devices of the same LAN are shown via direct arrows even though, in some embodiments, such communication may go through the router/access point. As shown herein, data flow arrows going through the router/access point are meant to represent data flowing out a LAN and to the NSP, or out of the NSP and to the LAN.


Further, FIGS. 3-5 outline the temporal flow of data between the various components of the resource delivery environment 100. In particular, the circled numerals of FIGS. 3-5 represent an illustrative order in which data may flow between the various components according to one embodiment. In other embodiments, the functions outlined by the circled numerals may be performed in a different order, and may include fewer or additional functions.



FIG. 3A illustrates one embodiment of the flow of data for uploading and requesting a resource within the resource delivery environment 100. The flow of FIG. 3A already assumes that the user has configured user computing devices 110, 111, 112 with resource manger clients and servers. In addition, the flow assumes that each of the user computing devices 110, 111, 112 has a user's local allocation for resources and the user has established with NSP 105 a user's NSP allocation for resources.


Prior to (1), a user may select a resource stored on user computing device 110 to upload to the NSP 105. The selection of the resource may be done via a user interface component of the resource manger client 210. At (1), the resource is transmitted over the network 180 to NSP 105, where it may be stored in the user's NSP allocation of storage 107, 109. Once the NSP 105 stores the resource, it may update the metadata associated with resource and transmit the updated metadata, at (2), to the user computing devices 110, 111, 112 running a resource manager server instance. In the embodiment of FIG. 3A, the metadata for the resource might contain a unique resource ID assigned to the resource by the NSP 105 so that the resource may be identified across computing systems. The metadata may also provide location information of the resource indicating that the most recent version of the resource is available at the NSP 105 and at user computing device I-A 110. Thus, after the metadata has been updated to the user computing devices 110, 111, 112, each resource manger server instance is aware that the most recent version of the resource may be obtained from either user computing device I-A 110 or NSP 105.


At (3), a user may request the resource at user computing device II-A. Since user computing device II-A does not have a copy of the resource, the resource manager server executing on user computing device II-A may access its copy of the received metadata to determine if the resource is available within LAN A 115. After accessing the metadata, the resource manager server of user computing device II-A may determine that the resource is available from user computing device I-A 110 and request the resource from user computing device I-A 110. At (4), the user computing device I-A receives the request for the resource. In some embodiments, user computing device I-A may verify that user computing device II-A 111 has been authorized or authenticated to receive the resource. Once user computing device II-A has been authorized or authenticated, user computing device I-A provides the resource to user computing device II-A. Thus, the resource was provided to the user computing device II-A without the need to leave the LAN A, thereby resulting in more efficient provision of the resource.



FIG. 3B illustrates one embodiment of the flow of data for editing and uploading a resource. The embodiment of FIG. 3B is an extension of the flow of data from FIG. 3A; that is, the resource was uploaded at first through user computing device I-A 110 to the NSP 105 and then user computing device II-A 111 requested and received the resource from user computing device I-A 110. Moving to (1) of FIG. 3B, a user may edit the resource at user computing device II-A. After editing the resource, the version of the resource stored in the user's local allocation of user computing device II-A is the most recent version of the resource, whereas the version stored on the NSP 105 and the version stored on user computing device I-A is out of date. The user, after editing, the resource may upload the resource to the NSP 105 at (2). After uploading the resource, the NSP 105 may update the metadata associated with the resource and then, at (3), send the updated metadata to each of the user computing devices 110, 111, 112. Upon further requests for the resource from the user using user computing device I-A 110 or III-A 112, the resource manager servers may locally consult the updated metadata provided in (3) and request the resource from user computing device II-A 111.


The embodiment of FIGS. 3A and 3B illustrates that metadata may be updated at the NSP 105 and then transmitted to user computing devices 110, 111, 112. However, the transmission of metadata may vary from embodiment to embodiment. For example, in other embodiments, the metadata may be stored at the NSP 105, and user computing devices may request the metadata from the NSP at the time the user requests a resource. In other embodiments, the NSP 105 may send updated metadata to one of the user computing devices 110, 111, 112 that acts a “master” of the other user computing devices in the LAN. As such, the master user computing device may provide metadata on request to the other user computing devices connected to the LAN that are participating in the resource delivery environment 100.



FIG. 3C illustrates another embodiment of the flow of data for editing and uploading a resource. The embodiment of FIG. 3C is an extension of the flow of data from FIG. 3A; that is, the resource was uploaded at first through user computing device I-A 110 to the NSP 105 and then user computing device II-A 111 requested and received the resource from user computing device I-A 110. In addition, the embodiment of FIG. 3C is an alternative to the flow illustrated in FIG. 3B. In general, instead of the NSP 105 providing updated metadata to the user computing devices 110, 111, 112 after the resource was edited and uploaded to the NSP 105 as illustrated in FIG. 3B, the flow in FIG. 3C illustrates the user computing device II-A 111 providing updated metadata to the other user computing devices 110 and 112 after the resource was edited and uploaded to the NSP 105. More specifically, moving to (1) of FIG. 3C, a user may edit the resource at user computing device II-A. After editing the resource, the version of the resource stored in the user's local allocation of user computing device II-A is the most recent version of the resource, whereas the version stored on the NSP 105 and the version stored on user computing device I-A is out of date. The user, after editing, the resource may upload the resource to the NSP 105 at (2). After uploading the resource, the user computing device II-A 111 may update the metadata associated with the resource and then, at (3), send the updated metadata to each of the other user computing devices 110, 112 associated with LAN A 115. Upon further requests for the resource from the user using user computing device I-A 110 or III-A 112, the resource manager servers may locally consult the updated metadata provided in (3) and request the resource from user computing device II-A 111.



FIGS. 4A and 4B illustrates one embodiment of the flow of data for requesting a resource where resource manager servers poll each user computing device within the LAN before requesting the resource from the NSP 105. The embodiment of FIGS. 4A and 4B differs from the embodiment of FIGS. 3A and 3B in that the embodiment of FIGS. 4A and 4B do not depend on the use of metadata to determine the location of a resource. Although the embodiment of FIGS. 4A and 4B do not depend on metadata to determine the location of a resource, some embodiments may use the metadata to determine resource identifiers, version information, or status information of the resource.



FIG. 4B illustrates one embodiment of the flow of data for requesting a resource available on a local area network. At (1), the user computing device I-A 110 receives a first request for a resource from a user. The user may use, in some embodiments, the resource manager client 210 to request the resource. The requested resource may be among the resources that have been uploaded to the NSP before the user made the request. For example, the resource may be displayed in a list of all the resources available in the user's NSP allocation. In the embodiment of FIG. 4B, the resource manager server 220 determines that the requested resource is not available at user computing device I-A 110. As a result, it must request and receive the resource from either the other computing devices on LAN A 115 (user computing device II-A 111, user computing device III-A 112) or request the resource from the NSP 105.


In (2), the user computing device I-A 110 polls each of the computing devices on LAN A 115 for the requested resource. Illustratively, the user computing device I-A 110 may poll for specific resources or a generic request for all resources or sets of resources. The resource manager server 220 instance of user computing device I-A 110 may access the list or data structure of participating computing devices to determine those computing devices to poll. For example, in the embodiment of FIG. 4A, the resource manager server instance executing on user computing device I-A 110 may have discovered that user computing device II-A 111 and user computing device III-A 112 are devices participating in the resource deliver environment (that is, they are executing an instance of the resource manager server). In the embodiment of FIG. 4A, the user computing device I-A polls, or requests, the resource from each of the participating computing devices. In the illustrative embodiment of FIG. 4A, neither user computing device II-A nor user computing device III-A have the resource. As a result, both respond back to the user computing device I-A indicating the resource is not available.


Upon determining that the resource is not available on the LAN A 115, the user computing device I-A 110, at (3), may request the resource from the NSP 105. The resource manager server 220 executing on the user computing device I-A may request the resource using a resource identifier. Upon receiving the request, the NSP 105 may provide the resource to user computing device I-A 110 at (4).



FIG. 4B illustrates one embodiment of the flow of data for requesting the resource of FIG. 4A from a computing device located on the LAN A 115. The illustrative embodiment of FIG. 4B describes additional steps that may be performed after the steps illustrated in FIG. 4A.


At (1) of FIG. 4B, a user may make a second request for the resource, but the request may be made from user computing device II-A 111 instead of user computing device I-A. User computing device II-A may execute a resource manager server 220 instance that maintains a list or data structure of those computing devices that are participating in the resource delivery environment 100. The resource manager server of user computing device II-A may then consult the list or data structure and determine that both user computing device I-A 110 and user computing device III-A 112 are participating computing devices. In some embodiments, the resource manager server of user computing device II-A may also check to make sure that that both user computing device I-A 110 and user computing device III-A 112 have been authorized or authenticated to provide the resource. Then, at (2), user computing device II-A polls or requests the resource from each participating device: user computing device I-A 110 and user computing device III-A. As described above with respect to FIG. 4B, user computing device I-A has a copy of the requested resource and user computing device III-A does not have a copy of the requested resource. As a result, the user computing device II-A receives notification that the resource is available from user computing device I-A.


In some embodiments, the user may request the most recent version of a resource, a particular version of a resource (e.g., “version 3.2”) or may request a minimum version of a resource (e.g., “at least version 3.2”). At (3), user computing device II-A 111 may check the version of the resource available from user computer device I-A to determine if it is the requested version of the resource. In some embodiments, the most recent version of the resource may be determined by checking the metadata of the resource available from user computing device I-A against the metadata of the resource available from NSP 105. In other embodiments, the metadata of the resource available from user computing device I-A may have status information indicating that the resource is the requested version. Once the user computing device II-A verifies that the version of the resource available form user computing device I-A is the requested version, it may then request and receive the resource at (4). In some embodiments, the user computing device I-A may check the metadata of the resource to ensure that user computing device II-A has been authorized or authenticated to receive the resource before providing it. Although the illustrative embodiment verifies the version of the resource available from user computing device I-A before receiving the resource from user computing device I-A, in other embodiments, verification may occur after the resource has been received.


Turning now to FIG. 5A, an illustrative embodiment of the flow of data for pre-fetching a resource will now be described. At (1) of the embodiment of FIG. 5A, a user may upload a resource to the NSP 105. Once the resource had been provided to the NSP 105, resource availability data may be sent, at (2), to computing devices that are participating in the resource delivery environment 100. The resource availability data may be part of metadata that is periodically retrieved by resource manager server instances in the resource delivery environment 100. In the embodiment of FIG. 5A, user computing device I-A 110 (of LAN A), user computing device I-B 120 (of LAN B), and user computing device II-B 121 (of LAN B) are computing devices participating in the resource delivery environment 100. As a result, NSP 105 provides the resource availability data to each device at (2).


In the embodiment of FIG. 5A, the user computing device I-B has a pre-fetch module 230 which has been configured to pre-fetch resources. The pre-fetch module 230 may pre-fetch resources based on the type of resource (for example, word processing document, image, video) or some other criteria. At (3), the pre-fetch module 230 of user computing device I-B accesses and analyzes the resource availability data provided in (2) to determine if it should pre-fetch the resource from the NSP 105. For example, if the pre-fetch module 230 is configured to pre-fetch documents that are spreadsheets, and the resource is a spreadsheet, the pre-fetch module will request the resource from the NSP 105 at (4). If, however, the resource is an image, the pre-fetch module will not request the resource from the NSP 105 and will wait until it receives updated resource availability data. When it receives updated resource availability data, it may perform (3) again. Once the pre-fetch module 230 has requested the resource at (4), the NSP 105 may provide the resource to user computing device I-B at (5).


In the embodiment of FIG. 5A, the user did not request the resource using user computing device I-B, rather, the resource was pre-fetched from the NSP 105 automatically based on the configuration of the pre-fetch module. As stated above with respect to FIG. 2, in some embodiments, the pre-fetch module may be configured with pre-fetch parameters so that the user may customize the pre-fetch behavior of the module. By pre-fetching resources, the user computing device I-B may provide more efficient access to resources that are of interest to the user while the user is using user computing device I-B 120.



FIG. 5B illustrates one embodiment of the flow of data for requesting the pre-fetched resource of FIG. 5A from a computing device located on the LAN B 120. The illustrative embodiment of FIG. 5B describes additional steps that may be performed after the steps illustrated in FIG. 5A.



FIG. 5B illustrates one embodiment of the flow of data for requesting a pre-fetched resource available on a local area network. In the embodiment of FIG. 5B, user computing device II-B does not have a pre-fetch module configured to pre-fetch the resource. The user at (1), may request the resource using user computing device II-B 121. The resource manager server instance of user computing device II-B may then, at (2), request the resource from user computing device I-B. In some embodiments, resource manager server instance of user computing device II-B may access and analyze metadata of the resource to determine the location of the most recent version of the resource (similar to the process described in FIGS. 3A and 3B) or in other embodiments may poll all participating computing devices of the LAN B 125 to determine if the devices have the resource (similar to the process described in FIGS. 4A and 4B). After the user computing device II-B 121 requests the resource from user computing device I-B 120, the user computing device II-B 121 receives the resource at (3). In some embodiments, the user computing device II-B 121 may verify that the version of the resource available at user computing device II-A is the most recent version as described above with respect to (3) of FIG. 4B.


Examples of Process Flow



FIGS. 6A-6C illustrate examples of embodiments of the process flow for embodiments of the resource delivery environment 100. Depending on the embodiment, the processes and methods of FIGS. 6A-6C may include fewer or additional blocks and/or the blocks may be performed in a different order than is illustrated. For ease of explanation, the processes and methods will be described herein as performed by one or more specific computer systems. However, other computer systems or modules may perform the process and methods without changing the overall scope of functionality of certain embodiments. Software code configured for execution on a computing device in order to perform the methods may be provided on a tangible computer readable medium, such as a compact disc, digital video disc, flash drive, hard drive, memory device or any other tangible medium. Such software code may be stored, partially or fully, on a memory of a computing device, such as the user computing device 110, and/or other computing devices illustrated in the figures described herein to perform the respective methods.



FIG. 6A is a flowchart illustrating one embodiment of the flow of data for initiating a resource manager server instance and listening for requests for resources. At block 601, an instance of the resource manager server 220 is initiated. The resource manager service may be a daemon that is started during the start up of the user computing device 110, or in other embodiments, may be started at the user's request. In some embodiments, the initiation of the resource manager server instance may start upon the user launching the resource manager client 210. In some embodiments, at initiation, the resource manager server 220 may establish a socket server on a dedicated port to listen for any incoming socket connection requests. The resource manager server 220 may also be configured to periodically broadcast notification packets that notify any other resource manager instance on its LAN that the resource manager server 220 is available to receive requests for resources. Processing may then move to block 602.


At block 602, the resource manager server 220 detects other computing devices on the network that are participating in the resource delivery environment 100. In some embodiments, the resource manager server 220 interfaces with, or includes, a packet analyzer that detects notification packets sent by other resource manager server instances on the network. In other embodiments, the resource manger server 220 may leverage network utilities of the user computing device's 110 operating system to detect all computing devices on the LAN and then attempt to establish a connection with the detected computing devices on an established port. If the connection is successful, the resource manager server 220 will know that the computing device is executing a resource manager server instance.


Once the participating devices are detected, processing moves to block 603. The resource manager server 220 may maintain a list or data structure of available resource manager servers on its LAN. In some embodiments, the resource manager server instance may also receive resource metadata from the other resource manager server instances on the LAN. At block 603, the resource manager server 220 may also update the metadata of the resources that are part of the user's local allocation. For example, the resource manager server 220 may communicate with the NSP 105 to retrieve the metadata for all resources of the user's NSP allocation and compare it with the metadata of the user computing device 110 to determine if there have been any changes in the metadata.


After the resource manager server 220 has updated available server and resource data in block 603, at block 604, the resource manager server 220 may listen for requests for resources. In some embodiments, the resource manager server 220 may expose a port for receiving resource requests. The requests may come from other resource manager service instance daemons executing within the LAN. In some embodiments, the resource manager client 210 may request the resource manager server 220 to retrieve a resource. The resource manager client 210 may communicate with the resource manager server 220 through the listening port, or in other embodiments, may communicate with the resource manager server through an API or other software interface. In some embodiments, the resource manager server 220 may refresh the server and resource data by executing the process flow again starting with block 602. The process flow may return to block 602 after a particular time-to-live (“TTL”). The TTL may be configured by the user, or in other embodiments, may be set to a fixed value programmatically. In other embodiments, blocks 602 and 603 may be executed concurrently in a separate processing thread, thereby continuously refreshing server and resource data. At block 605, when a resource has been requested, process flows to subroutine B. Subroutine B is described in greater detail with respect to FIG. 6B.



FIG. 6B is a flowchart illustrating one embodiment of the flow of data for providing a resource in response to a request for the resource. At block 620, the metadata for the resource is accessed. In some embodiments, the metadata is local to the user computing device 110 and the resource manager server 220 may access the metadata locally. In some embodiments, the metadata may be accessed from the NSP 105, or in other embodiments may be accessed by another computing device within the LAN. The resource manager server 220 may analyze the metadata and determine that most recent version of the resource is available in the data store 204 of the user computing device at block 621. If so, processing moves to block 622 and the resource is provided to the requester. If the resource is not available in the data store 204, the resource manager server 220 may analyze the metadata to determine if the resource is available on the LAN. If the resource is available on the LAN, processing moves to block 631 where the resource is accessed from the computing device on the local network storing the resource. Once accessed, the connected data store 204 is updated to have a copy of the most recent version of the resource. Process then flows to block 622. If the resource is not available on the LAN, then the resource manager server may access the resource from the remote NSP 105. Once accessed, the connected data store 204 is updated and the resource is returned to the requester at block 622.



FIG. 6C is a flowchart illustrating one embodiment of the flow of data for initiating a resource manager server instance and listening for requests for resources. FIG. 6C is similar to FIG. 6A in that the description of the process for each block is the same for FIG. 6C as it is for FIG. 6A. The process flow for FIG. 6C, however, occurs in a different order. Specifically, in FIG. 6C, blocks 602 and 603 are performed in response to a request for a resource from a user. In the embodiment illustrated in FIG. 6C, once the resource manager server 220 has been initiated, it may listen for requests from a resource. Once it receive the request, it may then detect any participating computing devices on the LAN, update server and resource data, and move to subroutine B to retrieve the resource.


Although certain embodiments have been described in the context of a local area network, other embodiments of the resource delivery environment may be used to manage resources across networks where accessing a resource from remote NSP may less efficient than accessing the same resource from a node within the network.


Each of the processes, methods, and algorithms described in the preceding sections may be embodied in, and fully or partially automated by, code modules executed by one or more computer systems or computer processors comprising computer hardware. The code modules may be stored on any type of non-transitory computer-readable medium or computer storage device, such as hard drives, solid state memory, optical disc, and/or the like. The systems and modules may also be transmitted as generated data signals (e.g., as part of a carrier wave or other analog or digital propagated signal) on a variety of computer-readable transmission mediums, including wireless-based and wired/cable-based mediums, and may take a variety of forms (e.g., as part of a single or multiplexed analog signal, or as multiple discrete digital packets or frames). The processes and algorithms may be implemented partially or wholly in application-specific circuitry. The results of the disclosed processes and process steps may be stored, persistently or otherwise, in any type of non-transitory computer storage such as, e.g., volatile or non-volatile storage.


The various features and processes described above may be used independently of one another, or may be combined in various ways. All possible combinations and subcombinations are intended to fall within the scope of this disclosure. In addition, certain method or process blocks may be omitted in some implementations. The methods and processes described herein are also not limited to any particular sequence, and the blocks or states relating thereto can be performed in other sequences that are appropriate. For example, described blocks or states may be performed in an order other than that specifically disclosed, or multiple blocks or states may be combined in a single block or state. The example blocks or states may be performed in serial, in parallel, or in some other manner. Blocks or states may be added to or removed from the disclosed example embodiments. The example systems and components described herein may be configured differently than described. For example, elements may be added to, removed from, or rearranged compared to the disclosed example embodiments.


Conditional language used herein, such as, among others, “can,” “could,” “might,” “may,” “e.g.,” and the like, unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments include, while other embodiments do not include, certain features, elements and/or steps. Thus, such conditional language is not generally intended to imply that features, elements and/or steps are in any way required for one or more embodiments or that one or more embodiments necessarily include logic for deciding, with or without author input or prompting, whether these features, elements and/or steps are included or are to be performed in any particular embodiment. The terms “comprising,” “including,” “having,” and the like are synonymous and are used inclusively, in an open-ended fashion, and do not exclude additional elements, features, acts, operations, and so forth. Also, the term “or” is used in its inclusive sense (and not in its exclusive sense) so that when used, for example, to connect a list of elements, the term “or” means one, some, or all of the elements in the list. Conjunctive language such as the phrase “at least one of X, Y and Z,” unless specifically stated otherwise, is otherwise understood with the context as used in general to convey that an item, term, etc. may be either X, Y or Z. Thus, such conjunctive language is not generally intended to imply that certain embodiments require at least one of X, at least one of Y and at least one of Z to each be present.


While certain example embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the disclosure. Thus, nothing in the foregoing description is intended to imply that any particular element, feature, characteristic, step, module, or block is necessary or indispensable. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions disclosed herein. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of certain of the inventions disclosed herein.


It should be emphasized that many variations and modifications may be made to the above-described embodiments, the elements of which are to be understood as being among other acceptable examples. All such modifications and variations are intended to be included herein within the scope of this disclosure and protected by the following claims.

Claims
  • 1. A method for retrieving a resource for a user comprising: determining, by a first computer device on a local area network, one or more computer devices connected to the local area network and configured to host resources, wherein the local area network comprises a local access point, each of the one or more computer devices are connected to the local access point, wherein a remote network storage provider is not connected to the local area network and the one or more computer devices communicate with remote network storage provider via the local access point;receiving, by the first computer device, a request for a resource;transmitting a request to at least one of the one or more computer devices connected to the local area network to determine whether the resource is available from the one or more computer devices connected to the local area network;receiving responses from the at least one of the one or more computer devices connected to the local area network indicating whether the resource is available from the one or more computer devices connected to the local area network;if the received responses from the one or more computer devices indicate that the resource is available, accessing, by the first computer device, an indication that the resource is available from a second computer device of the one or more computer devices connected to the local area network; andrequesting, by the first computer device, the most recent version of the resource hosted by the second computer device of the one or more computer devices connected to the local area network; anddetermining, by the second computer system, whether the first computer system is authorized to receive the resource based, at least in part, on metadata comprising authorization information associated with the resource, wherein the metadata includes an encrypted token that allows access to the resource to computer devices capable of decrypting the token;if the received responses from the one or more computer devices indicate that the resource is not available, requesting, by the first computer device, the resource from the remote network storage provider that is not connected to the local area network.
  • 2. The method of claim 1 further comprising: monitoring, by the first computer device, resource availability data, the resource availability data comprising an indication of a plurality of available resources from the second computer device or the remote computer system;determining, by the first computer device, whether the first computer device should pre-fetch one of the plurality of available resources; andautomatically pre-fetching, by the first computer, the one of the plurality of from the second computer device or the remote computer system.
  • 3. The method of claim 2, wherein the determining whether the first computer device should pre-fetch one of the plurality of available resources is based at least in part on the last accessed time of the plurality of resources.
  • 4. The method of claim 2, wherein the determining whether the first computer device should pre-fetch one of the plurality of available resources is based at least in part on a type of the plurality of resources.
  • 5. The method of claim 1, wherein the one or more computer devices are connected to the local access point using a wired connection or a wireless connection.
  • 6. The method of claim 1, transmitting a request comprises polling each of the one of the one or more computer devices connected to the local area network to determine whether the resource is available from the one or more computer devices connected to the local area network.
  • 7. A computer system connected to a local area network, the computer system comprising: a processor;a computer readable medium storing software instructions that when executed cause the processor to: detect one or more participating local computer devices, each of the participating local computer devices connected to the local area network and configured to provide resources to the other participating local computer devices, wherein the local area network comprises a local access point, each of the one or more participating local computer devices within the local area network are connected to the local access point, wherein a remote network storage provider is not connected to the local area network and the one or more participating local computer devices communicate with remote network storage provider via the local access point;receive a request for a resource;transmit a request to one or more of the participating local computer devices to determine whether the resource is available from one of the participating local computer devices within the local area network;receive responses from the one or more of the participating local computer devices indicating whether the resource is available from the one or more participating local computer devices;if the received responses indicate that the resource is available from one of the participating local computer devices within the local area network, request the resource from the participating local computer device that has the resource;receive the requested resource from the participating local computing device if the participating local computer device determines that the computer system is authorized to receive the requested resource based at least in part on authorization information included within the metadata of the resource, wherein the metadata includes an encrypted token that allows access to the resource to computing devices capable of decrypting the token; andif the received responses indicate that the resource is not available from one of the participating local computer devices within the local area network, request the resource from the remote network storage provider not connected to the local area network.
  • 8. The system of claim 7, wherein the software instructions stored in the computer readable medium further cause the processor to receive resource description data from the remote computer system.
  • 9. The system of claim 7, wherein the software instructions stored in the computer readable medium further cause the processor to receive resource description data from one of the participating computer devices.
  • 10. The system of claim 7, wherein the software instructions stored in the computer readable medium further cause the processor to: receive resource availability data from the remote computer system, the resource availability data indicating a plurality of available resources from the remote computer system;determine whether to pre-fetch one of the plurality available resources; andautomatically pre-fetch one of the plurality of available resources from the remote computer system.
  • 11. The system of claim 10 wherein the determining whether to pre-fetch one of the plurality of available resources is based at least in part on the last accessed time of the plurality of resources.
  • 12. The system of claim 10 wherein the determining whether to pre-fetch one of the plurality of available resources is based at least in part on a type of the plurality of resources.
  • 13. The system of claim 7, wherein the software instructions stored in the computer readable medium further cause the processor to modify the resource availability data to reflect that the system has an updated version of the resource.
  • 14. The system of claim 13, wherein the resource is stored by the computer system with a first attribute, and the software instructions stored in the computer readable medium further cause the processor to provide the resource to the requesting computer device with a second attribute.
  • 15. The system of claim 14, wherein the resource is a video resource and the software instructions stored in the computer readable medium further cause the processor to stream the resource to the requesting computer device.
  • 16. The system of claim 7, wherein the request for the resource comprises a requested version, and wherein the software instructions stored in the computer readable medium further cause the processor to verify that the resource from the local computer device hosting the resource matches the requested version.
  • 17. A non-transitory computer readable medium storing software instructions that when executed by a processor of a computer system, cause the processor to: receive information describing resources available from a remote network storage provider that is not connected to a local area network of the computer system;detect one or more participating local computer devices, each of the participating local computer devices connected to the local area network, wherein the local area network comprises a local access point, each of the one or more participating local computer devices within the local area network are connected to the local access point, wherein the one or more participating local computer devices communicate with the remote network storage provider via the local access point;receive a request for a resource;transmit a request to one or more of the participating local computer devices to determine whether the most recent version of the updated resource is located on one of the participating local computing devices within the local area network;receive responses from the one or more of the participating local computer devices indicating whether the resource is available from the one or more participating local computer devices;if the received responses indicate that the resource is located on one of the participating local computing devices within the local area network, request the resource from the participating local computer device that has the resource;receive the requested resource from the participating local computing device if the participating local computer device determines that the computer system is authorized to receive the requested resource based at least in part on authorization information included within the metadata of the resource, wherein the metadata includes an encrypted token that allows access to the resource to computer devices capable of decrypting the token; andif the received responses indicate that the resource is not available from one of the participating local computer devices within the local area network, request the resource from the remote network storage provider.
  • 18. The non-transitory computer readable medium of claim 17, wherein the software instructions stored in the computer readable medium further cause the processor to determine that the requesting computer devices has been authorized to receive the stored resource.
  • 19. The non-transitory computer readable medium of claim 17, wherein the stored resource has a first characteristic, and the software instructions stored in the computer readable medium further cause the processor to provide the resource to the requesting computer device with a second characteristic.
  • 20. The non-transitory computer readable medium of claim 17, wherein the stored resource is a video resource, and software instructions stored in the computer readable medium further cause the processor to stream the stored resource to the requesting computer device.
  • 21. The non-transitory computer readable medium of claim 17, wherein the software instructions stored in the computer readable medium further cause the processor to periodically broadcast a notification data packet that provides an indication that the system is a participating local computer device.
  • 22. The non-transitory computer readable medium of claim 17 wherein the software instructions stored in the computer readable medium further cause the processor to detect the one or more participating local computer devices by receiving notification data packets sent by the participating local computer devices.
  • 23. The non-transitory computer readable medium of claim 17 wherein the software instructions stored in the computer readable medium further cause the processor to detect the one or more participating local computer devices by determining all of the computer devices connected to the local area network and attempting to establish a connection to a port configured to receive requests for resources.
US Referenced Citations (1169)
Number Name Date Kind
5063500 Shorter Nov 1991 A
5341477 Pitkin et al. Aug 1994 A
5459837 Caccavale Oct 1995 A
5611049 Pitts Mar 1997 A
5701467 Freeston Dec 1997 A
5764910 Shachar Jun 1998 A
5774660 Brendel et al. Jun 1998 A
5852717 Bhide et al. Dec 1998 A
5892914 Pitts Apr 1999 A
5893116 Simmonds Apr 1999 A
5895462 Toki Apr 1999 A
5905248 Russell et al. May 1999 A
5933811 Angles et al. Aug 1999 A
5937427 Shinagawa et al. Aug 1999 A
5974454 Apfel et al. Oct 1999 A
5991306 Burns et al. Nov 1999 A
5999274 Lee et al. Dec 1999 A
6016512 Huitema Jan 2000 A
6018619 Allard et al. Jan 2000 A
6026452 Pitts Feb 2000 A
6038601 Lambert et al. Mar 2000 A
6052718 Gifford Apr 2000 A
6078960 Ballard Jun 2000 A
6085234 Pitts et al. Jul 2000 A
6092100 Berstis et al. Jul 2000 A
6098096 Tsirigotis et al. Aug 2000 A
6108703 Leighton et al. Aug 2000 A
6128279 O'Neil et al. Oct 2000 A
6151631 Ansell et al. Nov 2000 A
6157942 Chu et al. Dec 2000 A
6167438 Yates et al. Dec 2000 A
6167446 Lister et al. Dec 2000 A
6173316 De Boor et al. Jan 2001 B1
6182111 Inohara et al. Jan 2001 B1
6182125 Borella et al. Jan 2001 B1
6185598 Farber et al. Feb 2001 B1
6192051 Lipman et al. Feb 2001 B1
6205475 Pitts Mar 2001 B1
6223288 Angles et al. Apr 2001 B1
6243761 Mogul et al. Jun 2001 B1
6275496 Burns et al. Aug 2001 B1
6286043 Cuomo et al. Sep 2001 B1
6286084 Wexler et al. Sep 2001 B1
6304913 Rune Oct 2001 B1
6324580 Jindal et al. Nov 2001 B1
6330602 Law et al. Dec 2001 B1
6338082 Schneider Jan 2002 B1
6345308 Abe Feb 2002 B1
6351743 DeArdo et al. Feb 2002 B1
6351775 Yu Feb 2002 B1
6363411 Dugan et al. Mar 2002 B1
6366952 Pitts Apr 2002 B2
6374290 Scharber et al. Apr 2002 B1
6377257 Borrel et al. Apr 2002 B1
6386043 Millins May 2002 B1
6405252 Gupta et al. Jun 2002 B1
6408360 Chamberlain et al. Jun 2002 B1
6411967 Van Renesse Jun 2002 B1
6415280 Farber et al. Jul 2002 B1
6430607 Kavner Aug 2002 B1
6438592 Killian Aug 2002 B1
6442165 Sitaraman et al. Aug 2002 B1
6452925 Sistanizadeh et al. Sep 2002 B1
6457047 Chandra et al. Sep 2002 B1
6459909 Bilcliff et al. Oct 2002 B1
6473804 Kaiser et al. Oct 2002 B1
6484143 Swildens et al. Nov 2002 B1
6484161 Chipalkatti et al. Nov 2002 B1
6493765 Cunningham et al. Dec 2002 B1
6505241 Pitts Jan 2003 B2
6523036 Hickman et al. Feb 2003 B1
6529910 Fleskes Mar 2003 B1
6529953 Van Renesse Mar 2003 B1
6553413 Leighton et al. Apr 2003 B1
6560610 Eatherton et al. May 2003 B1
6611873 Kanehara Aug 2003 B1
6622168 Datta Sep 2003 B1
6643357 Lumsden Nov 2003 B2
6643707 Booth Nov 2003 B1
6654807 Farber et al. Nov 2003 B2
6658462 Dutta Dec 2003 B1
6665706 Kenner et al. Dec 2003 B2
6678717 Schneider Jan 2004 B1
6678791 Jacobs et al. Jan 2004 B1
6681282 Golden et al. Jan 2004 B1
6694358 Swildens et al. Feb 2004 B1
6697805 Choquier et al. Feb 2004 B1
6724770 Van Renesse Apr 2004 B1
6732237 Jacobs et al. May 2004 B1
6754699 Swildens et al. Jun 2004 B2
6754706 Swildens et al. Jun 2004 B1
6760721 Chasen et al. Jul 2004 B1
6769031 Bero Jul 2004 B1
6782398 Bahl Aug 2004 B1
6785704 McCanne Aug 2004 B1
6795434 Kumar et al. Sep 2004 B1
6799214 Li Sep 2004 B1
6804706 Pitts Oct 2004 B2
6810291 Card et al. Oct 2004 B2
6810411 Coughlin et al. Oct 2004 B1
6829654 Jungck Dec 2004 B1
6862607 Vermeulen Mar 2005 B1
6868439 Basu et al. Mar 2005 B2
6874017 Inoue et al. Mar 2005 B1
6917951 Orbits et al. Jul 2005 B2
6928467 Peng et al. Aug 2005 B2
6928485 Krishnamurthy et al. Aug 2005 B1
6941562 Gao et al. Sep 2005 B2
6963850 Bezos et al. Nov 2005 B1
6976090 Ben-Shaul et al. Dec 2005 B2
6981017 Kasriel et al. Dec 2005 B1
6985945 Farhat et al. Jan 2006 B2
6986018 O'Rourke et al. Jan 2006 B2
6990526 Zhu Jan 2006 B1
6996616 Leighton et al. Feb 2006 B1
7003555 Jungck Feb 2006 B1
7006099 Gut et al. Feb 2006 B2
7007089 Freedman Feb 2006 B2
7010578 Lewin et al. Mar 2006 B1
7010598 Sitaraman et al. Mar 2006 B2
7024466 Outten et al. Apr 2006 B2
7031445 Lumsden Apr 2006 B2
7032010 Swildens et al. Apr 2006 B1
7058633 Gnagy et al. Jun 2006 B1
7058706 Iyer et al. Jun 2006 B1
7058953 Willard et al. Jun 2006 B2
7065587 Huitema et al. Jun 2006 B2
7072982 Teodosiu et al. Jul 2006 B2
7076633 Tormasov et al. Jul 2006 B2
7082476 Cohen et al. Jul 2006 B1
7086061 Joshi et al. Aug 2006 B1
7092505 Allison et al. Aug 2006 B2
7092997 Kasriel et al. Aug 2006 B1
7096266 Lewin et al. Aug 2006 B2
7099936 Chase et al. Aug 2006 B2
7103645 Leighton et al. Sep 2006 B2
7114160 Suryanarayana et al. Sep 2006 B2
7117262 Bai Oct 2006 B2
7133905 Dilley et al. Nov 2006 B2
7136922 Sundaram et al. Nov 2006 B2
7139808 Anderson et al. Nov 2006 B2
7139821 Shah et al. Nov 2006 B1
7143169 Champagne et al. Nov 2006 B1
7143170 Swildens et al. Nov 2006 B2
7146560 Dang et al. Dec 2006 B2
7149809 Barde et al. Dec 2006 B2
7152118 Anderson, IV et al. Dec 2006 B2
7162539 Garcie-Luna-Aceves Jan 2007 B2
7174382 Ramanathan et al. Feb 2007 B2
7185063 Kasriel et al. Feb 2007 B1
7185084 Sirivara et al. Feb 2007 B2
7188214 Kasriel et al. Mar 2007 B1
7194522 Swildens et al. Mar 2007 B1
7194552 Schneider Mar 2007 B1
7200667 Teodosiu et al. Apr 2007 B2
7216170 Danker et al. May 2007 B2
7225254 Swildens et al. May 2007 B1
7228350 Hong et al. Jun 2007 B2
7228359 Monteiro Jun 2007 B1
7233978 Overton et al. Jun 2007 B2
7240100 Wein et al. Jul 2007 B1
7249196 Peiffer et al. Jul 2007 B1
7251675 Kamakura et al. Jul 2007 B1
7254626 Kommula et al. Aug 2007 B1
7254636 O'Toole, Jr. et al. Aug 2007 B1
7257581 Steele et al. Aug 2007 B1
7260598 Liskov et al. Aug 2007 B1
7260639 Afergan et al. Aug 2007 B2
7269784 Kasriel et al. Sep 2007 B1
7272227 Beran Sep 2007 B1
7274658 Bornstein et al. Sep 2007 B2
7284056 Ramig Oct 2007 B2
7289519 Liskov Oct 2007 B1
7293093 Leighton Nov 2007 B2
7308499 Chavez Dec 2007 B2
7310686 Uysal Dec 2007 B2
7316648 Kelly et al. Jan 2008 B2
7318074 Iyengar et al. Jan 2008 B2
7320131 O'Toole, Jr. Jan 2008 B1
7321918 Burd et al. Jan 2008 B2
7337968 Wilz, Sr. et al. Mar 2008 B2
7339937 Mitra et al. Mar 2008 B2
7340505 Lisiecki et al. Mar 2008 B2
7363291 Page Apr 2008 B1
7363626 Koutharapu et al. Apr 2008 B2
7370089 Boyd et al. May 2008 B2
7372809 Chen May 2008 B2
7373416 Kagan et al. May 2008 B2
7376736 Sundaram et al. May 2008 B2
7380078 Ikegaya et al. May 2008 B2
7392236 Rusch et al. Jun 2008 B2
7398301 Hennessey et al. Jul 2008 B2
7406512 Swildens et al. Jul 2008 B2
7406522 Riddle Jul 2008 B2
7409712 Brooks et al. Aug 2008 B1
7430610 Pace et al. Sep 2008 B2
7441045 Skene et al. Oct 2008 B2
7441261 Slater et al. Oct 2008 B2
7454457 Lowery et al. Nov 2008 B1
7454500 Hsu et al. Nov 2008 B1
7461170 Taylor et al. Dec 2008 B1
7464142 Flurry et al. Dec 2008 B2
7478148 Neerdaels Jan 2009 B2
7492720 Pruthi et al. Feb 2009 B2
7496651 Joshi Feb 2009 B1
7499998 Toebes et al. Mar 2009 B2
7502836 Menditto et al. Mar 2009 B1
7505464 Okmianski et al. Mar 2009 B2
7506034 Coates et al. Mar 2009 B2
7519720 Fishman et al. Apr 2009 B2
7519726 Palliyil et al. Apr 2009 B2
7523181 Swildens et al. Apr 2009 B2
7543024 Holstege Jun 2009 B2
7548947 Kasriel et al. Jun 2009 B2
7552235 Chase et al. Jun 2009 B2
7555542 Ayers et al. Jun 2009 B1
7561571 Lovett et al. Jul 2009 B1
7565407 Hayball Jul 2009 B1
7568032 Feng et al. Jul 2009 B2
7573916 Bechtolsheim et al. Aug 2009 B1
7574499 Swildens et al. Aug 2009 B1
7581009 Hsu et al. Aug 2009 B1
7594189 Walker et al. Sep 2009 B1
7596619 Leighton et al. Sep 2009 B2
7617222 Coulthard et al. Nov 2009 B2
7623460 Miyazaki Nov 2009 B2
7624169 Lisiecki et al. Nov 2009 B2
7631101 Sullivan et al. Dec 2009 B2
7640296 Fuchs et al. Dec 2009 B2
7650376 Blumenau Jan 2010 B1
7653700 Bahl et al. Jan 2010 B1
7653725 Yahiro et al. Jan 2010 B2
7657613 Hanson et al. Feb 2010 B1
7657622 Douglis et al. Feb 2010 B1
7661027 Langen et al. Feb 2010 B2
7664831 Cartmell et al. Feb 2010 B2
7664879 Chan et al. Feb 2010 B2
7676570 Levy et al. Mar 2010 B2
7680897 Carter et al. Mar 2010 B1
7684394 Cutbill et al. Mar 2010 B1
7685251 Houlihan et al. Mar 2010 B2
7693813 Cao et al. Apr 2010 B1
7693959 Leighton et al. Apr 2010 B2
7702724 Brydon et al. Apr 2010 B1
7706740 Collins et al. Apr 2010 B2
7707314 McCarthy et al. Apr 2010 B2
7711647 Gunaseelan et al. May 2010 B2
7711788 Lev Ran May 2010 B2
7716367 Leighton et al. May 2010 B1
7725602 Liu et al. May 2010 B2
7730187 Raciborski et al. Jun 2010 B2
7739400 Lindbo et al. Jun 2010 B2
7747720 Toebes et al. Jun 2010 B2
7756913 Day Jul 2010 B1
7756965 Joshi Jul 2010 B2
7757202 Dahlsted et al. Jul 2010 B2
7761572 Auerbach Jul 2010 B1
7765304 Davis et al. Jul 2010 B2
7769823 Jenny et al. Aug 2010 B2
7773596 Marques Aug 2010 B1
7774342 Virdy Aug 2010 B1
7783727 Foley et al. Aug 2010 B1
7787380 Aggarwal et al. Aug 2010 B1
7792989 Toebes et al. Sep 2010 B2
7805516 Kettler et al. Sep 2010 B2
7809597 Das et al. Oct 2010 B2
7813308 Reddy et al. Oct 2010 B2
7814229 Cabrera et al. Oct 2010 B1
7818454 Kim et al. Oct 2010 B2
7827256 Phillips et al. Nov 2010 B2
7836177 Kasriel et al. Nov 2010 B2
7853719 Cao et al. Dec 2010 B1
7865594 Baumback et al. Jan 2011 B1
7865953 Hsieh et al. Jan 2011 B1
7873065 Mukerji et al. Jan 2011 B1
7890612 Todd et al. Feb 2011 B2
7899899 Joshi Mar 2011 B2
7904875 Hegyi Mar 2011 B2
7912921 O'Rourke et al. Mar 2011 B2
7925782 Sivasubramanian et al. Apr 2011 B2
7930393 Baumback et al. Apr 2011 B1
7930402 Swildens et al. Apr 2011 B2
7930427 Josefsberg et al. Apr 2011 B2
7933988 Nasuto et al. Apr 2011 B2
7937477 Day et al. May 2011 B1
7945693 Farber et al. May 2011 B2
7949779 Farber et al. May 2011 B2
7958222 Pruitt et al. Jun 2011 B1
7958258 Yeung et al. Jun 2011 B2
7962597 Richardson et al. Jun 2011 B2
7966404 Hedin et al. Jun 2011 B2
7970816 Chess et al. Jun 2011 B2
7970940 van de Ven et al. Jun 2011 B1
7979509 Malmskog et al. Jul 2011 B1
7991910 Richardson et al. Aug 2011 B2
7996533 Leighton et al. Aug 2011 B2
7996535 Auerbach Aug 2011 B2
8000724 Rayburn et al. Aug 2011 B1
8001187 Stochosky Aug 2011 B2
8010707 Elzur et al. Aug 2011 B2
8019869 Kriegsman Sep 2011 B2
8024441 Kommula et al. Sep 2011 B2
8028090 Richardson et al. Sep 2011 B2
8041773 Abu-Ghazaleh et al. Oct 2011 B2
8041809 Sundaram et al. Oct 2011 B2
8041818 Gupta et al. Oct 2011 B2
8042054 White et al. Oct 2011 B2
8065275 Eriksen et al. Nov 2011 B2
8069231 Schran et al. Nov 2011 B2
8073940 Richardson Dec 2011 B1
8082348 Averbuj et al. Dec 2011 B1
8108623 Krishnaprasad et al. Jan 2012 B2
8117306 Baumback et al. Feb 2012 B1
8122098 Richardson et al. Feb 2012 B1
8122124 Baumback et al. Feb 2012 B1
8132242 Wu Mar 2012 B1
8135820 Richardson et al. Mar 2012 B2
8156199 Hoche-Mong et al. Apr 2012 B1
8156243 Richardson et al. Apr 2012 B2
8175863 Ostermeyer et al. May 2012 B1
8190682 Paterson-Jones et al. May 2012 B2
8195837 McCarthy et al. Jun 2012 B2
8224971 Miller et al. Jul 2012 B1
8224986 Liskov et al. Jul 2012 B1
8224994 Schneider Jul 2012 B1
8234403 Richardson et al. Jul 2012 B2
8239530 Sundaram et al. Aug 2012 B2
8250135 Driesen et al. Aug 2012 B2
8250211 Swildens et al. Aug 2012 B2
8250219 Raciborski et al. Aug 2012 B2
8266288 Banerjee et al. Sep 2012 B2
8266327 Kumar et al. Sep 2012 B2
8271471 Kamvar et al. Sep 2012 B1
8280998 Joshi Oct 2012 B2
8281035 Farber et al. Oct 2012 B2
8291046 Farber et al. Oct 2012 B2
8291117 Eggleston et al. Oct 2012 B1
8296393 Alexander et al. Oct 2012 B2
8301645 Crook Oct 2012 B1
8321568 Sivasubramanian et al. Nov 2012 B2
8346808 Higgins Jan 2013 B2
8380831 Barber Feb 2013 B2
8402137 Sivasubramanian et al. Mar 2013 B2
8423408 Barnes et al. Apr 2013 B1
8433749 Wee et al. Apr 2013 B2
8447831 Sivasubramanian et al. May 2013 B1
8447876 Verma et al. May 2013 B2
8452745 Ramakrishna May 2013 B2
8452874 MacCarthaigh et al. May 2013 B2
8463877 Richardson Jun 2013 B1
8468222 Sakata et al. Jun 2013 B2
8468245 Farber et al. Jun 2013 B2
8473613 Farber et al. Jun 2013 B2
8478903 Farber et al. Jul 2013 B2
8504721 Hsu et al. Aug 2013 B2
8510428 Joshi Aug 2013 B2
8510807 Elazary et al. Aug 2013 B1
8521851 Richardson et al. Aug 2013 B1
8521880 Richardson et al. Aug 2013 B1
8521908 Holmes et al. Aug 2013 B2
8526405 Curtis et al. Sep 2013 B2
8527639 Liskov et al. Sep 2013 B1
8527658 Holmes et al. Sep 2013 B2
8527660 Prasad et al. Sep 2013 B2
8549646 Stavrou et al. Oct 2013 B2
8572208 Farber et al. Oct 2013 B2
8572210 Farber et al. Oct 2013 B2
8577992 Richardson et al. Nov 2013 B1
8589996 Ma et al. Nov 2013 B2
8606996 Richardson et al. Dec 2013 B2
8612565 Schneider Dec 2013 B2
8615549 Knowles et al. Dec 2013 B2
8626950 Richardson et al. Jan 2014 B1
8635340 Schneider Jan 2014 B1
8639817 Sivasubramanian et al. Jan 2014 B2
8645539 McCarthy et al. Feb 2014 B2
8676918 Richardson et al. Mar 2014 B2
8683023 Brandwine et al. Mar 2014 B1
8683076 Farber et al. Mar 2014 B2
8688837 Richardson et al. Apr 2014 B1
8712950 Smith et al. Apr 2014 B2
8732309 Richardson et al. May 2014 B1
8745177 Kazerani et al. Jun 2014 B1
8756322 Lynch Jun 2014 B1
8756325 Sivasubramanian et al. Jun 2014 B2
8756341 Richardson et al. Jun 2014 B1
8782236 Marshall et al. Jul 2014 B1
8782279 Eggleston et al. Jul 2014 B2
8819283 Richardson et al. Aug 2014 B2
8904009 Marshall et al. Dec 2014 B1
8914514 Jenkins et al. Dec 2014 B1
8924528 Richardson et al. Dec 2014 B1
8930513 Richardson et al. Jan 2015 B1
8930544 Richardson et al. Jan 2015 B2
8938526 Richardson et al. Jan 2015 B1
8949459 Scholl Feb 2015 B1
8966318 Shah Feb 2015 B1
9003035 Richardson et al. Apr 2015 B1
9003040 MacCarthaigh et al. Apr 2015 B2
9009286 Sivasubramanian et al. Apr 2015 B2
9009334 Jenkins et al. Apr 2015 B1
9021127 Richardson et al. Apr 2015 B2
9021128 Sivasubramanian et al. Apr 2015 B2
9021129 Richardson et al. Apr 2015 B2
9026616 Sivasubramanian et al. May 2015 B2
9037975 Taylor et al. May 2015 B1
9075893 Jenkins Jul 2015 B1
9083675 Richardson et al. Jul 2015 B2
9083743 Patel et al. Jul 2015 B1
9106701 Richardson et al. Aug 2015 B2
9116803 Agrawal et al. Aug 2015 B1
9130756 Richardson et al. Sep 2015 B2
9130977 Zisapel et al. Sep 2015 B2
9137302 Makhijani et al. Sep 2015 B1
9154551 Watson Oct 2015 B1
9160703 Richardson et al. Oct 2015 B2
9172674 Patel et al. Oct 2015 B1
9176894 Marshall et al. Nov 2015 B2
9185012 Richardson et al. Nov 2015 B2
9191338 Richardson et al. Nov 2015 B2
9191458 Richardson et al. Nov 2015 B2
9195996 Walsh et al. Nov 2015 B1
9208097 Richardson et al. Dec 2015 B2
9210235 Sivasubramanian et al. Dec 2015 B2
9237087 Risbood et al. Jan 2016 B1
9237114 Richardson et al. Jan 2016 B2
9240954 Ellsworth et al. Jan 2016 B1
9246776 Ellsworth et al. Jan 2016 B2
9251112 Richardson et al. Feb 2016 B2
9253065 Richardson et al. Feb 2016 B2
9294391 Mostert Mar 2016 B1
9323577 Marr et al. Apr 2016 B2
9332078 Sivasubramanian et al. May 2016 B2
9386038 Martini Jul 2016 B2
9391949 Richardson et al. Jul 2016 B1
9407681 Richardson et al. Aug 2016 B1
9407699 Sivasubramanian et al. Aug 2016 B2
9444759 Richardson et al. Sep 2016 B2
9479476 Richardson et al. Oct 2016 B2
9495338 Hollis et al. Nov 2016 B1
9497259 Richardson et al. Nov 2016 B1
9515949 Richardson et al. Dec 2016 B2
9525659 Sonkin et al. Dec 2016 B1
9544394 Richardson et al. Jan 2017 B2
9571389 Richardson et al. Feb 2017 B2
9590946 Richardson et al. Mar 2017 B2
9608957 Sivasubramanian et al. Mar 2017 B2
9621660 Sivasubramanian et al. Apr 2017 B2
9628554 Marshall et al. Apr 2017 B2
9712325 Richardson et al. Jul 2017 B2
9712484 Richardson et al. Jul 2017 B1
20010000811 May et al. May 2001 A1
20010025305 Yoshiasa et al. Sep 2001 A1
20010027479 Delaney Oct 2001 A1
20010032133 Moran Oct 2001 A1
20010034704 Farhat et al. Oct 2001 A1
20010049741 Skene et al. Dec 2001 A1
20010052016 Skene et al. Dec 2001 A1
20010056416 Garcia-Luna-Aceves Dec 2001 A1
20010056500 Farber et al. Dec 2001 A1
20020002613 Freeman et al. Jan 2002 A1
20020004846 Garcia-Luna-Aceves et al. Jan 2002 A1
20020007413 Garcia-Luna-Aceves et al. Jan 2002 A1
20020010783 Primak et al. Jan 2002 A1
20020010798 Ben-Shaul et al. Jan 2002 A1
20020035624 Jun-hyeong Mar 2002 A1
20020048269 Hong et al. Apr 2002 A1
20020049608 Hartsell et al. Apr 2002 A1
20020049857 Farber et al. Apr 2002 A1
20020052942 Swildens et al. May 2002 A1
20020062372 Hong et al. May 2002 A1
20020068554 Dusse Jun 2002 A1
20020069420 Russell et al. Jun 2002 A1
20020078233 Biliris et al. Jun 2002 A1
20020082858 Heddaya et al. Jun 2002 A1
20020083118 Sim Jun 2002 A1
20020083148 Shaw et al. Jun 2002 A1
20020083178 Brothers Jun 2002 A1
20020087374 Boubez et al. Jul 2002 A1
20020091786 Yamaguchi et al. Jul 2002 A1
20020091801 Lewin et al. Jul 2002 A1
20020092026 Janniello et al. Jul 2002 A1
20020099616 Sweldens Jul 2002 A1
20020099850 Farber et al. Jul 2002 A1
20020101836 Dorenbosch Aug 2002 A1
20020103820 Cartmell et al. Aug 2002 A1
20020103972 Satran et al. Aug 2002 A1
20020107944 Bai et al. Aug 2002 A1
20020112049 Elnozahy et al. Aug 2002 A1
20020116481 Lee Aug 2002 A1
20020116491 Boyd et al. Aug 2002 A1
20020116582 Copeland et al. Aug 2002 A1
20020120666 Landsman et al. Aug 2002 A1
20020120782 Dillon et al. Aug 2002 A1
20020124047 Gartner et al. Sep 2002 A1
20020124098 Shaw Sep 2002 A1
20020129123 Johnson et al. Sep 2002 A1
20020131428 Pecus et al. Sep 2002 A1
20020133741 Maeda et al. Sep 2002 A1
20020135611 Deosaran et al. Sep 2002 A1
20020138286 Engstrom Sep 2002 A1
20020138437 Lewin et al. Sep 2002 A1
20020138443 Schran et al. Sep 2002 A1
20020143675 Orshan Oct 2002 A1
20020143989 Huitema et al. Oct 2002 A1
20020145993 Chowdhury et al. Oct 2002 A1
20020147770 Tang Oct 2002 A1
20020147774 Lisiecki et al. Oct 2002 A1
20020150094 Cheng et al. Oct 2002 A1
20020150276 Chang Oct 2002 A1
20020152326 Orshan Oct 2002 A1
20020154157 Sherr et al. Oct 2002 A1
20020156884 Bertram et al. Oct 2002 A1
20020156911 Croman et al. Oct 2002 A1
20020161745 Call Oct 2002 A1
20020161767 Shapiro et al. Oct 2002 A1
20020163882 Bornstein et al. Nov 2002 A1
20020165912 Wenocur et al. Nov 2002 A1
20020169890 Beaumont et al. Nov 2002 A1
20020184368 Wang Dec 2002 A1
20020188722 Banerjee et al. Dec 2002 A1
20020194324 Guha Dec 2002 A1
20020194382 Kausik et al. Dec 2002 A1
20020198953 O'Rourke et al. Dec 2002 A1
20030002484 Freedman Jan 2003 A1
20030005111 Allan Jan 2003 A1
20030007482 Khello et al. Jan 2003 A1
20030009488 Hart, III Jan 2003 A1
20030009591 Hayball et al. Jan 2003 A1
20030026410 Lumsden Feb 2003 A1
20030028642 Agarwal et al. Feb 2003 A1
20030033283 Evans et al. Feb 2003 A1
20030037108 Peiffer et al. Feb 2003 A1
20030037139 Shteyn Feb 2003 A1
20030041094 Lara et al. Feb 2003 A1
20030046343 Krishnamurthy et al. Mar 2003 A1
20030065739 Shnier Apr 2003 A1
20030074401 Connell et al. Apr 2003 A1
20030074471 Anderson et al. Apr 2003 A1
20030074472 Lucco et al. Apr 2003 A1
20030079027 Slocombe et al. Apr 2003 A1
20030093523 Cranor et al. May 2003 A1
20030099202 Lear et al. May 2003 A1
20030099237 Mitra et al. May 2003 A1
20030101278 Garcia-Luna-Aceves et al. May 2003 A1
20030112792 Cranor et al. Jun 2003 A1
20030120741 Wu et al. Jun 2003 A1
20030133554 Nykanen et al. Jul 2003 A1
20030135467 Okamoto Jul 2003 A1
20030135509 Davis et al. Jul 2003 A1
20030140087 Lincoln et al. Jul 2003 A1
20030145038 Tariq et al. Jul 2003 A1
20030145066 Okada et al. Jul 2003 A1
20030149581 Chaudhri et al. Aug 2003 A1
20030154239 Davis et al. Aug 2003 A1
20030154284 Bernardin et al. Aug 2003 A1
20030163722 Anderson, IV Aug 2003 A1
20030172145 Nguyen Sep 2003 A1
20030172183 Anderson, IV et al. Sep 2003 A1
20030172291 Judge et al. Sep 2003 A1
20030174648 Wang et al. Sep 2003 A1
20030182305 Balva et al. Sep 2003 A1
20030182413 Allen et al. Sep 2003 A1
20030182447 Schilling Sep 2003 A1
20030187935 Agarwalla et al. Oct 2003 A1
20030187970 Chase et al. Oct 2003 A1
20030191822 Leighton et al. Oct 2003 A1
20030200394 Ashmore et al. Oct 2003 A1
20030204602 Hudson et al. Oct 2003 A1
20030229682 Day Dec 2003 A1
20030233423 Dilley et al. Dec 2003 A1
20030233445 Levy et al. Dec 2003 A1
20030233455 Leber et al. Dec 2003 A1
20030236700 Arning et al. Dec 2003 A1
20030236779 Choi et al. Dec 2003 A1
20040003032 Ma et al. Jan 2004 A1
20040010563 Forte et al. Jan 2004 A1
20040010588 Slater et al. Jan 2004 A1
20040010621 Afergan et al. Jan 2004 A1
20040015584 Cartmell et al. Jan 2004 A1
20040019518 Abraham et al. Jan 2004 A1
20040024841 Becker et al. Feb 2004 A1
20040030620 Benjamin et al. Feb 2004 A1
20040034744 Karlsson et al. Feb 2004 A1
20040039798 Hotz et al. Feb 2004 A1
20040044731 Chen et al. Mar 2004 A1
20040044791 Pouzzner Mar 2004 A1
20040054757 Ueda Mar 2004 A1
20040059805 Dinker et al. Mar 2004 A1
20040064335 Yang Apr 2004 A1
20040064501 Jan et al. Apr 2004 A1
20040068542 Lalonde et al. Apr 2004 A1
20040073596 Kloninger et al. Apr 2004 A1
20040073707 Dillon Apr 2004 A1
20040073867 Kausik et al. Apr 2004 A1
20040078468 Hedin et al. Apr 2004 A1
20040078487 Cernohous et al. Apr 2004 A1
20040083283 Sundaram et al. Apr 2004 A1
20040083307 Uysal Apr 2004 A1
20040117455 Kaminksy et al. Jun 2004 A1
20040128344 Trossen Jul 2004 A1
20040128346 Melamed et al. Jul 2004 A1
20040148520 Talpade et al. Jul 2004 A1
20040167981 Douglas et al. Aug 2004 A1
20040167982 Cohen et al. Aug 2004 A1
20040172466 Douglas et al. Sep 2004 A1
20040194085 Beaubien et al. Sep 2004 A1
20040194102 Neerdaels Sep 2004 A1
20040203630 Wang Oct 2004 A1
20040205149 Dillon et al. Oct 2004 A1
20040205162 Parikh Oct 2004 A1
20040215823 Kleinfelter et al. Oct 2004 A1
20040221019 Swildens et al. Nov 2004 A1
20040221034 Kausik et al. Nov 2004 A1
20040246948 Lee et al. Dec 2004 A1
20040249939 Amini et al. Dec 2004 A1
20040249971 Klinker Dec 2004 A1
20040249975 Tuck et al. Dec 2004 A1
20040250119 Shelest et al. Dec 2004 A1
20040254921 Cohen et al. Dec 2004 A1
20040267906 Truty Dec 2004 A1
20040267907 Gustafsson Dec 2004 A1
20050010653 McCanne Jan 2005 A1
20050021706 Maggi et al. Jan 2005 A1
20050021862 Schroeder et al. Jan 2005 A1
20050027882 Sullivan et al. Feb 2005 A1
20050038967 Umbehocker et al. Feb 2005 A1
20050044270 Grove et al. Feb 2005 A1
20050102683 Branson et al. May 2005 A1
20050108169 Balasubramanian et al. May 2005 A1
20050108262 Fawcett May 2005 A1
20050108529 Juneau May 2005 A1
20050114296 Farber et al. May 2005 A1
20050117717 Lumsden Jun 2005 A1
20050132083 Raciborski et al. Jun 2005 A1
20050147088 Bao et al. Jul 2005 A1
20050157712 Rangarajan et al. Jul 2005 A1
20050160133 Greenlee et al. Jul 2005 A1
20050163168 Sheth et al. Jul 2005 A1
20050168782 Kobashi et al. Aug 2005 A1
20050171959 Deforche et al. Aug 2005 A1
20050181769 Kogawa Aug 2005 A1
20050188073 Nakamichi et al. Aug 2005 A1
20050192008 Desai et al. Sep 2005 A1
20050198170 LeMay et al. Sep 2005 A1
20050198334 Farber et al. Sep 2005 A1
20050198571 Kramer et al. Sep 2005 A1
20050216483 Armstrong et al. Sep 2005 A1
20050216569 Coppola et al. Sep 2005 A1
20050216674 Robbin et al. Sep 2005 A1
20050223095 Volz et al. Oct 2005 A1
20050228856 Swildens et al. Oct 2005 A1
20050229119 Torvinen Oct 2005 A1
20050232165 Brawn et al. Oct 2005 A1
20050234864 Shapiro Oct 2005 A1
20050240574 Challenger et al. Oct 2005 A1
20050256880 Nam Koong et al. Nov 2005 A1
20050259645 Chen et al. Nov 2005 A1
20050259672 Eduri Nov 2005 A1
20050262248 Jennings, III et al. Nov 2005 A1
20050266835 Agrawal et al. Dec 2005 A1
20050267937 Daniels et al. Dec 2005 A1
20050267991 Huitema et al. Dec 2005 A1
20050267992 Huitema et al. Dec 2005 A1
20050267993 Huitema et al. Dec 2005 A1
20050278259 Gunaseelan et al. Dec 2005 A1
20050283759 Peteanu et al. Dec 2005 A1
20050283784 Suzuki Dec 2005 A1
20060013158 Ahuja et al. Jan 2006 A1
20060020596 Liu et al. Jan 2006 A1
20060020684 Mukherjee et al. Jan 2006 A1
20060020714 Girouard et al. Jan 2006 A1
20060020715 Jungck Jan 2006 A1
20060021001 Giles et al. Jan 2006 A1
20060026067 Nicholas et al. Feb 2006 A1
20060026154 Altinel et al. Feb 2006 A1
20060031239 Koenig Feb 2006 A1
20060031319 Nelson et al. Feb 2006 A1
20060031503 Gilbert Feb 2006 A1
20060034494 Holloran Feb 2006 A1
20060036720 Faulk, Jr. Feb 2006 A1
20060036966 Yevdayev Feb 2006 A1
20060037037 Miranz Feb 2006 A1
20060039352 Karstens Feb 2006 A1
20060041614 Oe Feb 2006 A1
20060047787 Agarwal et al. Mar 2006 A1
20060047813 Aggarwal et al. Mar 2006 A1
20060059246 Grove Mar 2006 A1
20060063534 Kokkonen et al. Mar 2006 A1
20060064476 Decasper et al. Mar 2006 A1
20060064500 Roth et al. Mar 2006 A1
20060070060 Tantawi et al. Mar 2006 A1
20060074750 Clark et al. Apr 2006 A1
20060075084 Lyon Apr 2006 A1
20060075139 Jungck Apr 2006 A1
20060083165 McLane et al. Apr 2006 A1
20060085536 Meyer et al. Apr 2006 A1
20060088026 Mazur et al. Apr 2006 A1
20060112066 Hamzy May 2006 A1
20060112176 Liu et al. May 2006 A1
20060120385 Atchison et al. Jun 2006 A1
20060129665 Toebes et al. Jun 2006 A1
20060136453 Kwan Jun 2006 A1
20060143293 Freedman Jun 2006 A1
20060146820 Friedman et al. Jul 2006 A1
20060149529 Nguyen et al. Jul 2006 A1
20060155823 Tran et al. Jul 2006 A1
20060155862 Kathi et al. Jul 2006 A1
20060161541 Cencini Jul 2006 A1
20060165051 Banerjee et al. Jul 2006 A1
20060168088 Leighton et al. Jul 2006 A1
20060173957 Robinson Aug 2006 A1
20060179080 Meek et al. Aug 2006 A1
20060184936 Abels et al. Aug 2006 A1
20060190605 Franz et al. Aug 2006 A1
20060193247 Naseh et al. Aug 2006 A1
20060195866 Thukral Aug 2006 A1
20060206568 Verma et al. Sep 2006 A1
20060206586 Ling et al. Sep 2006 A1
20060218256 Farber et al. Sep 2006 A1
20060218304 Mukherjee et al. Sep 2006 A1
20060224752 Parekh et al. Oct 2006 A1
20060227740 McLaughlin et al. Oct 2006 A1
20060227758 Rana et al. Oct 2006 A1
20060230137 Gare et al. Oct 2006 A1
20060230265 Krishna Oct 2006 A1
20060233155 Srivastava Oct 2006 A1
20060253546 Chang et al. Nov 2006 A1
20060253609 Andreev et al. Nov 2006 A1
20060259581 Piersol Nov 2006 A1
20060259690 Vittal et al. Nov 2006 A1
20060259984 Juneau Nov 2006 A1
20060265497 Ohata et al. Nov 2006 A1
20060265508 Angel et al. Nov 2006 A1
20060265516 Schilling Nov 2006 A1
20060265720 Cai et al. Nov 2006 A1
20060271641 Stavrakos et al. Nov 2006 A1
20060282522 Lewin et al. Dec 2006 A1
20060288119 Kim et al. Dec 2006 A1
20070005689 Leighton et al. Jan 2007 A1
20070005801 Kumar et al. Jan 2007 A1
20070005892 Mullender et al. Jan 2007 A1
20070011267 Overton et al. Jan 2007 A1
20070014241 Banerjee et al. Jan 2007 A1
20070021998 Laithwaite et al. Jan 2007 A1
20070028001 Phillips et al. Feb 2007 A1
20070038729 Sullivan et al. Feb 2007 A1
20070038994 Davis et al. Feb 2007 A1
20070041393 Westhead et al. Feb 2007 A1
20070043859 Ruul Feb 2007 A1
20070050522 Grove et al. Mar 2007 A1
20070050703 Lebel Mar 2007 A1
20070055764 Dilley et al. Mar 2007 A1
20070061440 Sundaram et al. Mar 2007 A1
20070064610 Khandani Mar 2007 A1
20070076872 Juneau Apr 2007 A1
20070086429 Lawrence et al. Apr 2007 A1
20070094361 Hoynowski et al. Apr 2007 A1
20070101061 Baskaran et al. May 2007 A1
20070101377 Six et al. May 2007 A1
20070118667 McCarthy et al. May 2007 A1
20070118668 McCarthy et al. May 2007 A1
20070134641 Lieu Jun 2007 A1
20070156919 Potti et al. Jul 2007 A1
20070162331 Sullivan Jul 2007 A1
20070168517 Weller Jul 2007 A1
20070174426 Swildens et al. Jul 2007 A1
20070174442 Sherman et al. Jul 2007 A1
20070174490 Choi et al. Jul 2007 A1
20070183342 Wong et al. Aug 2007 A1
20070198982 Bolan et al. Aug 2007 A1
20070204107 Greenfield et al. Aug 2007 A1
20070208737 Li et al. Sep 2007 A1
20070219795 Park et al. Sep 2007 A1
20070220010 Ertugrul Sep 2007 A1
20070233705 Farber et al. Oct 2007 A1
20070233706 Farber et al. Oct 2007 A1
20070233846 Farber et al. Oct 2007 A1
20070233884 Farber et al. Oct 2007 A1
20070243860 Aiello et al. Oct 2007 A1
20070244964 Challenger et al. Oct 2007 A1
20070245022 Olliphant et al. Oct 2007 A1
20070250467 Mesnik et al. Oct 2007 A1
20070250560 Wein et al. Oct 2007 A1
20070250601 Amlekar et al. Oct 2007 A1
20070250611 Bhogal et al. Oct 2007 A1
20070253377 Janneteau et al. Nov 2007 A1
20070255843 Zubev Nov 2007 A1
20070263604 Tai Nov 2007 A1
20070266113 Koopmans et al. Nov 2007 A1
20070266311 Westphal Nov 2007 A1
20070266333 Cossey et al. Nov 2007 A1
20070270165 Poosala Nov 2007 A1
20070271375 Hwang Nov 2007 A1
20070271385 Davis et al. Nov 2007 A1
20070271560 Wahlert et al. Nov 2007 A1
20070271608 Shimizu et al. Nov 2007 A1
20070280229 Kenney Dec 2007 A1
20070288588 Wein et al. Dec 2007 A1
20070291739 Sullivan et al. Dec 2007 A1
20080005057 Ozzie et al. Jan 2008 A1
20080008089 Bornstein et al. Jan 2008 A1
20080016233 Schneider Jan 2008 A1
20080025304 Venkataswami et al. Jan 2008 A1
20080147873 Matsumoto Jan 2008 A1
20080037536 Padmanabhan et al. Feb 2008 A1
20080046550 Mazur et al. Feb 2008 A1
20080046596 Afergan et al. Feb 2008 A1
20080056207 Eriksson et al. Mar 2008 A1
20080065724 Seed et al. Mar 2008 A1
20080065745 Leighton et al. Mar 2008 A1
20080071859 Seed et al. Mar 2008 A1
20080071987 Karn et al. Mar 2008 A1
20080072264 Crayford Mar 2008 A1
20080082551 Farber et al. Apr 2008 A1
20080082662 Dandliker et al. Apr 2008 A1
20080086434 Chesla Apr 2008 A1
20080086559 Davis et al. Apr 2008 A1
20080086574 Raciborski et al. Apr 2008 A1
20080092242 Rowley Apr 2008 A1
20080103805 Shear et al. May 2008 A1
20080104268 Farber et al. May 2008 A1
20080109679 Wright et al. May 2008 A1
20080114829 Button et al. May 2008 A1
20080125077 Velazquez et al. May 2008 A1
20080126706 Newport et al. May 2008 A1
20080134043 Georgis et al. Jun 2008 A1
20080140800 Farber et al. Jun 2008 A1
20080147866 Stolorz et al. Jun 2008 A1
20080155059 Hardin et al. Jun 2008 A1
20080155061 Afergan et al. Jun 2008 A1
20080155613 Benya et al. Jun 2008 A1
20080155614 Cooper et al. Jun 2008 A1
20080162667 Verma et al. Jul 2008 A1
20080162821 Duran et al. Jul 2008 A1
20080162843 Davis et al. Jul 2008 A1
20080172488 Jawahar et al. Jul 2008 A1
20080189437 Halley Aug 2008 A1
20080201332 Souders et al. Aug 2008 A1
20080215718 Stolorz et al. Sep 2008 A1
20080215730 Sundaram et al. Sep 2008 A1
20080215735 Farber et al. Sep 2008 A1
20080215747 Menon et al. Sep 2008 A1
20080215750 Farber et al. Sep 2008 A1
20080215755 Farber et al. Sep 2008 A1
20080222281 Dilley et al. Sep 2008 A1
20080222291 Weller et al. Sep 2008 A1
20080222295 Robinson et al. Sep 2008 A1
20080228574 Stewart et al. Sep 2008 A1
20080228920 Souders et al. Sep 2008 A1
20080235400 Slocombe et al. Sep 2008 A1
20080256175 Lee et al. Oct 2008 A1
20080263135 Olliphant Oct 2008 A1
20080275772 Suryanarayana et al. Nov 2008 A1
20080281946 Swildens et al. Nov 2008 A1
20080281950 Wald et al. Nov 2008 A1
20080288722 Lecoq et al. Nov 2008 A1
20080301670 Gouge et al. Dec 2008 A1
20080312766 Couckuyt Dec 2008 A1
20080319862 Golan et al. Dec 2008 A1
20080320123 Houlihan et al. Dec 2008 A1
20080320269 Houlihan et al. Dec 2008 A1
20090013063 Soman Jan 2009 A1
20090016236 Alcala et al. Jan 2009 A1
20090029644 Sue et al. Jan 2009 A1
20090031367 Sue Jan 2009 A1
20090031368 Ling Jan 2009 A1
20090031376 Riley et al. Jan 2009 A1
20090049098 Pickelsimer et al. Feb 2009 A1
20090063038 Shrivathsan et al. Mar 2009 A1
20090063704 Taylor et al. Mar 2009 A1
20090070533 Elazary et al. Mar 2009 A1
20090083228 Shatz et al. Mar 2009 A1
20090083279 Hasek Mar 2009 A1
20090086728 Gulati et al. Apr 2009 A1
20090086741 Zhang Apr 2009 A1
20090089869 Varghese Apr 2009 A1
20090103707 McGary et al. Apr 2009 A1
20090106381 Kasriel et al. Apr 2009 A1
20090112703 Brown Apr 2009 A1
20090125393 Hwang et al. May 2009 A1
20090125934 Jones et al. May 2009 A1
20090132368 Cotter et al. May 2009 A1
20090132648 Swildens et al. May 2009 A1
20090138533 Iwasaki et al. May 2009 A1
20090144411 Winkler et al. Jun 2009 A1
20090144412 Ferguson et al. Jun 2009 A1
20090150926 Schlack Jun 2009 A1
20090157850 Gagliardi et al. Jun 2009 A1
20090158163 Stephens et al. Jun 2009 A1
20090164331 Bishop et al. Jun 2009 A1
20090164614 Christian et al. Jun 2009 A1
20090177667 Ramos et al. Jul 2009 A1
20090182815 Czechowski et al. Jul 2009 A1
20090182837 Rogers Jul 2009 A1
20090182945 Aviles et al. Jul 2009 A1
20090187575 DaCosta Jul 2009 A1
20090198817 Sundaram et al. Aug 2009 A1
20090204682 Jeyaseelan et al. Aug 2009 A1
20090210549 Hudson et al. Aug 2009 A1
20090233623 Johnson Sep 2009 A1
20090241167 Moore Sep 2009 A1
20090248697 Richardson et al. Oct 2009 A1
20090248786 Richardson et al. Oct 2009 A1
20090248787 Sivasubramanian et al. Oct 2009 A1
20090248852 Fuhrmann et al. Oct 2009 A1
20090248858 Sivasubramanian et al. Oct 2009 A1
20090248893 Richardson et al. Oct 2009 A1
20090249222 Schmidt Oct 2009 A1
20090253435 Olofsson Oct 2009 A1
20090254661 Fullagar et al. Oct 2009 A1
20090259588 Lindsay Oct 2009 A1
20090259971 Rankine et al. Oct 2009 A1
20090262741 Jungck et al. Oct 2009 A1
20090271498 Cable Oct 2009 A1
20090271577 Campana et al. Oct 2009 A1
20090271730 Rose et al. Oct 2009 A1
20090276771 Nickolov et al. Nov 2009 A1
20090279444 Ravindran et al. Nov 2009 A1
20090282038 Subotin et al. Nov 2009 A1
20090287750 Banavar et al. Nov 2009 A1
20090307307 Igarashi Dec 2009 A1
20090327489 Swildens et al. Dec 2009 A1
20090327517 Sivasubramanian et al. Dec 2009 A1
20090327914 Adar et al. Dec 2009 A1
20100005175 Swildens et al. Jan 2010 A1
20100011061 Hudson et al. Jan 2010 A1
20100011126 Hsu et al. Jan 2010 A1
20100020699 On Jan 2010 A1
20100023601 Lewin et al. Jan 2010 A1
20100030662 Klein Feb 2010 A1
20100030914 Sparks et al. Feb 2010 A1
20100034470 Valencia-Campo et al. Feb 2010 A1
20100036944 Douglis et al. Feb 2010 A1
20100042725 Jeon et al. Feb 2010 A1
20100070603 Moss et al. Mar 2010 A1
20100082320 Wood et al. Apr 2010 A1
20100082787 Kommula et al. Apr 2010 A1
20100088367 Brown et al. Apr 2010 A1
20100088405 Huang et al. Apr 2010 A1
20100095008 Joshi Apr 2010 A1
20100100629 Raciborski et al. Apr 2010 A1
20100057894 Glasser May 2010 A1
20100111059 Bappu et al. May 2010 A1
20100115133 Joshi May 2010 A1
20100115342 Shigeta et al. May 2010 A1
20100121953 Friedman et al. May 2010 A1
20100121981 Drako May 2010 A1
20100122069 Gonion May 2010 A1
20100125626 Lucas et al. May 2010 A1
20100125673 Richardson et al. May 2010 A1
20100125675 Richardson et al. May 2010 A1
20100131646 Drako May 2010 A1
20100138559 Sullivan et al. Jun 2010 A1
20100150155 Napierala Jun 2010 A1
20100161799 Maloo Jun 2010 A1
20100169392 Lev Ran Jul 2010 A1
20100169452 Atluri et al. Jul 2010 A1
20100174811 Musiri et al. Jul 2010 A1
20100192225 Ma et al. Jul 2010 A1
20100217801 Leighton et al. Aug 2010 A1
20100217856 Falkena Aug 2010 A1
20100223364 Wei Sep 2010 A1
20100226372 Watanabe Sep 2010 A1
20100228819 Wei Sep 2010 A1
20100257024 Holmes et al. Oct 2010 A1
20100257266 Holmes et al. Oct 2010 A1
20100257566 Matila Oct 2010 A1
20100268789 Yoo et al. Oct 2010 A1
20100268814 Cross et al. Oct 2010 A1
20100274765 Murphy Oct 2010 A1
20100281482 Pike et al. Nov 2010 A1
20100293296 Hsu et al. Nov 2010 A1
20100293479 Rousso et al. Nov 2010 A1
20100299427 Joshi Nov 2010 A1
20100299438 Zimmerman et al. Nov 2010 A1
20100299439 McCarthy et al. Nov 2010 A1
20100312861 Kolhi et al. Dec 2010 A1
20100318508 Brawer et al. Dec 2010 A1
20100322255 Hao et al. Dec 2010 A1
20100325365 Colglazier et al. Dec 2010 A1
20100332595 Fullagar et al. Dec 2010 A1
20110010244 Hatridge Jan 2011 A1
20110029598 Arnold et al. Feb 2011 A1
20110040893 Karaoguz et al. Feb 2011 A1
20110055714 Vemulapalli et al. Mar 2011 A1
20110055921 Narayanaswamy et al. Mar 2011 A1
20110058675 Brueck et al. Mar 2011 A1
20110072138 Canturk et al. Mar 2011 A1
20110072366 Spencer Mar 2011 A1
20110078000 Ma et al. Mar 2011 A1
20110078230 Sepulveda Mar 2011 A1
20110085654 Jana et al. Apr 2011 A1
20110087769 Holmes et al. Apr 2011 A1
20110096987 Morales et al. Apr 2011 A1
20110113467 Agarwal et al. May 2011 A1
20110153938 Verzunov et al. Jun 2011 A1
20110153941 Spatscheck et al. Jun 2011 A1
20110154318 Oshins et al. Jun 2011 A1
20110161461 Niven-Jenkins Jun 2011 A1
20110166935 Armentrout et al. Jul 2011 A1
20110182290 Perkins Jul 2011 A1
20110191445 Dazzi Aug 2011 A1
20110191449 Swildens et al. Aug 2011 A1
20110191459 Joshi Aug 2011 A1
20110196892 Xia Aug 2011 A1
20110208876 Richardson et al. Aug 2011 A1
20110208958 Stuedi et al. Aug 2011 A1
20110209064 Jorgensen et al. Aug 2011 A1
20110219120 Farber et al. Sep 2011 A1
20110219372 Agarwal et al. Sep 2011 A1
20110238501 Almeida Sep 2011 A1
20110238793 Bedare et al. Sep 2011 A1
20110239215 Sugai Sep 2011 A1
20110252142 Richardson et al. Oct 2011 A1
20110252143 Baumback et al. Oct 2011 A1
20110258049 Ramer et al. Oct 2011 A1
20110258614 Tamm Oct 2011 A1
20110270964 Huang et al. Nov 2011 A1
20110276623 Girbal Nov 2011 A1
20110296053 Medved et al. Dec 2011 A1
20110302304 Baumback et al. Dec 2011 A1
20110320522 Endres et al. Dec 2011 A1
20110320559 Foti Dec 2011 A1
20120011190 Driesen et al. Jan 2012 A1
20120023090 Holloway et al. Jan 2012 A1
20120036238 Sundaram et al. Feb 2012 A1
20120066360 Ghosh Mar 2012 A1
20120072600 Richardson et al. Mar 2012 A1
20120078998 Son et al. Mar 2012 A1
20120079096 Cowan Mar 2012 A1
20120079115 Richardson et al. Mar 2012 A1
20120089972 Scheidel et al. Apr 2012 A1
20120096065 Suit et al. Apr 2012 A1
20120110515 Abramoff et al. May 2012 A1
20120124184 Sakata et al. May 2012 A1
20120131177 Brandt et al. May 2012 A1
20120136697 Peles et al. May 2012 A1
20120143688 Alexander Jun 2012 A1
20120159476 Ramteke et al. Jun 2012 A1
20120166516 Simmons Jun 2012 A1
20120169646 Berkes et al. Jul 2012 A1
20120173677 Richardson et al. Jul 2012 A1
20120173760 Jog et al. Jul 2012 A1
20120179817 Bade et al. Jul 2012 A1
20120179839 Raciborski et al. Jul 2012 A1
20120198043 Hesketh et al. Aug 2012 A1
20120198071 Black et al. Aug 2012 A1
20120224516 Stojanovski et al. Sep 2012 A1
20120226649 Kovacs et al. Sep 2012 A1
20120233522 Barton Sep 2012 A1
20120233668 Leafe et al. Sep 2012 A1
20120254961 Kim et al. Oct 2012 A1
20120257628 Bu et al. Oct 2012 A1
20120278831 van Coppenolle et al. Nov 2012 A1
20120303785 Sivasubramanian et al. Nov 2012 A1
20120303804 Sundaram et al. Nov 2012 A1
20120311648 Swildens et al. Dec 2012 A1
20120324089 Joshi Dec 2012 A1
20130003735 Chao et al. Jan 2013 A1
20130007100 Trahan et al. Jan 2013 A1
20130007101 Trahan et al. Jan 2013 A1
20130007102 Trahan et al. Jan 2013 A1
20130007241 Trahan et al. Jan 2013 A1
20130007273 Baumback et al. Jan 2013 A1
20130019311 Swildens et al. Jan 2013 A1
20130034099 Hikichi et al. Feb 2013 A1
20130041872 Aizman et al. Feb 2013 A1
20130046869 Jenkins et al. Feb 2013 A1
20130055374 Kustarz et al. Feb 2013 A1
20130067530 Spektor et al. Mar 2013 A1
20130080420 Taylor et al. Mar 2013 A1
20130080421 Taylor et al. Mar 2013 A1
20130080576 Taylor et al. Mar 2013 A1
20130080577 Taylor et al. Mar 2013 A1
20130086001 Bhogal Apr 2013 A1
20130117282 Mugali, Jr. et al. May 2013 A1
20130117849 Golshan et al. May 2013 A1
20130130221 Kortemeyer et al. May 2013 A1
20130133057 Yoon et al. May 2013 A1
20130151646 Chidambaram et al. Jun 2013 A1
20130198341 Kim Aug 2013 A1
20130212300 Eggleston et al. Aug 2013 A1
20130227165 Liu Aug 2013 A1
20130246567 Green et al. Sep 2013 A1
20130254269 Sivasubramanian et al. Sep 2013 A1
20130263256 Dickinson et al. Oct 2013 A1
20130268616 Sakata et al. Oct 2013 A1
20130279335 Ahmadi Oct 2013 A1
20130305046 Mankovski et al. Nov 2013 A1
20130311605 Richardson et al. Nov 2013 A1
20130311989 Ota et al. Nov 2013 A1
20130318153 Sivasubramanian et al. Nov 2013 A1
20130339429 Richardson et al. Dec 2013 A1
20130346567 Richardson et al. Dec 2013 A1
20140006577 Joe et al. Jan 2014 A1
20140007239 Sharpe et al. Jan 2014 A1
20140019605 Boberg Jan 2014 A1
20140036675 Wang et al. Feb 2014 A1
20140040478 Hsu et al. Feb 2014 A1
20140053022 Forgette et al. Feb 2014 A1
20140059120 Richardson et al. Feb 2014 A1
20140059198 Richardson et al. Feb 2014 A1
20140059379 Ren et al. Feb 2014 A1
20140075109 Richardson et al. Mar 2014 A1
20140089917 Attalla et al. Mar 2014 A1
20140108672 Ou et al. Apr 2014 A1
20140137111 Dees et al. May 2014 A1
20140143320 Sivasubramanian et al. May 2014 A1
20140164817 Bartholomy et al. Jun 2014 A1
20140165061 Greene et al. Jun 2014 A1
20140215019 Ahrens Jul 2014 A1
20140257891 Richardson et al. Sep 2014 A1
20140280679 Dey et al. Sep 2014 A1
20140297870 Eggleston et al. Oct 2014 A1
20140310402 Giaretta et al. Oct 2014 A1
20140310811 Hentunen Oct 2014 A1
20140325155 Marshall et al. Oct 2014 A1
20140331328 Wang et al. Nov 2014 A1
20140337472 Newton et al. Nov 2014 A1
20140365666 Richardson et al. Dec 2014 A1
20150006615 Wainner et al. Jan 2015 A1
20150067171 Yum Mar 2015 A1
20150081842 Richardson et al. Mar 2015 A1
20150089621 Khalid Mar 2015 A1
20150172379 Richardson et al. Jun 2015 A1
20150172407 MacCarthaigh et al. Jun 2015 A1
20150172414 Richardson et al. Jun 2015 A1
20150172415 Richardson et al. Jun 2015 A1
20150180988 Sivasubramanian et al. Jun 2015 A1
20150188734 Petrov Jul 2015 A1
20150188994 Marshall et al. Jul 2015 A1
20150189042 Sun et al. Jul 2015 A1
20150195244 Richardson et al. Jul 2015 A1
20150207733 Richardson et al. Jul 2015 A1
20150215270 Sivasubramanian et al. Jul 2015 A1
20150215656 Pulung et al. Jul 2015 A1
20150229710 Sivasubramanian et al. Aug 2015 A1
20150244580 Saavedra Aug 2015 A1
20150249579 Ellsworth et al. Sep 2015 A1
20150256647 Richardson et al. Sep 2015 A1
20150288647 Chhabra et al. Oct 2015 A1
20150319194 Richardson et al. Nov 2015 A1
20150319260 Watson Nov 2015 A1
20150334082 Richardson et al. Nov 2015 A1
20160006672 Saavedra Jan 2016 A1
20160021197 Pogrebinsky et al. Jan 2016 A1
20160026568 Marshall et al. Jan 2016 A1
20160028644 Richardson et al. Jan 2016 A1
20160028755 Vasseur et al. Jan 2016 A1
20160041910 Richardson et al. Feb 2016 A1
20160065665 Richardson et al. Mar 2016 A1
20160072720 Richardson et al. Mar 2016 A1
20160134492 Ellsworth et al. May 2016 A1
20160142367 Richardson et al. May 2016 A1
20160182454 Phonsa et al. Jun 2016 A1
20160182542 Staniford Jun 2016 A1
20160205062 Mosert Jul 2016 A1
20160241637 Marr et al. Aug 2016 A1
20160241639 Brookins et al. Aug 2016 A1
20160241651 Sivasubramanian et al. Aug 2016 A1
20160308959 Richardson et al. Oct 2016 A1
20170041428 Katsev Feb 2017 A1
20170085495 Richardson et al. Mar 2017 A1
20170126557 Richardson et al. May 2017 A1
20170126796 Hollis et al. May 2017 A1
20170142062 Richardson et al. May 2017 A1
20170180217 Puchala et al. Jun 2017 A1
20170180267 Puchala et al. Jun 2017 A1
Foreign Referenced Citations (40)
Number Date Country
2741 895 May 2010 CA
1422468 Jun 2003 CN
1511399 Jul 2004 CN
1605182 Apr 2005 CN
101189598 May 2008 CN
101460907 Jun 2009 CN
103731481 Apr 2014 CN
1603307 Dec 2005 EP
1351141 Oct 2007 EP
2008167 Dec 2008 EP
3156911 Apr 2017 EP
07-141305 Jun 1995 JP
2001-0506093 May 2001 JP
2001-249907 Sep 2001 JP
2002-024192 Jan 2002 JP
2002-044137 Feb 2002 JP
2002-323986 Nov 2002 JP
2003-167810 Jun 2003 JP
2003-167813 Jun 2003 JP
2003-522358 Jul 2003 JP
2003188901 Jul 2003 JP
2004-070935 Mar 2004 JP
2004-532471 Oct 2004 JP
2004-533738 Nov 2004 JP
2005-537687 Dec 2005 JP
2007-133896 May 2007 JP
2007-207225 Aug 2007 JP
2008-515106 May 2008 JP
2009-071538 Apr 2009 JP
2012-509623 Apr 2012 JP
2012-209623 Oct 2012 JP
WO 2002069608 Sep 2002 WO
WO 2005071560 Aug 2005 WO
WO 2007007960 Jan 2007 WO
WO 2007126837 Nov 2007 WO
WO 2009124006 Oct 2009 WO
WO 2010002603 Jan 2010 WO
WO 2012044587 Apr 2012 WO
WO 2012065641 May 2012 WO
WO 2017106455 Jun 2017 WO
Non-Patent Literature Citations (148)
Entry
“Non-Final Office Action dated Jan. 3, 2012,” U.S. Appl. No. 12/652,541, filed Jan. 3, 2012; 35 pages.
“Final Office Action dated Sep. 5, 2012,” U.S. Appl. No. 12/652,541, filed Sep. 5, 2012; 40 pages.
“Notice of Allowance dated Jan. 4, 2013,” U.S. Appl. No. 12/652,541, Jan. 4, 2013; 11 pages.
“Non-Final Office Action dated Apr. 30, 2014,” U.S. Appl. No. 13/842,970; 20 pages.
“Final Office Action dated Aug. 19, 2014,” U.S. Appl. No. 13/842,970; 13 pages.
“Notice of Allowance dated Dec. 5, 2014,” U.S. Appl. No. 13/842,970; 6 pages.
Canonical Name (CNAME) DNS Records, domainavenue.com, Feb. 1, 2001, XP055153783, Retrieved from the Internet: URL:http://www.domainavenue.com/cname.htm [retrieved on Nov. 18, 2014].
“Content delivery network”, Wikipedia, the free encyclopedia, Retrieved from the Internet: URL:http://en.wikipedia.org/w/index.php?title=Contentdelivery network&oldid=601009970, XP055153445, Mar. 24, 2008.
Gunther et al, “Measuring Round Trip Times to determine the Distance between WLAN Nodes”,May 2005, In Proc. of Networking 2005, all pages.
Hartung et al.; Digital rights management and watermarking of multimedia content for m-commerce applications; Published in: Communications Magazine, IEEE (vol. 38, Issue: 11 ); Date of Publication: Nov. 2000; pp. 78-84; IEEE Xplore.
Kalafut et al., Understanding Implications of DNS Zone Provisioning., Proceeding IMC '08 Proceedings of the 8th AMC SIGCOMM conference on Internet measurement., pp. 211-216, ACM New York, NY, USA., 2008.
Kato, Yoshinobu , Server load balancer—Difference in distribution technique and supported protocol—Focus on function to meet the needs, Nikkei Communications, Japan, Nikkei Business Publications, Inc., Mar. 20, 2000, vol. 314, pp. 114 to 123.
Mulligan et al.; How DRM-based content delivery systems disrupt expectations of “personal use”; Published in: Proceeding DRM '03 Proceedings of the 3rd ACM workshop on Digital rights management; 2003; pp. 77-89; ACM Digital Library.
Supplementary European Search Report in Application No. 09729072.0 2266064 dated Dec. 10, 2014.
First Singapore Written Opinion in Application No. 201006836-9, dated Oct. 12, 2011 in 12 pages.
Singapore Written Opinion in Application No. 201006836-9, dated Apr. 30, 2012 in 10 pages.
First Office Action in Chinese Application No. 200980111422.3 dated Apr. 13, 2012.
First Office Action in Japanese Application No. 2011-502138 dated Feb. 1, 2013.
Singapore Written Opinion in Application No. 201006837-7, dated Oct. 12, 2011 in 11 pages.
Supplementary European Search Report in Application No. 09727694.3 dated Jan. 30, 2012 in 6 pages.
Singapore Examination Report in Application No. 201006837-7 dated Mar. 16, 2012.
First Office Action in Chinese Application No. 200980111426.1 dated Feb. 16, 2013.
Second Office Action in Chinese Application No. 200980111426.1 dated Dec. 25, 2013.
Third Office Action in Chinese Application No. 200980111426.1 dated Jul. 7, 2014.
Fourth Office Action in Chinese Application No. 200980111426.1 dated Jan. 15, 2015.
First Office Action in Japanese Application No. 2011-502139 dated Nov. 5, 2013.
Decision of Rejection in Application No. 2011-502139 dated Jun. 30, 2014.
Singapore Written Opinion in Application No. 201006874-0, dated Oct. 12, 2011 in 10 pages.
First Office Action in Japanese Application No. 2011-502140 dated Dec. 7, 2012.
First Office Action in Chinese Application No. 200980119995.0 dated Jul. 6, 2012.
Second Office Action in Chinese Application No. 200980119995.0 dated Apr. 15, 2013.
Examination Report in Singapore Application No. 201006874-0 dated May 16, 2012.
Search Report for European Application No. 09839809.2 dated May 11, 2015.
Supplementary European Search Report in Application No. 09728756.9 dated Jan. 8, 2013.
First Office Action in Chinese Application No. 200980119993.1 dated Jul. 4, 2012.
Second Office Action in Chinese Application No. 200980119993.1 dated Mar. 12, 2013.
Third Office Action in Chinese Application No. 200980119993.1 dated Oct. 21, 2013.
First Office Action in Japanese Application No. 2011-503091 dated Nov. 18, 2013.
Search Report and Written Opinion issued in Singapore Application No. 201006873-2 dated Oct. 12, 2011.
First Office Action is Chinese Application No. 200980125551.8 dated Jul. 4, 2012.
First Office Action in Japanese Application No. 2011-516466 dated Mar. 6, 2013.
Second Office Action in Japanese Application No. 2011-516466 dated Mar. 17, 2014.
Decision of Refusal in Japanese Application No. 2011-516466 dated Jan. 16, 2015.
Office Action in Canadian Application No. 2726915 dated May 13, 2013.
First Office Action in Korean Application No. 10-2011-7002461 dated May 29, 2013.
First Office Action in Chinese Application No. 200980145872.4 dated Nov. 29, 2012.
First Office Action in Canadian Application No. 2741895 dated Feb. 25, 2013.
Second Office Action in Canadian Application No. 2741895 dated Oct. 21, 2013.
Search Report and Written Opinion in Singapore Application No. 201103333-9 dated Nov. 19, 2012.
Examination Report in Singapore Application No. 201103333-9 dated Aug. 13, 2013.
First Office Action in Japanese Application No. 2013-529454 dated Feb. 3, 2014 in 6 pages.
Office Action in Japanese Application No. 2013-529454 dated Mar. 9, 2015 in 8 pages.
First Office Action issued in Australian Application No. 2011307319 dated Mar. 6, 2014 in 5 pages.
Search Report and Written Opinion in Singapore Application No. 201301573-0 dated Jul. 1, 2014.
First Office Action in Chinese Application No. 201180046104.0 dated Nov. 3, 2014.
Examination Report in Singapore Application No. 201301573-0 dated Dec. 22, 2014.
First Office Action in Chinese Application No. 201180053405.6 dated May 3, 2015.
Office Action in Japanese Application No. 2013-540982 dated Jun. 2, 2014.
Written Opinion in Singapore Application No. 201303521-7 dated May 20, 2014.
Supplementary European Search Report in Application No. 07754164.7 dated Dec. 20, 2010 in 7 pages.
Office Action in Chinese Application No. 200780020255.2 dated Mar. 4, 2013.
Office Action in Indian Application No. 3742/KOLNP/2008 dated Nov. 22, 2013.
Office Action in Japanese Application No. 2012-052264 dated Dec. 11, 2012 in 26 pages.
Office Action in Japanese Application No. 2013-123086 dated Apr. 15, 2014 in 3 pages.
Office Action in Japanese Application No. 2013-123086 dated Dec. 2, 2014 in 2 pages.
Armour et al.: “A Heuristic Algorithm and Simulation Approach to Relative Location of Facilities”; Management Science, vol. 9, No. 2 (Jan. 1963); pp. 294-309.
Horvath et al., “Enhancing Energy Efficiency in Multi-tier Web Server Clusters via Prioritization,” in Parallel and Distributed Processing Symposium, 2007. IPDPS 2007. IEEE International , vol., no., pp. 1-6, Mar. 26-30, 2007.
Meng et al., “Improving the Scalability of Data Center Networks with Traffic-Aware Virtual Machine Placement”; Proceedings of the 29th Conference on Information Communications, INFOCOM'10, pp. 1154-1162. Piscataway, NJ. IEEE Press, 2010.
Fifth Office Action in Chinese Application No. 200980111426.1 dated Aug. 14, 2015.
Office Action in Japanese Application No. 2014-225580 dated Oct. 26, 2015.
Second Office Action in Chinese Application No. 201180046104.0 dated Sep. 29, 2015.
Office Action in Canadian Application No. 2816612 dated Nov. 3, 2015.
“Global Server Load Balancing with ServerIron,” Foundry Networks, retrieved Aug. 30, 2007, from http://www.foundrynet.com/pdf/an-global-server-load-bal.pdf, 7 pages.
“Grid Computing Solutions,” Sun Microsystems, Inc., retrieved May 3, 2006, from http://www.sun.com/software/grid, 3 pages.
“Grid Offerings,” Java.net, retrieved May 3, 2006, from http://wiki.java.net/bin/view/Sungrid/OtherGridOfferings, 8 pages.
“Recent Advances Boost System Virtualization,” eWeek.com, retrieved from May 3, 2006, http://www.eWeek.com/article2/0,1895,1772626,00.asp, 5 pages.
“Scaleable Trust of Next Generation Management (STRONGMAN),” retrieved May 17, 2006, from http://www.cis.upenn.edu/˜dsl/STRONGMAN/, 4 pages.
“Sun EDA Compute Ranch,” Sun Microsystems, Inc., retrieved May 3, 2006, from http://sun.com/processors/ranch/brochure.pdf, 2 pages.
“Sun Microsystems Accelerates UltraSP ARC Processor Design Program With New Burlington, Mass. Compute Ranch,” Nov. 6, 2002, Sun Microsystems, Inc., retrieved May 3, 2006, from http://www.sun.com/smi/Press/sunflash/2002-11/sunflash.20021106.3 .xml, 2 pages.
“Sun N1 Grid Engine 6,” Sun Microsystems, Inc., retrieved May 3, 2006, from http://www.sun.com/software/gridware/index.xml, 3 pages.
“Sun Opens New Processor Design Compute Ranch,” Nov. 30, 2001, Sun Microsystems, Inc., retrieved May 3, 2006, from http://www.sun.com/smi/Press/sunflash/2001-11/sunflash.20011130.1.xml, 3 pages.
“The Softricity Desktop,” Softricity, Inc., retrieved May 3, 2006, from http://www.softricity.com/products/, 3 pages.
“Xen—The Xen virtual Machine Monitor,” University of Cambridge Computer Laboratory, retrieved Nov. 8, 2005, from http://www.cl.cam.ac.uk/Research/SRG/netos/xen/, 2 pages.
“XenFaq,” retrieved Nov. 8, 2005, from http://wiki.xensource.com/xenwiki/XenFaq?action=print, 9 pages.
Abi, Issam, et al., “A Business Driven Management Framework for Utility Computing Environments,” Oct. 12, 2004, HP Laboratories Bristol, HPL-2004-171, retrieved Aug. 30, 2007, from http://www.hpl.hp.com/techreports/2004/HPL-2004-171.pdf, 14 pages.
American Bar Association; Digital Signature Guidelines Tutorial [online]; Feb. 10, 2002 [retrieved on Mar. 2, 2010]; American Bar Association Section of Science and Technology Information Security Committee; Retrieved from the internet: (URL: http://web.archive.org/web/20020210124615/www.abanet.org/scitech/ec/isc/dsg-tutorial.html; pp. 1-8.
Baglioni et al., “Preprocessing and Mining Web Log Data for Web Personalization”, LNAI 2829, 2003, pp. 237-249.
Barbir, A., et al., “Known Content Network (CN) Request-Routing Mechanisms”, Request for Comments 3568, [online], IETF, Jul. 2003, [retrieved on Feb. 26, 2013], Retrieved from the Internet: (URL: http://tools.ietf.org/rfc/rfc3568.txt).
Bellovin, S., “Distributed Firewalls,” ;login;:37-39, Nov. 1999, http://www.cs.columbia.edu/-smb/papers/distfw. html, 10 pages, retrieved Nov. 11, 2005.
Blaze, M., “Using the KeyNote Trust Management System,” Mar. 1, 2001, from http://www.crypto.com/trustmgt/kn.html, 4 pages, retrieved May 17, 2006.
Brenton, C., “What is Egress Filtering and How Can I Implement it? —Egress Filtering v 0.2,” Feb. 29, 2000, SANS Institute, http://www.sans.org/infosecFAQ/firewall/egress.htm, 6 pages.
Byun et al., “A Dynamic Grid Services Deployment Mechanism for On-Demand Resource Provisioning”, IEEE International Symposium on Cluster Computing and the Grid:863-870, 2005.
Chipara et al, “Realtime Power-Aware Routing in Sensor Network”, IEEE, 2006, 10 pages.
Clark, C., “Live Migration of Virtual Machines,” May 2005, NSDI '05: 2nd Symposium on Networked Systems Design and Implementation, Boston, MA, May 2-4, 2005, retrieved from http://www.usenix.org/events/nsdi05/tech/full_papers/clark/clark.pdf, 14 pages.
Coulson, D., “Network Security Iptables,” Apr. 2003, Linuxpro, Part 2, retrieved from http://davidcoulson.net/writing/lxf/38/iptables.pdf, 4 pages.
Coulson, D., “Network Security Iptables,” Mar. 2003, Linuxpro, Part 1, retrieved from http://davidcoulson.net/writing/lxf/39/iptables.pdf, 4 pages.
Deleuze, C., et al., A DNS Based Mapping Peering System for Peering CDNs, draft-deleuze-cdnp-dnsmap-peer-00.txt, Nov. 20, 2000, 20 pages.
Demers, A., “Epidemic Algorithms for Replicated Datavase Maintenance,” 1987, Proceedings of the sixth annual ACM Symposium on Principles of Distributed Computing, Vancouver, British Columbia, Canada, Aug. 10-12, 1987, 12 pages.
Gruener, J., “A Vision of Togetherness,” May 24, 2004, NetworkWorld, retrieved May 3, 2006, from, http://www.networkworld.com/supp/2004/ndc3/0524virt.html, 9 pages.
Gunther et al, “Measuring Round Trip Times to determine the Distance between WLAN Nodes”, Dec. 18, 2004, Technical University Berlin, all pages.
International Preliminary Report on Patentability in PCT/US2007/007601 dated Sep. 30, 2008 in 8 pages.
International Preliminary Report on Patentability in PCT/US2011/053302 dated Apr. 2, 2013.
International Preliminary Report on Patentability in PCT/US2011/061486 dated May 22, 2013.
International Search Report and Written Opinion in PCT/US07/07601 dated Jul. 18, 2008 in 11 pages.
International Search Report and Written Opinion in PCT/US2011/053302 dated Nov. 28, 2011 in 11 pages.
International Search Report and Written Opinion in PCT/US2011/061486 dated Mar. 30, 2012 in 11 pages.
Ioannidis, S., et al., “Implementing a Distributed Firewall,” Nov. 2000, (ACM) Proceedings of the ACM Computer and Communications Security (CCS) 2000, Athens, Greece, pp. 190-199, retrieved from http://www.cis.upenn.edu/˜dls/STRONGMAN/Papers/df.pdf, 10 pages.
Joseph, Joshy, et al., “Introduction to Grid Computing,” Apr. 16, 2004, retrieved Aug. 30, 2007, from http://www.informit.com/articles/printerfriendly.aspx?p=169508, 19 pages.
Kenshi, P., “Help File Library: Iptables Basics,” Justlinux, retrieved Dec. 1, 2005, from http://www.justlinux.com/nhf/Security/Iptables_Basics.html, 4 pages.
Liu et al., “Combined mining of Web server logs and web contents for classifying user navigation patterns and predicting users' future requests,” Data & Knowledge Engineering 61 (2007) pp. 304-330.
Maesono, et al., “A Local Scheduling Method considering Data Transfer in Data Grid,” Technical Report of IEICE, vol. 104, No. 692, pp. 435-440, The Institute of Electronics, Information and Communication Engineers, Japan, Feb. 2005.
Shankland, S., “Sun to buy start-up to bolster N1 ,” Jul. 30, 2003, CNet News.com, retrieved May 3, 2006, http://news.zdnet.com/2100-3513_22-5057752.html, 8 pages.
Strand, L., “Adaptive distributed firewall using intrusion detection,” Nov. 1, 2004, University of Oslo Department of Informatics, retrieved Mar. 8, 2006, from http://gnist.org/˜lars/studies/master/StrandLars-master.pdf, 158 pages.
Takizawa, et al., “Scalable MultiReplication Framework on the Grid,” Report of Study of Information Processing Society of Japan, Information Processing Society, vol. 2004, No. 81, pp. 247-252, Japan, Aug. 1, 2004.
Tan et al., “Classification: Basic Concepts, Decision Tree, and Model Evaluation”, Introduction in Data Mining; http://www-users.cs.umn.edu/˜kumar/dmbook/ch4.pdf, 2005, pp. 245-205.
Van Renesse, R., “Astrolabe: A Robust and Scalable Technology for Distributed System Monitoring, Management, and Data Mining,” May 2003, ACM Transactions on Computer Systems (TOCS), 21 (2): 164-206, 43 pages.
Vijayan, J., “Terraspring Gives Sun's N1 a Boost,” Nov. 25, 2002, Computerworld, retrieved May 3, 2003, from http://www.computerworld.com/printthis/2002/0,4814, 76159,00.html, 3 pages.
Virtual Iron Software Home, Virtual Iron, retrieved May 3, 2006, from http://www.virtualiron.com/, 1 page.
Waldspurger, CA., “Spawn: A Distributed Computational Economy,” Feb. 1992, IEEE Transactions on Software Engineering, 18(2): 103-117, I5 pages.
Watanabe, et al., “Remote Program Shipping System for GridRPC Systems,” Report of Study of Information Processing Society of Japan, Information Processing Society, vol. 2003, No. 102, pp. 73-78, Japan, Oct. 16, 2003.
Xu et al., “Decision tree regression for soft classification of remote sensing data”, Remote Sensing of Environment 97 (2005) pp. 322-336.
Yamagata, et al., “A virtual-machine based fast deployment tool for Grid execution environment,” Report of Study of Information Processing Society of Japan, Information Processing Society, vol. 2006, No. 20, pp. 127-132, Japan, Feb. 28, 2006.
Zhu, Xiaoyun, et al., “Utility-Driven Workload Management Using Nested Control Design,” Mar, 29, 2006, HP Laboratories Palo Alto, HPL-2005-193(R.1), retrieved Aug. 30, 2007, from http://www.hpl.hp/com/techreports/2005/HPL-2005-193R1.pdf, 9 pages.
Guo, F., Understanding Memory Resource Management in Vmware vSphere 5.0, Vmware, 2011, pp. 1-29.
Hameed, CC, “Disk Fragmentation and System Performance”, Mar. 14, 2008, 3 pages.
Liu, “The Ultimate Guide to Preventing DNS-based DDoS Attacks”, Retrieved from http://www.infoworld.com/article/2612835/security/the-ultimate-guide-to-preventing-dns-based-ddos-attacks.html, Published Oct. 30, 2013.
Ragan, “Three Types of DNS Attacks and How to Deal with Them”, Retrieved from http://www.csoonline.com/article/2133916/malware-cybercrime/three-types-of-dns-attacks-and-how-to-deal-with-them.html, Published Aug. 28, 2013.
Office Action in European Application No. 09839809.2 dated Dec. 8, 2016.
Office Action in European Application No. 11767118.0 dated Feb. 3, 2017.
Supplementary Examination Report in Singapore Application No. 11201501987U dated May 17, 2017.
International Search Report and Written Opinion in PCT/US/2016/066848 dated May 1, 2017.
Sharif et al, “Secure In-VM Monitoring Using Hardware Virtualization”, Microsoft, Oct. 2009 http://research.microsoft.com/pubs/153179/sim-ccs09.pdf; 11 pages.
Office Action in Japanese Application No. 2011-502139 dated Aug. 17, 2015.
Office Action in Japanese Application No. 2014-225580 dated Oct. 3, 2016.
Office Action in Japanese Application No. 2011-516466 dated May 30, 2016.
Partial Supplementary Search Report in European Application No. 09826977.2 dated Oct. 4, 2016.
Office Action in Chinese Application No. 201310717573.1 dated Jul. 29, 2016.
Third Office Action in Chinese Application No. 201180046104.0 dated Apr. 14, 2016.
Decision of Rejection in Chinese Application No. 201180046104.0 dated Oct. 17, 2016.
Office Action in Canadian Application No. 2816612 dated Oct. 7, 2016.
Second Office Action in Chinese Application No. 201180053405.6 dated Dec. 4, 2015.
Office Action in Japanese Application No. 2015-533132 dated Apr. 25, 2016.
Office Action in Canadian Application No. 2884796 dated Apr. 28, 2016.
Office Action in Russian Application No. 2015114568 dated May 16, 2016.
Office Action in Japanese Application No. 2015-075644 dated Apr. 5, 2016.
Office Action in European Application No. 07754164.7 dated Dec. 14, 2015.
Office Action in Chinese Application No. 201310537815.9 dated Jul. 5, 2016.
Office Action in Chinese Application No. 201310537815.9 dated Jun. 2, 2017.