The libp2p project is creating a set of modular, loosely-coupled building blocks (based on a shared core) for modern peer-to-peer networking. Our goal is to enable a new generation of decentralized applications in which network nodes are full peers, provide and consume data, and route traffic for one another, all without the need for centralized infrastructure or reliance on third-party data ownership.
- Core Tenets
- Visionary
- Evolve
- ⏱ Full Observability
- 🧪 Automated compatibility testing
- Stream Migration Protocol
- 🤖 libp2p as a Wasm library
- 🤝 Low latency, efficient connection handshake
- 🛣️ Peer Routing Records
- 🗣️ Polite peering
- 🧱 Composable routing
- 💣 Attack resistance, threat models and security
- 📈 Proving we are scalable and interoperable
- 🌡️ Telemetry protocol
- 📩 Message-oriented transports
- ☎️ Reducing the dial fail rate
- 🔀 Peer exchange protocol
- 🏹 RPC and other common node communication patterns
- Done
Before we dive into what libp2p should support and enable, let's outline the core tenets that underpin the project. As maintainers, we commit to ensuring libp2p is:
- 🔒 Secure - Building on libp2p improves an application's security posture. We minimize vulnerabilities and act rapidly to address and report issues.
- 🪨 Stable - Releases do not unknowingly break deployed features. We maintain cross-version compatibility across libp2p releases and implementations. Deprecations are well-communicated.
- 🥽 Specified - We thoroughly specify the libp2p framework and its suite of supported protocols, independent of language or implementation. Through specifications, we coordinate and drive future developments.
- 🚀 Performant - We ensure comparable performance to widely used protocols on the Internet. We avoid performance degradations in new releases.
These tenets form the foundation for features and initiatives listed below. As a result, we generally prioritize filling any gaps in these tenets above other work.
This roadmap doesn't provide a timeline for project adoption across libp2p implementations. For specific sequencing and dates, see the different implementation roadmaps:
- (other implementations: feel free to add)
Our long term roadmap.
These are the goals that move libp2p from "a networking toolbox for building P2P applications" to a project that fundamentally reshapes the architecture of the Internet. They are our dreams, aspirations, and the North star we should always keep in sight. This is what motivates us and it speaks intimately to our mission statement; the libp2p analogy of IPFS working on Mars.
What? Interacting and transacting with the person next to me should not require me to resort to the Internet, make use of centralised services run by corporations, expose myself to censorship, and lose self-agency over my data.
This theme covers a number of related topics: mesh networking, community networks, sneaker nets, isolated networks in libp2p.
An undertaking like this touches upon many surfaces of the system, e.g. implementing new transports (Bluetooth, software defined radio, ultrasonic data [Chirp], Wi-Fi direct, QR, Ethernet, 802.11s, etc.), new discovery mechanisms (local peer exchange, social peer advertisement, etc.), packet-switched routing, and more.
But it's not just about connectivity. In this new reality, nodes can come and go easily. As a result, new requirements will emerge, such as supporting roaming (the ability for a user to switch networks without dropping ongoing sessions) and resilient state and connectivity, to buffer data (potentially via a store-and-forward architecture) so that a node disconnecting intermittently can get up to speed when they come back online.
For certain applications, we might want to take compensatory actions after a grace period, such as rebalancing data across nodes. And this requires us to think about group membership, partitioning, consensus, etc. This is just an initial train of thought, and there's a lot more ground to cover.
Why? The IPFS roadmap tackles mesh networks, isolated networks, sneaker nets, and making IPFS work in Mars where general connectedness to the Internet does not exist. The network should pave the way for IPFS to evolve in that direction.
What? Supporting transports like cjdns, I2P and Tor (see OpenBazaar/go-onion-transport) helps create resilient, privacy-centric communications, and moves the needle forward towards censorship-resistant networks. As an intermediary step, we should improve our existing transport stack, e.g. preventing downgrade attacks when securing connections.
What? First-class integration of libp2p in mobile devices is a prerequisite for the class of offline-first use cases we are targeting.
This implies building/supporting Java/Kotlin and Swift implementations -- either fully-fledged or trimmed-down versions that do the minimum necessary or wrap existing implementations like nim-libp2p or rust-libp2p.
Why? Bringing libp2p natively to mobile devices is an enabler for offline-first use cases.
What? Distinct from consumer mobile devices like smartphones, IoT devices like embedded sensors are a potential use case for libp2p. These devices are typically more resource constrained and may have intermittent connectivity. They also tend to do minimal processing locally, but transmit frequently to a cloud where data analysis occurs.
Why? IoT can greatly benefit from peer-to-peer networking. Supporting IoT environments with libp2p greatly expands libp2p's userbase on the one side and on the other enables existing libp2p deployments to interconnect with said IoT devices.
What? Academics should be able to use libp2p as a playground for their research. Amongst other points, this encompasses:
-
Building a public utility p2p network that academics can deploy their algorithms and solutions onto, to trial them on a large scale, or test their hypothesis on.
-
Packaging P2P prior art in composable building blocks, to allow researchers to focus on the problem at hand, without having to reinvent the wheel.
-
Providing modelling tools, data collection hooks, sampling strategies, etc. to facilitate research practices.
-
Making libp2p stable and dependable enough so researchers are satisfied with the rigor of studies built on libp2p.
This goal has parallels with the TestLab endeavour.
Why? To contribute back to the p2p research community; to harness the work taking place at research facilities by implementing the research outputs on libp2p.
What? A number of nodes in the network take on important assistive roles, e.g. bootstrap, DHT boosters, relay, network, etc. However:
-
relying on static IPs or DNS entries exposes us to centralisation, and is fragile.
-
the network grows and shrinks dynamically, so we should scale these nodes accordingly.
-
these nodes are easy to attack directly, and such attacks can harm the network; currently we have no resilience plan.
-
routing/connectivity between nodes could be compromised by network attacks, or censorship.
In the long term, we aim to build a resilient, self-healing network that scales dynamically based in response to traffic volume, disasters, and network conditions.
Why? To get closer to the dream of unstoppable, intelligent, adaptive networks.
What? Providing solutions to store data for nodes that have gone offline temporarily. Payloads can be pubsub messages, DHT provider records, or even RPC calls. In traditional MQ systems, this property is typically termed "reliability".
Several ideas have been floated within the libp2p community:
-
Third-party postbox nodes that are incentivised to buffer data between nodes A and B, when either is unavailable.
-
Store-and-forward architectures.
And there's probably many more to explore. When reasoning about these methods, we should keep in mind aspects like replication, storage, liveness, byzantine fault tolerance, etc. Depending on the mechanism, the challenges may even align with those of Filecoin.
Why? It's an enabler for offline-first scenarios, low quality connections, roaming, etc.
Links:
Our short-term roadmap.
These are the projects pushing the existing libp2p stack forward.
What? libp2p should expose a wide set of metrics, making it easy to monitor the system.
Metrics should include:
- Transport metrics (TCP, QUIC, security protocols, stream multiplexers)
- Swarm metrics
- other subsystems (AutoNAT, AutoRelay, Hole Punching)
Why? A system that cannot be monitored will misbehave - sooner or later.
Links:
Status: In progress
What? There are more than 6 implementations of the libp2p specification in different languages. We need to ensure compatibility of all combinations of these implementations. Given the number of libp2p implementations and the amount of libp2p protocols, verifying compatibility on a continuous basis can only be tackled in an automated fashion.
Why? Automated compatibility testing allows us to move fast with confidence and will increase trust in the libp2p project as a whole.
We can build on top of the testground project. Multiple of the so called testground test plans are already in place for the go-libp2p implementation in the libp2p test-plans repository.
Links:
What? A protocol to migrate a stream from one connection to another.
Why? Among others, this allows the migration of streams from a relayed connection to a direct connection.
Links:*
- Tracking issue libp2p#328
- Specification draft libp2p#406 (comment)
What? This point encompasses two things:
-
Preparing existing implementations to run in Wasm environments (mainly the browser).
-
Evaluating if it's feasible to build a canonical implementation of libp2p, that is maintained in a single language, compiling down to WebAssembly so that it can be used from any other programming language -- as long as the user is building a Wasm application.
Why? Aside from targeting Wasm use cases, having one canonical implementation of libp2p that can run anywhere could help focus the team's time on building new features, instead of keeping a multitude of implementations across different languages in sync, i.e. create more value and impact. Wasm also presents a huge vector for making libp2p the de-facto networking stack, for cases where Wasm is a suitable deployment model.
Links:
High priority for: IPFS
What? Establishing a connection and performing the initial handshake should be as cheap and fast as possible. On TCP, the current libp2p handshake spends one round-trip negotiating the security protocol, and another round-trip negotiating the stream multiplexer. By using advanced features of the handshake protocol, we might even be able to reach the holy grail of a 0-RTT handshake in some cases.
Why? Applications rely on quick connection establishment. libp2p shouldn't make them wait for any longer than absolutely necessary.
Links:
What? Methods such as DHT traversal depend on potentially untrustworthy third parties to relay address information. Peer Routing Records provide a means of distributing verifiable address records, which we can prove originated from the addressed peer itself.
Why? Being able to prove the authenticity of addresses discovered through some mechanism prevents address spoofing as well as attacks enabled through address spoofing.
Peer Routing Records are defined in RFC 0003. They are used in combination with Signed Envelopes which are defined in RFC 0002. While the specification work is done, existing discovery mechanisms such as the Kademlia DHT need to support advertising signed Peer Routing Records.
What? Peers don't behave well with one another. They do not send DISCONNECT messages reporting the reason (e.g. rate limiting) for disconnection, they do not warn when they're about to close a connection, they don't give peers a chance to keep important connections open, etc.
Why? Peers act haphazardly when observed from the outside, leading e.g. to unnecessary connection churn. They do not have the means to act more collaboratively. We are lacking a wire protocol that governs the connection between two peers.
What? The composable routing framework has four "pillars**:
-
Routing syntax and language
The routing syntax is a common data model (with a user-facing syntactic representation) for communicating routing-related information (requests and responses). The implementation of the routing syntax provides serialization and pretty printing of routing expressions.
-
Routing interface
A routing system processes routing requests and returns routing responses. Routing requests and responses have semantics, which are unlike those of a traditional request/response protocols, that implement function call arguments and return values.
-
Smart Records
Smart Records (SR) is a technology that enables multiple decentralized parties and protocols to randevouz and share information on a topic. Specifically, SR is a key-value store service, which facilitates conflict-free updates to values by multiple writers.
-
Subnets
At present, there is a single DHT network which spans across all IPFS nodes. We would like to introduce a general standard for the co-existence of multiple network instances with individual discovery, membership and content routing semantics.
Why? Enable interoperability of protocols and nodes with different versions and capabilities, developed by independent teams or organizations. As a consequence, it also enables middleware components (like caching, batching, predictive fetching, and so on** and the co-existence of different content finding protocols and subnetworks.
Links:
What? This is an overarching element of the roadmap, and it affects everything else. Activities under this endeavour include:
-
Past and present. Pragmatically analysing and profiling the exposure of each component against a taxonomy of attacks and threat models, e.g. DDoS, byzantine, sybil, poisoning, eclipse, flooding, etc.
-
Past and present. Establishing a plan to mitigate all identified attack vectors, and delivering on it.
-
Future. Setting up an ongoing process to assess the security implications of all future pull requests (e.g. checklists for code reviews).
-
We may even decide to hire a specialist in the team.
-
Different kinds of simulations.
Why? As more projects entrust libp2p to take care of their networking requirements, the more we have at stake (reputationally), and the higher the incentive for attackers to find ways to disrupt libp2p networks.
Links:
-
Low-Resource Eclipse Attacks on Ethereum's Peer-to-Peer Network.
-
Ethereum Serenity research: Sybil-like attacks at the p2p level.
What? Proving the scalability of libp2p at orders of magnitude 10^4, 10^6, and more, across all native implementations of libp2p. Conducting these tests in a lab setting requires solving problems like cluster operation, code instrumentation and metrics collection at scale.
But some magnitudes are cost-ineffective to test in a dedicated infrastructure. We might have to resort to capturing empirical evidence from live networks. This ties in with the opt-in telemetry protocol and the extension of IPTB into IPTL (TestLab).
And we cannot forget negative testing. This includes chaos engineering (libp2p chaos monkey idea), orchestrated attacks and theoretical simulations.
Example targets/KPIs:
-
DHT lookups return the correct value in <= N seconds in a 10^9 node network.
-
Pubsub messages reach all subscribers in <= N seconds in a 10^9 node network where M% subscribe to the topic
-
Network survives and re-balances following the churn of N% nodes, at M node/s departure/arrival rate, measured by ...
Why? To gain confidence that the technology that we're building is a rock-solid foundation for the future of P2P networks; to quantitatively measure the impact of our changes on the large scale; to combat the perception in some circles that libp2p is "immature".
What? By developing a privacy-preserving telemetry protocol, libp2p networks could build a world-wide real-time visualisation of the network, à la Torflow, Kaspersky's Cybermap, or Checkpoint's Threatmap.
The privacy properties of this protocol need to be strong enough that metrics collection can be enabled by default (with an easy switch to disable it for users who disagree with that assessment). As an example, the IETF PPM working group is currently doing interesting work standardizing such a protocol, using advanced cryptography and a distributed setup.
Nodes could probe and collect stats about the connections it maintains with other peers: latency, traceroute, IP address, hole punching success rates etc. The resulting protocol should expose a way for applications running on top of libp2p to use this framework for collecting application- specific metrics.
Why? To gain real-time insight into libp2p networks and the applications using the stack.
What? The data layer of the libp2p API is geared towards streams, and does not support message orientation. The notion of messages has been discussed in the past, and there is even a draft proposal for a multigram protocol.
Progressing with this work entails designing the abstractions, and implementing, at least, a UDP transport, as the community has demanded.
Why? Currently the libp2p API precludes us from modelling message-oriented transports like UDP or Bluetooth.
What? Reducing the dial fail rate implies improvements in several areas.
-
Outbound dials: We should strategise dials based on context, or based on a heuristic determined by the application. For example, apps designed for local exchange of data will naturally prefer to try local/physical endpoints over public ones first. We may want to dial relay addresses last, dial newer addresses first, etc.
Users should also have the capability to customise how addresses are resolved, how dials are throttled, how connections are selected if multiple dials succeeded, etc. In a nutshell, the dialing behaviour should be fully customisable per host.
-
Context-sensitive advertisement of self-addresses: private addresses should not leak into public DHTs, both for connectivity and security reasons (cf. IPFS DHT pollution in 2016). Similarly, local discovery mechanisms should only transmit private addresses. The DHT topology question becomes relevant to define scopes (e.g. federated/concentric/shared DHTs for different scopes). Also, when dealing with multi-layer NATs, there may be better routes between peers behind regional or ISP NATs other than their public endpoints.
-
Connectivity-related problems: see Unprecedented global connectivity and Improve NAT traversal.
Why? Dialing is a crucial function of our system and using a non-deterministic, scattershot approach is inefficient both in regards to the number of failed dial attempts and the increased time to first byte.
Links:
Copied and adapted from: libp2p/notes#3
What? We currently use mDNS to discover local peers but it would also be nice if we could have a peer exchange protocol for discovering even more local peers.
Why? (1) relying on the global DHT to discover local peers is problematic; (2) ideally, we want to be able to discover all peers on the local network. In case two devices are in the same room, they should be able to share files with each-other directly. This ties into offline and decentralised networks.
Links
What? Make it easy for developers to communicate between libp2p nodes using development patterns that they are used to. This includes creating libraries with the appropriate documentation and examples that support common use cases including:
-
RPCs using both primitive and non-primitive data types
-
Peer service discovery and version compatibility
-
Streaming blocks of non-primitive data types
-
RPCs with implicit context (e.g. if performing multiple operations on objID, only pass it once)
Why? We currently have multiple implementations and strategies for getting libp2p nodes to communicate, however the startup cost for developers wanting to add their own communication protocols and endpoints is still too high. By providing simple and familiar frameworks like RPC to developers they should be able to more efficiently develop their projects. Additionally, easy to use high level communication frameworks should allow developers not very familiar with low-level networking to get started with libp2p.
Links
- See Rust's libp2p-request-response as one possible communication pattern abstraction.
Status: Done
What? A DHT crawl measurements (Nov 22nd 2019) showed that out of 4344 peers, 2754 were undialable (~63%). This evidence correlates with feedback from the IPFS and Filecoin teams.
We need to implement additional mechanisms for Firewall and NAT traversal to have the highest probability of being able to establish a direct connection. Mechanisms we wish to add include:
- Project Flare stack (via Circuit Relay v2, Direct Connection Upgrade through Relay, AutoNAT, Stream Migration, ...)
Why? Good connectivity is the bread-and-butter of libp2p. Focusing on solving these issues for TCP and QUIC will bring more stability and robustness to the rest of the system.
Links:
Status: Done
What? WebTransport is a browser-API offering low-latency, bidirectional client-server messaging running on top of QUIC. The browser API allows the establishment of connections to servers that don't have a TLS certificate signed by a certificate authority if the hash of the certificate is known in advance.
Why? This allows libp2p nodes running in the browser (using js-libp2p-webtransport) to connect to the rest of the libp2p network.
Links:
- IETF draft
- W3C Browser API
- libp2p Specification
- webtransport-go
- go-libp2p WebTransport
- js-libp2p WebTransport
Status: Done
What? WebRTC is a transport protocol supported by all major browsers. Those browsers allow the establishment of connections to remote endpoints that don't have a TLS certificate signed by a trusted certificate authority. In addition WebRTC includes hole punching capabilities.
Why? In most p2p networks the majority of nodes do not have a signed TLS certificate. With WebRTC browsers will thus be able to connect to these previously unreachable nodes. In addition, being able to hole punch allows browsers to connect to nodes behind firewalls and NATs e.g. other browsers. Note that the former, namely connecting without trusted TLS certificate, can as well be achieved with the WebTransport protocol.
Links:
- Tracking issue libp2p#220
/webrtc
specification/webrtc-direct
specification