Skip to main content

What’s the difference between Decentralized and Distributed ?

The terms ‘decentralized’ and ‘distributed’ are often used when talking about blockchains — and often confused, for the difference is not always obvious.

Bitcoin’s blockchain protocol, for instance, is a decentralized system for exchanging digital cash — but it’s also an example of distributed ledger technology. What’s going on?

  • Centralization and decentralization refer to levels of control.

In a centralized system, control is exerted by just one entity (a person or an enterprise, for example). In a decentralized system, there is no single controlling entity. Instead, control is shared among several independent entities.

  • Distribution refers to differences of location.

In a non-distributed (or co-located) system, all the parts of the system are in the same physical location. In a distributed system, parts of the system exist in separate locations.

Allow me to clarify using examples.

Imagine you are writing a document using the Microsoft Word application on a PC running the Microsoft Windows operating system. This setup is both centralized and non-distributed. One entity, Microsoft, controls your application and operating system (centralized). Both the application and the operating system are located on your PC, i.e. in one physical location (non-distributed).

Now, suppose you run an open source operating system like Linux on your PC with open source word-processing software. Different people and organizations contribute to the evolution of both items (the setup is now decentralized). On the other hand, you are still using one physical PC to run all the software (it’s still non-distributed).

A distributed, but centralized system may sound contradictory, but if we use the definitions above based on control and location, we’ll see how this works. Consider a cloud service provider offering a data storage service. Physically, your data could be shared and replicated on different machines according to resource availability and resiliency(distributed). However, wherever the machines and data storage facilities happen to be, the cloud service provider still controls them all (centralized).

That leaves one last case, which is the decentralized and distributed system. We’ll use Bitcoin as our example. Bitcoin is a blockchain system that cannot be altered by any one entity (decentralized). It also runs as a peer-to-peer network of independent computers spread across the globe (distributed).

We can now make more sense out of discussions about how much certain blockchains are truly decentralized or distributed.

Whereas public blockchains tend to be decentralized, private blockchains are typically controlled by one entity like an enterprise. Some people then suggest that private blockchains should not be called blockchains, for this reason (i.e., they are centralized).

Decentralized blockchains using a mining consensus system like proof of work may lose their decentralization if one miner (or group of miners) becomes more powerful than all the others, leading to the threat of a 51% attack.

Cryptocurrency exchanges serving users of otherwise decentralized blockchains may introduce centralization and risk. Consider the Mt. Gox exchange, once the largest online exchange for users to buy and sell Bitcoins. It was controlled by one entity, lacked security, and was hacked several times before it finally shut down.

Even the ‘decentralized-by-design’ blockchains of Bitcoin and Ethereum have been rated as ‘not particularly decentralized’ in a study conducted at Cornell University. The study found that power was concentrated among relatively few miners or mining pools. It also considered these blockchains to be less distributed than one might think, with many blockchain nodes physically located in just a few large data centers .

To conclude, there are degrees of decentralization and distribution, rather than hard divisions. How much decentralization or distribution is desirable then depends on your objectives. Hopefully with the definitions given here, you’ll be able to have a meaningful discussion on the matter and a constructive exchange of points of view.

Comments

Popular posts from this blog

OWASP Top 10 Threats and Mitigations Exam - Single Select

Last updated 4 Aug 11 Course Title: OWASP Top 10 Threats and Mitigation Exam Questions - Single Select 1) Which of the following consequences is most likely to occur due to an injection attack? Spoofing Cross-site request forgery Denial of service   Correct Insecure direct object references 2) Your application is created using a language that does not support a clear distinction between code and data. Which vulnerability is most likely to occur in your application? Injection   Correct Insecure direct object references Failure to restrict URL access Insufficient transport layer protection 3) Which of the following scenarios is most likely to cause an injection attack? Unvalidated input is embedded in an instruction stream.   Correct Unvalidated input can be distinguished from valid instructions. A Web application does not validate a client’s access to a resource. A Web action performs an operation on behalf of the user without checkin...

CKA Simulator Kubernetes 1.22

  https://killer.sh Pre Setup Once you've gained access to your terminal it might be wise to spend ~1 minute to setup your environment. You could set these: alias k = kubectl                         # will already be pre-configured export do = "--dry-run=client -o yaml"     # k get pod x $do export now = "--force --grace-period 0"   # k delete pod x $now Vim To make vim use 2 spaces for a tab edit ~/.vimrc to contain: set tabstop=2 set expandtab set shiftwidth=2 More setup suggestions are in the tips section .     Question 1 | Contexts Task weight: 1%   You have access to multiple clusters from your main terminal through kubectl contexts. Write all those context names into /opt/course/1/contexts . Next write a command to display the current context into /opt/course/1/context_default_kubectl.sh , the command should use kubectl . Finally write a second command doing the same thing into ...