Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Waku's maximum bandwidth for global adoption #31

Open
alrevuelta opened this issue Oct 12, 2023 · 3 comments
Open

Waku's maximum bandwidth for global adoption #31

alrevuelta opened this issue Oct 12, 2023 · 3 comments

Comments

@alrevuelta
Copy link
Contributor

TLDR: This issue aims to set the maximum bandwidth in x Mbps that each waku shard should consume so that the maximum amount of people can run a full waku node. It is up to #22 to specify how this maximum will be enforced.

Conclusion: Limit to 10 Mbps each waku shard.

Introduction

Waku is designed in a way that everyone should be able to run a full node on an average laptop with a residential Internet connection, at least in one shard. This will enable true decentralization and give power to the users, since they won't need to rely on third parties to send/receive messages. Professional node operators running in data centers, can of course contribute to multiple shards, but we should keep the bandwidth/hardware requirements of single shard rather low.

This vision opposes the federated approach, where a few nodes requiring vast amounts of resources (cpu, memory, bandwidth) run in datacenters, taking the power from the user. While federated approaches are an improvement from traditional client-server architectures, waku envisions a fully peer-to-peer architecture where anyone should be able to run a node.

In order to ensure that anyone can run a node in desktop, there are two main limiting factors:

    1. Bandwidth consumption in Mbps
    1. CPU/memory resources (mainly limited by RLN proof verification)

This issue focuses on i) bandwidth consumption and #30 on ii) CPU/memory resources. Note that on #23 an analysis on the impact on RLN was already made, but wasn't focused on scalability. Said issues do.

In #22 we discussed why and how to limit the maximum bandwidth per shard, but we haven't come up with a specific number in Mbps. This issue i) presents data from the available bandwidth at different locations and ii) suggests a maximum bandwidth in Mbps that waku should enforce.

Bandwidth Availability and Usage

The following tables show:

  • Table [1] The Q25, Q75 and average bandwidth (upload/download) in Mbps available on different continents. Raw data is available here and credits to @leobago for the summarized version. Note: The below numbers were rounded to the nearest integer.
  • Table [2] The median global bandwidth (upload/download) in Mbps, taken from speedtest (accessed 12 Oct 2023).
  • Table [3] Download bandwidth requirements in Mbps for Netflix video streaming, source.
Table [1] Download (Mbps) Upload (Mbps)
Q25 Average Q75 Q25 Average Q75
North-America 58 107 137 38 68 85
South-America 21 54 72 13 33 44
Europe 49 93 119 30 56 72
Asia 23 53 71 15 37 50
Oceania 44 84 108 27 50 63
Africa 12 26 33 7 17 22
Table [2] Median Download (Mbps) Median Upload (Mbps)
Global 83 38
Table [3] Video resolution Recommended Bandwidth
HD 3 Mbps
Full HD 5 Mbps
4K/UHD 15 Mbps

Selecting a Maximum Bandwidth

With the above data, we should be informed to take a decision on the maximum bandwidth that we should enforce per shard. With this number, we will apply the techniques explained in #22 to ensure (with some statistical confidence) that the bandwidth won't exceed that number.

The tradeoff is clear:

  • We enforce a low bandwidth: more people can run full waku nodes, overall network throughput is less, network decentralization is easier, gives power to the user as its fully sovereign.
  • We don't enforce a low bandwidth: not possible to run full waku nodes in laptops acting as a centralization force, nodes are run by few professional operators in datacenters, waku users just use light clients, network throughput can scale way easier, federated approach.

So it's about where to draw this line.

Points to take into account:

  • Relay contributes to bandwidth the most: Relay is the protocol that mostly contributes to bandwidth usage, and it can't choose to allocate fewer bandwidth resources like other protocols (eg store can choose to provide less resources and it will work). In other words, the network sets the relay bandwidth requirements, and if the node can't meet them, it just wont work.
  • Upload and download bandwidth are the same: Due to how gossipsub works, and hence relay, the bandwidth consumption is symmetric, meaning that upload and download bandwidth is the same. This is because of D and the reciprocity of the connections, meaning that one node upload is another download.
  • Nodes not meeting requirements can use light clients. Note that nodes not meeting the bandwidth requirements can still use waku, but they will have to use light protocols, which are a great alternative, especially on mobile, but with some drawbacks (trust assumptions, less reliability, etc)
  • Waku can't take all the bandwidth: Waku is meant to be used in conjunction with other services, so it shouldn't consume all the existing bandwidth. If Waku consumes x Mbps and someone bandwidth is x Mpbs, the UX won't be good.
  • Compare with existing well-known services: As shown in Table [3], Netflix 4K video streaming takes 15Mbps, so that is an order of magnitude to take into account.

Coming up with a number:

  • Lowest average download speed across continents is Africa (26 Mbps)
  • Lowest average upload speed across continents is Africa (17 Mbps)
  • Since in waku the bandwidth consumption is symmetric, we are limited by the lowest (17 Mpbs)
  • However waku should not consume all bandwidth, leaving some room for other applications.
  • We could set 10 Mbps, which is between Full HD video and 4K.
  • With 10Mbps the % of average bandwidth waku will consume is:
    • North-America 9 %
    • South-America 18 %
    • Europe 11 %
    • Asia 18 %
    • Oceania 12 %
    • Africa 38 %

Conclusion: Limit to 10 Mbps each waku shard. How? Not trivial, see #22 (comment)

Note: This number is not set in stone and is subject to modifications, but it will most likely stay in the same order of magnitude if changed.

@s-tikhomirov
Copy link
Contributor

Upload and download bandwidth are the same

Does this not depend on the number of messages that originates from a node? Imagine that Alice is an active publisher (for example, she is a full node that thousands of light nodes connect to), while Bob is a relay node only used for reading, not publishing. Wouldn't it be the case that Alice's bandwidth consumption will be skewed towards upload bandwidth, compared to Bob's?

@alrevuelta
Copy link
Contributor Author

alrevuelta commented Oct 16, 2023

Does this not depend on the number of messages that originates from a node? Imagine that Alice is an active publisher (for example, she is a full node that thousands of light nodes connect to), while Bob is a relay node only used for reading, not publishing. Wouldn't it be the case that Alice's bandwidth consumption will be skewed towards upload bandwidth, compared to Bob's?

Even in that case both A/B up/down bandwidth will be the same. Assuming ofc that both nodes are subscribed to the same topic. In gossipsub every node sends and receives all the messages in the topic, with some fixed amplification factor. There might be some cases where specific gossipsub config can alter this though, but afaik the differences shouldn't be much.

Note that I'm disregarding the bandwidth that Alice will consume serving the light clients, since its trivial to limit this.

@vpavlin
Copy link
Member

vpavlin commented Oct 27, 2023

Thanks for the detailed writeup!

I agree that our focus should be on decentralization and 10Mbps sounds reasonable.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants