GNUnet with the GTK+ user interface
|Initial release||November 5, 2001|
|Stable release||0.10.1 (April 8, 2014) [±]|
|Operating system||Linux, FreeBSD, NetBSD, OpenBSD, OS X, Windows|
|Type||Anonymous P2P, Friend-to-friend|
|License||GNU General Public License|
|Alexa rank||1,022,092 (Oct 2015[update])|
|Part of a series on|
|Networks and protocols|
|Development and societal aspects|
|Non-public file sharing|
|Websites and services|
|By country or region|
GNUnet is a free software framework for decentralized, peer-to-peer networking and an official GNU package. The framework offers link encryption, peer discovery, resource allocation, communication over many transports (such as TCP, UDP, HTTP, HTTPS, WLAN and Bluetooth) and various basic peer-to-peer algorithms for routing, multicast and network size estimation.
GNUnet's basic network topology is that of a mesh network. GNUnet includes a distributed hash table (DHT) which is a randomized variant of Kademlia that can still efficiently route in small-world networks. GNUnet offers a "F2F topology" option for restricting connections to only the users' trusted friends. The users' friends' own friends (and so on) can then indirectly exchange files with the users' computer, never using its IP address directly.
GNUnet uses Uniform resource identifiers (not approved by IANA, although an application has been made). GNUnet URIs consist of two major parts: the module and the module specific identifier. A GNUnet URI is of form gnunet://module/identifier where module is the module name and identifier is a module specific string.
The primary codebase is written in C, but with gnunet-java there is an effort to produce an API for developing extensions in Java. GNUnet is part of the GNU project. It has gained interest to the hacker community after the PRISM revelations.
GNUnet consists of several subsystems, of which essential ones are Transport and Core subsystems. Transport subsystem provides insecure link-layer communications, while Core provides peer discovery and encryption. On top of the core subsystem various applications are built.
GNUnet includes various P2P applications in the main distribution of the framework, including filesharing, chat and VPN; additionally, a few external projects (such as secushare) are also extending the GNUnet infrastructure.
GNUnet is unrelated to the older Gnutella P2P protocol. Gnutella is not an official GNU project while GNUnet is.
GNUnet network has no trusted entities so it is impossible to maintain global reputation. Instead, each peer maintains its own trust for each of its local links.
When resources, such as bandwidth and CPU time, are in excess, peer provides them to all requesting neighbors without reducing trust or otherwise charging them. When a node is under stress it drops requests from its neighbor nodes having lower internal trust value. However, when peer has less resources than enough to fulfill everyone's requests, it denies requests of those neighbors that it trusts less and charges others by reducing their trust.
The primary application at this point is anonymous, censorship-resistant file-sharing, allowing users to anonymously publish or retrieve information of all kinds. GNUnet protocol that provides anonymity is called GAP (GNUnet anonymity protocol). GNUnet uses GNU libextractor to automatically annotate shared files with metadata.
Files shared with GNUnet are ECRS (An Encoding for Censorship-Resistant Sharing) coded.
All content is represented as GBlocks. Each GBlock contains 1024 bytes. There are several types of GBlocks, each of them serves a particular purpose. Any GBlock is uniquely identified by its RIPEMD-160 hash .
DBlocks store actual file contents and nothing else. File is split at 1024 byte boundaries and resulting chunks are stored in DBlocks. DBlocks are linked together into Merkle tree by means of IBlocks that store DBlock identifiers.
Blocks are encrypted with a symmetric key derived from when they are stored in the network.
Queries and replies
GNUnet Anonymity Protocol consists of queries and replies. Depending on load of the forwarding node, messages are forwarded to zero or more nodes.
Queries are used to search for content and request data blocks.
Query contains resource identifier, reply address, priority and TTL (Time-to-Live).
Resource identifier of datum is a triple-hash . Peer that replies to query provides to prove that it indeed has the requested resource without providing to intermediate nodes, so intermediate nodes can't decrypt .
Reply address is the major difference compared to Freenet protocol. While in Freenet reply always propagates back using the same path as the query, in GNUnet the path may be shorter. Peer receiving a query may drop it, forward it without rewriting reply address or indirect it by replacing reply address with its own address. By indirecting queries peer provides cover traffic for its own queries, while by forwarding them peer avoids being a link in reply propagation and preserves its bandwidth. This feature allows the user to trade anonymity for efficiency. User can specify an anonymity level for each publish, search and download operation. An anonymity level of zero can be used to select non-anonymous file-sharing. GNUnet's DHT infrastructure is only used if non-anonymous file-sharing is specified. The anonymity level determines how much cover traffic a peer must have to hide the user's own actions.
Priority specifies how much of its trust user wants to spend in case of resource shortage.
TTL is used to prevent queries from staying in the network for too long.
File sharing URIs
- chk identifies files, typically:
gnunet://fs/chk/[file hash].[query hash].[file size in bytes]
- File hash is the hash of the plaintext file, which allows to decrypt it once it is downloaded. Query hash is the hash of topmost GBlock which allows to download the whole tree of GBlocks that contain encrypted file. File size is required to determine the shape of the tree.
- sks identifies files within namespaces, typically:
- ksk identifies search queries, typically:
- loc identifies a datum on a specific machine, typically:
A type of GNUnet filesharing URI pointing to a specific copy of GNU GPL license text:
Another type of GNUnet filesharing URI, pointing to the search results of a search with keyword "gpl":
GNU Name System
GNUnet includes an implementation of the GNU Name System (GNS), a decentralized and censorship-resistant replacement for DNS. In GNS, each user manages his own master zone which is mapped into the DNS namespace under the .gnu top-level domain. Users can delegate subdomains to zones managed by other users. Lookups of records defined by other users are performed using GNUnet's DHT.
GNUnet can tunnel IP traffic over the peer-to-peer network. If necessary, GNUnet can perform IPv4-IPv6 protocol translation in the process. GNUnet provides a DNS Application-level gateway to proxy DNS requests and map addresses to the desired address family as necessary. This way, GNUnet offers a possible technology to facilitate IPv6 transition. Furthermore, in combination with GNS, GNUnet's protocol translation system can be used to access hidden services --- IP-based services that run locally at some peer in the network and which can only be accessed by resolving a GNS name.
Gabor X toth published in early September 2013 a thesis to present the design of a social messaging service for the GNUnet peer-to-peer framework that offers scalability, extensibility, and end-to-end encrypted communication. The scalability property is achieved through multicast message delivery, while extensibility is made possible by using PSYC (Protocol for SYnchronous Conferencing), which provides an extensible RPC (Remote Procedure Call) syntax that can evolve over time without having to upgrade the software on all nodes in the network. Another key feature provided by the PSYC layer are stateful multicast channels, which are used to store e.g. user profiles. End-to-end encrypted communication is provided by the mesh service of GNUnet, upon which the multicast channels are built. Pseudonymous users and social places in the system have cryptographical identities — identified by their public key — these are mapped to human memorable names using GNS (GNU Name System), where each pseudonym has a zone pointing to its places.
That is the required building block for turning the GNUnet framework into a fully peer-to-peer social networking platform.
A trivial chat module has been implemented more as a test than as a serious application, but it is usable.
- Anonymous P2P
- Comparison of file sharing applications
- Anonymous network software: Freenet, I2P, Tor (anonymity network)
- Synchronous conferencing
- Grothoff, Christian (2013-12-24). "GNUnet 0.10.0 released" (Mailing list). info-gnunet. Retrieved 2013-12-25.
- GNUnet Source Code
- "gnunet.org Site Overview". Alexa Internet. Retrieved October 27, 2015.
- EvansPolotGrothoff 2012.
- Grothoff 2013.
- FerreiraGrothoffRuth 2003, Figure 1.
- FerreiraGrothoffRuth 2003, II. GNUNET AND THE TRANSPORT LAYER: "The core is responsible for link-to-link encryption, binding of node identities to routable addresses, and peer discovery."
- GrothoffPatrascuBennettStef 2002, 3.1.1 UDP.
- FerreiraGrothoffRuth 2003.
- Service Name and Transport Protocol Port Number Registry, p. 37
- Grothoff 2003.
- GrothoffPatrascuBennettStef 2002, 2.4 Mojo Nation.
- BennettGrothoff 2003.
- BennettGrothoffHorozovPatrascu 2002.
- GrothoffPatrascuBennettStef 2002, 5.5 More on queries.
- Grothoff, Christian. "File-Sharing URIs". www.gnunet.org. Retrieved 15 July 2016.
- Toth, Gabor X (2013-09-05), Design of a Social Messaging System Using Stateful Multicast - Retrieved 2013-09-28
- Grothoff, Christian; Patrascu, Ioana; Bennett, Krista; Stef, Tiberiu; Horozov, Tzvetan (2002-06-13). The GNet whitepaper (PDF) (Technical report). Purdue University.
- Bennett, Krista; Grothoff, Christian; Horozov, Tzvetan; Patrascu, Ioana (2002-07-03). Batten, Lynn; Seberry, Jennifer, eds. Efficient Sharing of Encrypted Data. Lecture Notes in Computer Science. Springer Berlin Heidelberg. pp. 107–120. ISBN 9783540438618. doi:10.1007/3-540-45450-0_8.
- Ferreira, Ronaldo; Grothoff, Christian; Ruth, Paul (2003-05-01). "A transport layer abstraction for peer-to-peer networks" (PDF). 3rd IEEE/ACM International Symposium on Cluster Computing and the Grid, 2003. Proceedings. CCGrid 2003. IEEE: 398–405. ISBN 0-7695-1919-9. doi:10.1109/CCGRID.2003.1199393.
- Grothoff, Dipl-Math Christian (2003-06-01). "Resource allocation in peer-to-peer networks". Wirtschaftsinformatik. 45 (3): 285–292. ISSN 0937-6429. doi:10.1007/BF03254946.
- Bennett, Krista; Grothoff, Christian (2003-03-26). Dingledine, Roger, ed. gap – Practical Anonymous Networking. Lecture Notes in Computer Science. Springer Berlin Heidelberg. pp. 141–160. ISBN 9783540206101. doi:10.1007/978-3-540-40956-4_10.
- Evans, Nathan; Polot, Bartlomiej; Grothoff, Christian (2012-05-21). Bestak, Robert; Kencl, Lukas; Li, Li Erran; Widmer, Joerg; Yin, Hao, eds. Efficient and Secure Decentralized Network Size Estimation. Lecture Notes in Computer Science. Springer Berlin Heidelberg. pp. 304–317. ISBN 9783642300448. doi:10.1007/978-3-642-30045-5_23.
- Grothoff, Christian (2013-08-01). "Video: You broke the Internet. We're making ourselves a GNU one.". gnunet.org. Pirate Party Germany, Berlin. Retrieved 4 October 2013.
- Grothoff, Christian (2015). "The Architecture of the GNUnet: 45 Subsystems in 45 Minutes" (PDF). Retrieved 2016-07-14.
- Official website
- Paper describing ECRS
- A comparison of GNUnet with other peer-to-peer networking
- GNUnet adds VPN, direct wireless peering, and more, LWN.net, December 21, 2011
- Master's thesis about the GNU Name System
- Master's thesis about stateful multicast messaging design
- Secure share - social network service built on top of GNUnet