Blockchain Protocol Series — Introduction

Alex Oberhauser
The Blockchain
Published in
3 min readMay 24, 2015

--

This article is the first in a series of blog posts that investigate and describe a unified blockchain protocol. Such a protocol should be reusable for all different kinds of blockchains. The underlying assumption is that such a shared protocol exists and that a “standardization” simplifies the creation of new, domain-specific, blockchains, without the need to reproduce each time the low-level design and implementation part.

Outline

The blog series starts with an introduction why a blockchain protocol is needed and gives a first overview about the two conceptual parts, the low- and high-level protocol. The two consecutive posts describe them in more detail. After the theoretical specification a new post introduces the reference implementation, implemented in a specifically for this purpose developed framework. In the last post the framework is described.

  1. Introduction: Introduces the idea and outlines the structure. The post that you are currently reading.
  2. Low-Level Protocol: Node to node communication and message format.
  3. High-Level Protocol: Blockchain overlay network management and blockchain data exchange strategy.
  4. Implementation: Reference implementation in the blockchain software framework.
  5. Software Framework: The introduced framework from the previous post is explained in more detail.

The need for such a Protocol

The internet would not be such a big success without the underlying protocol stack, also known as OSI model. This protocol stack allows communication between hosts across geographical regions, organizations and domains, without the need to negotiate each time the communication means. It makes the internet as we know it possible. With this analogy in mind we can see the blockchain protocol as extension to the current OSI layer. The new layer adds economic and social value exchange to the mix. The main purpose is to have an unified, but not limiting, protocol that allows the development of blockchain applications, the same way as web application are developed today. The main driving factors to standardize the protocol is interoperability between participating nodes, and that across all kind of blockchains, and simplicity for the development of new blockchains, without the need to reproduce low level and generic implementations.

Where does it fit in?

OSI 7 Layer Model with Blockchain Protocols

The following image shows the two types of new layers on top of the OSI model. The lowest level, the Blockchain Message Exchange, is similar to TLS. It specifies a handshake logic to agree on the right protocol and assures compatibility between nodes. It further specifies and serializes the binary packages that are sent over the wire. This protocol could be part of the operating system or any lower level implementation, e.g. hidden inside a library.

The next layer, on top, is the Blockchain Overlay Network. It contains higher level functionality, like discovery of new and management of overlay networks related to blockchains. This layer abstract away from the underlying blockchain management and allows to manage multiple blockchains at the same time. This part will be most likely designed as middleware, with a clear interface for the development of new blockchains.

What next?

In this article the idea to abstract away from the underlying implementation was introduced. In the next few blog posts this idea is described in more detail.

The main purpose of this series is to trigger a discussion and propose solutions.

--

--

Alex Oberhauser
The Blockchain

Founding CEO of @Sigimera and Creator of @BTCFunding - Tech-Entrepreneuer, Blockchain Engineer, Citizen of the World and Inhabitant of the Cyberspace