2021-08-16 17:09:56 +08:00
---
slug: 30
title: 30/ADAPTIVE-NODES
name: Adaptive nodes
2021-09-01 18:54:02 +08:00
status: draft
2024-01-15 23:01:06 +08:00
editor: Oskar Thorén < oskarth @titanproxy .com >
2021-08-16 17:09:56 +08:00
contributors:
---
This is an informational spec that show cases the concept of adaptive nodes.
# Node types - a continuum
We can look at node types as a continuum, from more restricted to less restricted, fewer resources to more resources.
2021-09-01 18:57:29 +08:00
data:image/s3,"s3://crabby-images/6ec12/6ec12e0dcd5d3ed77fa41ea2255877f2aed00496" alt="Node types - a continuum "
2021-08-16 17:09:56 +08:00
2021-09-01 18:54:02 +08:00
## Possible limitations
- Connectivity: Not publicly connectable vs static IP and DNS
- Connectivity: Mostly offline to mostly online to always online
- Resources: Storage, CPU, Memory, Bandwidth
## Accessibility and motivation
Some examples:
2021-09-06 09:40:54 +08:00
- Opening browser window: costs nothing, but contribute nothing
2021-09-01 18:54:02 +08:00
- Desktop: download, leave in background, contribute somewhat
- Cluster: expensive, upkeep, but can contribute a lot
These are also illustrative, so a node in a browser in certain environment might contribute similarly to Desktop.
## Adaptive nodes
We call these nodes *adaptive nodes* to highlights different modes of contributing, such as:
- Only leeching from the network
- Relaying messages for one or more topics
- Providing services for lighter nodes such as lightpush and filter
- Storing historical messages to various degrees
- Ensuring relay network can't be spammed with RLN
## Planned incentives
Incentives to run a node is currently planned around:
- SWAP for accounting and settlement of services provided
- RLN RELAY for spam protection
- Other incentivization schemes are likely to follow and is an area of active research
2021-08-16 17:09:56 +08:00
# Node protocol selection
Each node can choose which protocols to support, depending on its resources and goals.
2021-09-01 19:00:02 +08:00
data:image/s3,"s3://crabby-images/23c49/23c493a8839c7ec88b0c56b11a8b5859d05f9618" alt="Protocol selection "
2021-08-16 17:09:56 +08:00
2021-09-01 18:54:02 +08:00
In the case of protocols like 11/WAKU2-RELAY etc (12, 13, 19, 21) these correspond to Libp2p protocols.
However, other protocols like 16/WAKU2-RPC (local HTTP JSON-RPC), 25/LIBP2P-DNS-DISCOVERY, Discovery v5 (DevP2P) or interfacing with distributed storage, are running on different network stacks.
This is in addition to protocols that specify payloads, such as 14/WAKU2-MESSAGE, 26/WAKU2-PAYLOAD, or application specific ones. As well as specs that act more as recommendations, such as 23/WAKU2-TOPICS or 27/WAKU2-PEERS.
2021-08-16 17:09:56 +08:00
# Waku network visualization
We can better visualize the network with some illustrative examples.
## Topology and topics
The first one shows an example topology with different PubSub topics for the relay protocol.
2021-09-01 19:00:02 +08:00
data:image/s3,"s3://crabby-images/ceab5/ceab57d8657d23341522c1e66ca9d62eee0f8539" alt="Waku Network visualization "
2021-09-01 18:54:02 +08:00
## Legend
2021-09-01 19:00:02 +08:00
data:image/s3,"s3://crabby-images/9467c/9467c14b356d3bf13db95b1b1b290038fcbf05a4" alt="Waku Network visualization legend "
2021-09-01 18:54:02 +08:00
The dotted box shows what content topics (application-specific) a node is interested in.
2021-08-16 17:09:56 +08:00
2021-09-01 18:54:02 +08:00
A node that is purely providing a service to the network might not care.
2021-09-06 09:40:54 +08:00
In this example, we see support for toy chat, a topic in Waku v1 (Status chat), WalletConnect, and SuperRare community.
2021-09-01 18:54:02 +08:00
## Auxiliary network
This is a separate component with its own topology.
Behavior and interaction with other protocols specified in Vac RFCs, e.g. 25/LIBP2P-DNS-DISCOVERY, 15/WAKU-BRIDGE, etc.
2021-08-16 17:09:56 +08:00
## Node Cross Section
This one shows a cross-section of nodes in different dimensions and shows how the connections look different for different protocols.
2021-09-01 18:57:29 +08:00
data:image/s3,"s3://crabby-images/f161e/f161ebf7b1dd69c6d7bf134d2dc4d610f7dc1f47" alt="Node Cross Section "
2021-08-16 17:09:56 +08:00
# Copyright
Copyright and related rights waived via [CC0 ](https://creativecommons.org/publicdomain/zero/1.0/ ).