The present disclosure relates generally to computer networks, and, more particularly, to cloud computing concepts and home/user networks.
As users grow and mature in their Internet knowledge and experience, they begin to realize that any given home network can be part of “the cloud”. Current thinking and positioning of “the cloud”, however, is that it is something “out there, outside the home”. If so, then one person's home network is part of another person's “cloud” and vice versa. In actuality, all home networks should be part of the cloud.
The embodiments herein may be better understood by referring to the following description in conjunction with the accompanying drawings in which like reference numerals indicate identically or functionally similar elements, of which:
According to one or more embodiments of the disclosure, a first interface of a switch interconnects with a broadband modem within a wide area network (WAN), while a second interface of the switch interconnects with a WAN interface of a router, where the router provides a gateway between the WAN and a local area network (LAN). Additionally, a web server is provided at the switch, where the web server is reachable to the WAN on the first interface and to the LAN on the second interface. The switch may then inspect traffic received at the first and second interfaces, and determines, based on inspecting, whether to transparently forward the traffic between the first and second interfaces or to redirect the traffic to the web server. In this manner, as one example example, a home network (LAN) may establish presence on the Public Internet (WAN), allowing secure access to personal home-based content from anywhere via the in-home web server representing the home network on the Internet.
A computer network is a geographically distributed collection of nodes interconnected by communication links and segments for transporting data (e.g., voice, video, and/or data) between end nodes, such as personal computers and workstations, or other devices, such as sensors, etc. Many types of networks are available, ranging from Local Area Networks (LANs) to Wide Area Networks (WANs). LANs typically connect the nodes over dedicated private communications links located in the same general physical location, such as a building or campus. WANs, on the other hand, typically connect geographically dispersed nodes over long-distance communications links, such as common carrier telephone lines, optical lightpaths, Synchronous Optical Networks (SONET), Synchronous Digital Hierarchy (SDH) links, etc.
Note that the links between the devices may generally be wired or wireless. Data packets (or frames) 150 may be exchanged among the devices of the computer network 100 over the links using predefined network communication protocols such as certain known wired protocols, wireless protocols, or other protocols where appropriate. In this context, a protocol consists of a set of rules defining how the nodes interact with each other. In general, the connections to/from and between the networks may comprise IPv4 and/or IPv6 (or one or more translations between the two), without being specifically distinguished herein. Those skilled in the art will understand that any number of nodes, devices, links, etc. may be used in the computer network, and that the view shown herein is for simplicity. Also, those skilled in the art will further understand that while the network is shown using a certain device naming convention, the network 100 and the device names are merely an example illustration that is not meant to limit the disclosure.
According to the techniques herein, a device 200 may be placed within network 100 that physically resides between a router 130 and a broadband modem 120. Although generally intended to be placed physically within the local network's location (e.g., within the user's home), the device logically resides on the WAN side of the router, and is thus reachable on the public Internet from both inside the LAN (e.g., home/internal) users and also by outside the LAN (e.g., WAN/external) users (i.e., is on both the public and private “side” of the network). Essentially, this device 200 is physically connected serially between Ethernet links 125a and 125b, but as described below, it may be more accurately understood as being logically in parallel to the router. In particular, as described herein, device 200 comprises an in-home web server that enables a local/home network to quickly and easily establish presence on the Public Internet (e.g., especially an IPv6 Internet), allowing secure access to local (e.g., personal home-based) content from anywhere, without requiring firewall configurations or special service subscriptions. In addition, the device may also represent the public Internet (e.g., Cloud functions) locally in the home, such as a caching server/service. Thus, instead of promoting a “centralized” cloud paradigm, the device 200 in accordance with the techniques herein promotes a “distributed” cloud paradigm that complements the “centralized” functionality (i.e., instead of the cloud being “out there”, the cloud is “everywhere”).
In addition, the device 200 may generally comprise a switch 250 between the first and second interfaces, which may be controlled by at least one processor 220 comprising hardware elements or logic elements adapted to execute software programs and manipulate data structures stored within a storage location 240 or other memory. For example, as shown, a web server process (or module) 260 (reachable to the WAN on the first interface 210 and to the LAN on the second interface 212) may be provided as a separate process/function from the switching capabilities of switch 250, though each of the web server and switch may be processes stored within the same memory on the device, and executed by the process 220. It will be apparent to those skilled in the art that other processor and memory types, including various computer-readable media, may be used to store and execute program instructions pertaining to the techniques described herein. Also, while the description illustrates various processes, it is expressly contemplated that various processes may be embodied as modules configured to operate in accordance with the techniques herein (e.g., according to the functionality of a similar process).
Note that the provided storage 240, particularly with regard to storage associated with the web server accessible to the WAN and the LAN (e.g., files, data, etc.) may be included internally within the device (internal storage), or connected externally, such as local external storage 245 via a port 217 (e.g., a universal serial bus (USB) port), or else virtually connected via the WAN to traditional cloud-based storage (WAN-based external storage).
Operationally, the device 200 is an independent device on the Internet where each packet and/or TCP session received at the device on either the first or second interface is inspected, such that a decision may be made (determining per-packet or per-session, respectively) whether to transparently forward the packet between the first and second interfaces or redirect it to an internal server or service, e.g., web server 260. That is, downstream (inbound Internet) traffic destined for inside the local network (e.g., home) is transparently bridged via the switch 250 in the device 200 and goes to the local router 130, while upstream (outbound Internet) traffic destined for outside the local network is also transparently bridged from the router through the device 200. This is shown as flow “a” in
Illustratively, the device 200 allows each local network 140 (e.g., home) to become a publicly accessible (yet protected) network, like a micro-autonomous-system, where local storage and/or resources are made publicly available, and vice versa, where public storage and/or resources (e.g., cloud functions) are made locally available (e.g., for a caching server/service). Essentially, the device 200 appears as a web server both to the public Internet (users outside the local network/home), and to users inside the local network/home.
The following use cases illustrate various features and functionality of the device 200 according to one or more embodiments herein.
Notably, as an example of how the functionality of the device 200 herein may be viewed by users, consider this comparison: typing “AliceCloud” into a browser while on Alice's home network will resolve locally (within the network) to the internal web servers of Alice's device 200. If not on the local network (e.g., while traveling), typing “AliceCloud” will be redirected to Alice's device 200 from the WAN.
It is important to note that the device 200 may be attached directly to the local network via the internal switch 250, such as via connecting a third interface 215 (logically isolated from the first and second interfaces 210 and 212) to one of the LAN side ports/interfaces 132 in the local router 130, as shown in
According to one or more embodiments herein, the broadband modem 120 may be integrated with device 200 (i.e., physically collocating the device 200/switch 250 with the modem 120) as shown in
Upon receipt of traffic on either interface 210/215 of the device 200, the switch 250 (e.g., processor 220) may inspect the received traffic in step 730 to determine, in step 735 based on the inspection, whether to transparently forward the traffic between the first and second interfaces or to redirect the traffic to the web server, as described in detail above. As such, in step 740, the switch/device may forward or redirect the traffic to the appropriate destination, accordingly. The procedure 700 may then return to step 730 to receive additional traffic. Alternatively, the procedure may also return to step 725 to receive additional configuration, or else to step 720 to maintain synchronization of files between servers.
It should be noted that while certain steps within procedure 700 may be optional as described above, the steps shown in
The techniques described herein, therefore, provide Internet presence for a home network. In particular, the techniques herein provide a virtual solution that changes the view of an average Internet user that the “cloud” is something “out there” but rather that is “everywhere”. That is, the techniques abstract and virtualize symmetrically, e.g., bringing the home (storage) closer to the Internet, and bringing the Internet (cloud) closer to the home network and devices therein, in a manner that is generally transparent to the user. Furthermore, the techniques herein offer advantages over cloud storage, since local storage is more efficient in terms of bandwidth, and also over traditional local storage (network attached storage, “NAS”), since access from anywhere is simplified without port forwarding and firewall issues generally associated with configuring traditional local storage, as may be appreciated by those skilled in the art. Note that the techniques herein are particularly useful to home networks that do not have IPv6 routers and IPv6 NAS.
While there have been shown and described illustrative embodiments that provide Internet presence for a home network, it is to be understood that various other adaptations and modifications may be made within the spirit and scope of the embodiments herein. For example, the embodiments have been shown and described herein with relation to current network technologies, such as IPv6, broadband, etc. However, the embodiments in their broader sense are not as limited, and may, in fact, be used with other types of network and/or communication protocols. For example, while the device 200 may generally be applicable as an IPv6 device, it may be configured to operate within the bounds of IPv4 network protocols.
The foregoing description has been directed to specific embodiments. It will be apparent, however, that other variations and modifications may be made to the described embodiments, with the attainment of some or all of their advantages. For instance, it is expressly contemplated that the components and/or elements described herein can be implemented as software being stored on a tangible (non-transitory) computer-readable medium (e.g., disks/CDs/RAM/EEPROM/etc.) having program instructions executing on a computer, hardware, firmware, or a combination thereof. Accordingly this description is to be taken only by way of example and not to otherwise limit the scope of the embodiments herein. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the embodiments herein.
Number | Name | Date | Kind |
---|---|---|---|
6035105 | McCloghrie et al. | Mar 2000 | A |
6701378 | Gilhuly et al. | Mar 2004 | B1 |
6850980 | Gourlay | Feb 2005 | B1 |
6917626 | Duvvury | Jul 2005 | B1 |
7251681 | Gourlay | Jul 2007 | B1 |
7257634 | Colby et al. | Aug 2007 | B2 |
7554997 | Schlichter et al. | Jun 2009 | B1 |
7646772 | Sivabalan et al. | Jan 2010 | B2 |
7719959 | Shah et al. | May 2010 | B2 |
8214744 | Frank et al. | Jul 2012 | B1 |
20020010818 | Wei et al. | Jan 2002 | A1 |
20040015940 | Heisey et al. | Jan 2004 | A1 |
20040205251 | Wiles et al. | Oct 2004 | A1 |
20050021839 | Russell et al. | Jan 2005 | A1 |
20050107985 | Agrawal et al. | May 2005 | A1 |
20050108428 | Cornet et al. | May 2005 | A1 |
20050188055 | Saletore | Aug 2005 | A1 |
20060164978 | Werner et al. | Jul 2006 | A1 |
20060270448 | Huotari et al. | Nov 2006 | A1 |
20070022185 | Hamilton et al. | Jan 2007 | A1 |
20070214083 | Jones et al. | Sep 2007 | A1 |
20080069121 | Adamson et al. | Mar 2008 | A1 |
20080082662 | Dandliker et al. | Apr 2008 | A1 |
20080155083 | Pichetti et al. | Jun 2008 | A1 |
20090034509 | Krapp et al. | Feb 2009 | A1 |
20090122787 | Huotari et al. | May 2009 | A1 |
20100115415 | Hickey | May 2010 | A1 |
20100205152 | Ansari et al. | Aug 2010 | A1 |
20110299538 | Maruta | Dec 2011 | A1 |
20120166628 | Kullos | Jun 2012 | A1 |
20120172071 | Arcidiacono et al. | Jul 2012 | A1 |
20120269059 | Gupta et al. | Oct 2012 | A1 |
20130232251 | Pauley | Sep 2013 | A1 |
Number | Date | Country | |
---|---|---|---|
20140071849 A1 | Mar 2014 | US |