- Content-centric networking
-
Content-centric networking (also content-based networking, data-oriented networking[1] or named data networking[2]) is an alternative approach to the architecture of computer networks. Its founding principle is that a communication network should allow a user to focus on the data he or she needs, rather than having to reference a specific, physical location where that data is to be retrieved from. This stems from the fact that the vast majority of current Internet usage (a "high 90% level of traffic"[3]) consists of data being disseminated from a source to a number of users.
The contemporary Internet architecture revolves around a host-based conversation model, created in the 1970s to allow geographically distributed users to use a few big, immobile computers.[4] The content-centric networking seeks to adapt the network architecture to current network usage patterns.
Content-centric networking comes with potential for a wide range of benefits such as content caching to reduce congestion and improve delivery speed, simpler configuration of network devices, and building security into the network at the data level. However, the change of communication paradigm may pose problems for certain types of network activities, for instance for real-time multimedia applications, but recent research indicates these applications are feasible.[1][2]
Application-layer designs have also been proposed for deploying a content-centric interface. This has benefits such as easier deployment, backwards compatibility and more flexible delivery support. The Juno middleware offers applications a content-centric request/reply interface that can be utilised alongside existing content providers [5] [6]. Juno also introduces the concept of a delivery-centric interface, which extends the traditional content-centric interface [7] to allow applications to stipulate multiple diverse delivery requirements that place certain constraints on how the content should be provided. For instance, these constraints can deal with such things as performance, resilience, security, monetary cost and anonymity. Through such an interface, applications can shape how the underlying delivery is performed without needing to handle such concerns themselves.
Contents
History
The philosophy behind content-centric networks was pioneered by Ted Nelson[8] in 1979 and later by Brent Baccala[9] in 2002. In 1999, the TRIAD project at Stanford[10] proposed avoiding DNS lookups by using the name of an object to route towards a close replica of it. In 2006, the DONA project at UC Berkeley and ICSI proposed a content-centric network architecture, which improved TRIAD by incorporating security (authenticity) and persistence as first-class primitives in the architecture. In 2009, PARC announced their content-centric architecture within the CCNx project, which is led by Van Jacobson, a research fellow at PARC. On September 21, 2009, PARC published the specifications for interoperability and released an initial open source implementation (under GPL) of the Content Centric Networking research project on the Project CCNx site.
How it works
The existing Internet is a tree of physical equipment to connect streams of packets from any leaf, to any leaf. It is efficient for communication, but not for distribution. The general proposal of content-centric networking recognizes that a great deal of information is produced once, then copied many times. Therefore, it makes sense to distribute the copying and any related activities into the network's tree of equipment. In many cases, substantial storage is already available, and could be used more efficiently if it could recognize particular content and only keep one copy of it. Since the network equipment is tree-shaped, it naturally scales content delivery to the size of the audience, and simultaneously reduces up-stream equipment to just the minimum needed to produce the content. As network service is built out, the content delivery naturally increases at the same time.[11]
Content-centric networking uses a practical data storage cache at each level of the network to dramatically decrease the transmission traffic, and also increase the speed of response. The cache envisioned by CCN is a packet-level cache present at each node in the tree of network equipment not a complete copy of some media file. In that way, the worst case is that everything behaves as it does now: A consumer requests some data and it propagates through the network. However, the second time the data is requested, if it is still in the cache at some level, there are dramatic savings.[12]
One important issue with content-centric delivery is to assure that the name of the content sufficiently describes the information. For example, the name should include a version, so data can be corrected. It should also include a cryptographic hash, so that the content can be authenticated. The name also needs detailed information about the decoding format. In the case of video, an especially demanding case, it should describe the transcoding format. The general scheme appears able to accommodate all three of the common video distribution systems: Individual transcoding streams, quality layers, and even dynamic recoding. In the case of dynamic recoding, perhaps only a single recoder is required, and then the network caches the new transcoding.[13]
If the content is cryptographically signed, the consumer's equipment can also validate the data easily, and tell upstream devices when it is corrupted. Since the validation complaints can and should be verified at each node, the rejection will propagate only to correct caches with bad data. Hackers will not be able to deny service in the network with lies about hash validation.[14]
A content-centric network is also well suited to provision mobile devices. When content is used, a connection does not need to follow the mobile device. The data needed can be requested anew, and may often be immediately available at new network nodes because it has already been cached.
In this model, the logical place to put commercial copy control and security is not in consumer equipment, but in the neighboring commercial network nodes. If the node agrees that the consumer has a distribution agreement, then restricted content can be delivered. Such delivery contracts require relatively few, cheap CPU cycles from devices already present near the edge of an ISP's net. If there are commercial restrictions, those may need to be included in the content names, as well.[15]
References
- ^ a b Data-Oriented Network Architecture (DONA)
- ^ a b Named Data Networking
- ^ Van Jacobson's Google Tech Talks speech entitled "A New Way to Look at Networking"
- ^ ARPAnet#Background_of_the_ARPANET
- ^ Juno: An Adaptive Delivery-Centric Middleware
- ^ Juno Content-Centric Middleware
- ^ Towards a Modern Communications API by Michael Demmer et. al.
- ^ Literary Machines
- ^ Data-oriented networking
- ^ Stanford TRIAD Project
- ^ CCN video by Van Jacobson on PARC web site, introduction
- ^ CCN video by Van Jacobson on PARC web site
- ^ CCN video by Van Jacobson on PARC web site, questions
- ^ Van jacobson, PARC talk, ibid. near the end of the question period.
- ^ CCN video by Van Jacobson on PARC web site, questions
External links
- Research at PARC on Content-centric networking
- Van Jacobson's page at PARC
- Data-Oriented Network Architecture (DONA), Data-Oriented Network Research at UC Berkeley / ICSI
- Networking Named Content (preprint of CoNEXT 2009 paper)
- Research at the University of Colorado on Content-centric networking
- Antonio Carzaniga's page on Content-based networking
- A middleware-based content-centric solution (Juno)
This computer networking article is a stub. You can help Wikipedia by expanding it.