Hey ya! It is Thursday. I recorded a really great podcast episode today with JJ Jacks, of Open Core Summit. And one of the topics we covered in brief is this post from Vitalik Buterin on the Meaning of Decentralization. Has anyone here read it?
From my point of view:
Type âaâ and âbâ still have a weakness, if you destroy his âcoordination centerâ all communications will down. But structure âŃâ does not have âcoordination cantersâ it like a mesh network if you destroy 1-2-10-15 âstationsâ nothing happened⌠because âstationsâ always have an âanother wayâ to another âstationâ. Only this structure has an extraordinary ability to survive, Tardigrade should learn this structure more detailed
âŚand doesnât matter how we name this âstructureâ only the mechanism of its work matters.
Yeah, âdecentralizedâ may work for torrents, where if one tracker goes down, I can download the same file using another tracker. But here I cannot really have copies my data on all satellites etc.
A file, uploaded by a customer, is dependant on the existance of the central point - the satellite. It does not matter if the data itself is distributed to 10k nodes or is instead on a server in a datacenter somewhere.
Something bad happens to the satellite (software bug, hardware problem, people with guns) and say bye to your data. Exactly the same as if it was stored on Amazon or in some other âcentralizedâ service.
The only thing, IMO, that the current Storj structure has is that by distributing the data to mane less-reliable nodes it can be made cheaper than storing the same amount of data in a datacenter, on reliable datacenter hardware with backups etc.
EDIT: Also, wouldnât Storj structure fit the âcentralizedâ example better, with the satellite at the center? Nodes do not coordinate anything with each other, neither do uplinks. Nodes and uplinks do talk to each other, but only after setting it up with the satelite.
Also, I would lite to update the old picture from the old book
Here are modern models:
As I said before: âdoesnât matter how we name this âstructureâ only the mechanism of its work mattersâ
11 posts were split to a new topic: How to achieve a âFull decentralizationâ (distribution) without slow down
And now we can return to the topic: you pointed out to the âfull decentralizationâ (distribution) of metadata only.
No, Letâs me explain what mean âfull-decentralizationâ:
- No single point of failure (for example you can hit all âcoordinatorsâ and half of the network but your data will be accessible)
- Data and metadata are distributed across all network
The data is already distributed across the network (nodes). The metadata is distributed only across clusters but not the network of storage nodes.
But who is the owner of these clusters? and who are the owners of these storage nodes?
Clusters belongs to satellite operator. Each node belongs to node operator.
So, to operators.
Letâs look deeper:
storage nodes owners - multiple independent owners.
clusters (satellites) - single owner.
You can own the satellite cluster too. And anyone, right now.
So, back to the topic.
What is full decentralization are you meaning?
P.S. I would like to suggest to read an article of Vitalik again, itâs deeply dive into decentralization in almost all aspects, include politic.
Here is the answer and here is the model âper-to-perâ
How many independent satellite ownes we have rigth now?
I have no idea, itâs open source.
But widely known StorjLabs and Stefan
I see only Storj Labs as an owner and Stefan satellite was decommissioned.
So right now we have (look into trust-cache.json):
{
"entries": {
"https://tardigrade.io/trusted-satellites": [
{
"SatelliteURL": {
"id": "12EayRS2V1kEsWESU9QMRseFhdxYxKicsiFmxrsLZHeLUtdps3S",
"host": "us-central-1.tardigrade.io",
"port": 7777
},
"authoritative": true
},
{
"SatelliteURL": {
"id": "12L9ZFwhzVpuEKMUNUqkaTLGzwY9G24tbiigLiXpmZWKwmcNDDs",
"host": "europe-west-1.tardigrade.io",
"port": 7777
},
"authoritative": true
},
{
"SatelliteURL": {
"id": "121RTSDpyNZVcEU84Ticf2L1ntiuUimbWgfATz21tuvgk3vzoA6",
"host": "asia-east-1.tardigrade.io",
"port": 7777
},
"authoritative": true
},
{
"SatelliteURL": {
"id": "118UWpMCHzs6CvSgWd9BfFVjw5K9pZbJjkfZJexMtSkmKxvvAW",
"host": "satellite.stefan-benten.de",
"port": 7777
},
"authoritative": false
},
{
"SatelliteURL": {
"id": "1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE",
"host": "saltlake.tardigrade.io",
"port": 7777
},
"authoritative": true
},
{
"SatelliteURL": {
"id": "12rfG3sh9NCWiX3ivPjq2HtdLmbqCrvHVEzJubnzFzosMuawymB",
"host": "europe-north-1.tardigrade.io",
"port": 7777
},
"authoritative": true
}
]
}
}
5 working satellites with one owner. This is single point of failure.
Itâs how you see it, but not what it is mean.
This model means the slow distributed network with hard coordination between peers, they must to have a consensus - see How to achieve a "Full decentralization" (distribution) without slow down again.
So, better to explain what you mean by this picture in reality.
We already have
Now we seems need to add âmore peer ownersâ. How much is enough?
That does not change the fact that it would be a separate network.
Letâs say a client uploaded some files using satellite A, which belongs to company X.
Company X goes out of business/is hacked/is bombed/etc.
The client cannot download his file using satellite B, belonging to company Y. While the data is still stored in the nodes, it is now impossible to access it.
It probably would be impossible to access data, uploaded using Tardigrade satellite europe-west if that satellite suffered a catastrophic failure. Even though Tardigrade operates other satellites.
So, probably the only real way to achieve independence with the current system would be for each client to run his own satellite. That, however, would be such a hassle compared to just storing the data on own servers.
If satellites would use an own distributed network and would exchange with data, will it become more decentralized?
I would say it would be not acceptable for customers. Do you want to operate a full node to access your data? If you simply need to restore your backup right now on that fresh server?
Why you take care of âslowâ when we talk about âMeaning of Decentralizationâ?
What do you mean by âslowâ and how it impacts decentralization?