Blockchain for Business with Hyperledger Fabric: A complete guide to enterprise blockchain implementation using Hyperledger Fabric
By Nakul Shah
()
About this ebook
The book starts with a brief introduction to the world of blockchain. The book will cover all aspects of fabric ranging from network setup, to use case deployment and testing. Several examples have been covered in this book which will provide you a hands-on understanding of the subject. You will also learn to use the basic functions, libraries and packages required in a Fabric business network deployment.
Related to Blockchain for Business with Hyperledger Fabric
Related ebooks
Building Decentralized Blockchain Applications: Learn How to Use Blockchain as the Foundation for Next-Gen Apps (English Edition) Rating: 0 out of 5 stars0 ratingsBlockchain From Concept to Execution Rating: 0 out of 5 stars0 ratingsHyperledger Fabric In-Depth: Learn, Build and Deploy Blockchain Applications Using Hyperledger Fabric Rating: 0 out of 5 stars0 ratingsSmart Contract Development with Solidity and Ethereum: Building Smart Contracts with the Azure Blockchain Rating: 0 out of 5 stars0 ratingsDeep Learning for Data Architects: Unleash the power of Python's deep learning algorithms (English Edition) Rating: 0 out of 5 stars0 ratingsCommercializing Blockchain: Strategic Applications in the Real World Rating: 0 out of 5 stars0 ratingsMetaverse and Web3: A Beginner’s Guide: A Digital Space Powered with Decentralized Technology (English Edition) Rating: 0 out of 5 stars0 ratingsMicroservices by Examples Using .NET Core: Using .NET Core Rating: 0 out of 5 stars0 ratingsMastering Cloud-Native Microservices: Designing and implementing Cloud-Native Microservices for Next-Gen Apps (English Edition) Rating: 0 out of 5 stars0 ratingsDesigning Microservices using Django: Structuring, Deploying and Managing the Microservices Architecture with Django Rating: 0 out of 5 stars0 ratingsBlockchain: The Untold Story: From birth of Internet to future of Blockchain Rating: 0 out of 5 stars0 ratingsBlockchain in e-Governance: Driving the next Frontier in G2C Services (English Edition) Rating: 0 out of 5 stars0 ratingsEthereum Blockchain Developer - The Bootcamp Rating: 5 out of 5 stars5/5Blockchain Consortium The Ultimate Step-By-Step Guide Rating: 0 out of 5 stars0 ratingsBuilding Full Stack DeFi Applications: A practical guide to creating your own decentralized finance projects on blockchain Rating: 0 out of 5 stars0 ratingsThe WEALTHTECH Book: The FinTech Handbook for Investors, Entrepreneurs and Finance Visionaries Rating: 0 out of 5 stars0 ratingsBlockchain Simplified: A Comprehensive Beginner's Guide to Learn and Understand Blockchain Technology Rating: 0 out of 5 stars0 ratingsBlockchain Technologies Rating: 0 out of 5 stars0 ratingsBlockchain As A Service A Complete Guide - 2020 Edition Rating: 0 out of 5 stars0 ratingsThe Solidity Programmer's Handbook Rating: 0 out of 5 stars0 ratingsHyperledger Fabric A Complete Guide - 2021 Edition Rating: 0 out of 5 stars0 ratingsQuick Guide for Smart Contracts Creation and Deployment on Ethereum Blockchain Rating: 0 out of 5 stars0 ratingsI Don't Trust You: But Blockchain and Bitcoin Will Help Rating: 0 out of 5 stars0 ratings
Enterprise Applications For You
Access 2019 For Dummies Rating: 0 out of 5 stars0 ratingsQuickBooks 2024 All-in-One For Dummies Rating: 0 out of 5 stars0 ratingsExcel : The Ultimate Comprehensive Step-By-Step Guide to the Basics of Excel Programming: 1 Rating: 5 out of 5 stars5/5Excel Formulas That Automate Tasks You No Longer Have Time For Rating: 5 out of 5 stars5/5QuickBooks 2023 All-in-One For Dummies Rating: 0 out of 5 stars0 ratingsExcel 101: A Beginner's & Intermediate's Guide for Mastering the Quintessence of Microsoft Excel (2010-2019 & 365) in no time! Rating: 0 out of 5 stars0 ratingsQuickBooks Online For Dummies Rating: 0 out of 5 stars0 ratingsBitcoin For Dummies Rating: 4 out of 5 stars4/5Learning Microsoft Endpoint Manager: Unified Endpoint Management with Intune and the Enterprise Mobility + Security Suite Rating: 0 out of 5 stars0 ratingsCreating Online Courses with ChatGPT | A Step-by-Step Guide with Prompt Templates Rating: 4 out of 5 stars4/5Excel 2019 Bible Rating: 5 out of 5 stars5/5Excel Data Analysis For Dummies Rating: 0 out of 5 stars0 ratingsManaging Humans: Biting and Humorous Tales of a Software Engineering Manager Rating: 4 out of 5 stars4/5102 Useful Excel 365 Functions: Excel 365 Essentials, #3 Rating: 0 out of 5 stars0 ratingsExcel All-in-One For Dummies Rating: 0 out of 5 stars0 ratingsQuickBooks 2021 For Dummies Rating: 0 out of 5 stars0 ratingsCode like a Pro in C# Rating: 0 out of 5 stars0 ratingsPowerShell Troubleshooting Guide Rating: 0 out of 5 stars0 ratingsExcel for the Math Classroom Rating: 5 out of 5 stars5/5Experts' Guide to OneNote Rating: 5 out of 5 stars5/5Excel Tables: A Complete Guide for Creating, Using and Automating Lists and Tables Rating: 5 out of 5 stars5/5Excel 2019 For Dummies Rating: 3 out of 5 stars3/5Learn Windows PowerShell in a Month of Lunches Rating: 0 out of 5 stars0 ratingsEnterprise AI For Dummies Rating: 3 out of 5 stars3/5Learning Python Rating: 5 out of 5 stars5/5Excel Formulas and Functions 2020: Excel Academy, #1 Rating: 3 out of 5 stars3/5
Reviews for Blockchain for Business with Hyperledger Fabric
0 ratings0 reviews
Book preview
Blockchain for Business with Hyperledger Fabric - Nakul Shah
Blockchain and Decentralization
After World War II, organizations started leveraging databases for their operations. As the use of databases increased, companies realized there was a need to share this data—both, within an organization as well as across companies all over the globe. The Internet revolutionized the process of sharing data by making it seamless to exchange information. It also opened doors for new possibilities in the world of digitization, like Internet banking, social media, online ticketing, and more.
However, since the inception of the Internet, there has always been a need for realtime, low-cost connectivity and exchange of money (or value) through some form of the Internet of trust.
Trust has always been a missing element within the Internet. Trust is what the banks and other financial institutions laid their foundations on. Since people couldn't trust each other with their money, they would go to the banks hoping that the bank would keep their money safe and give it back when requested. This trust shook up during the global meltdown of 2008. As banks began to collapse, people started losing their trust in banks and realized the need for a reliable e-cash system through which two people could exchange value without the need for a central counterparty, to mitigate fraud. Thus, people wanted to exchange money the way they exchange information over the Internet. This hope became a reality in 2008 when a white paper went viral over the Internet. The paper described the working of Bitcoin, which was a protocol that allowed people to exchange value (in the form of cryptocurrency) without the need of any central authority and outside the control of any government or jurisdiction. Since its early days, Bitcoin has always stayed in the grey area, with central authorities debating about its legality and a surge in Bitcoin's use on the dark web.
While this parallel debate was going on regarding the legality of Bitcoin, some financial institutions started looking under the cover. They wanted to understand the technology that was making their existence moot—a technology that enabled people to transfer value, across borders, without the need for central authorities like banks, and with no failures or frauds. Thus, blockchain came to the forefront. Blockchain is the technology that underpins Bitcoin. It is a decentralized distributed transaction database to which you can write new data, but you can never edit or delete it. It is immutable!
In this chapter, we will focus on the following key topics:
Background of Bitcoin and blockchain
Working of blockchain and its key concepts
Operation of wallets and the role played by mining in running a blockchain network
Building blocks of a blockchain and structure of a block
Decentralization and distributed systems
Enterprise blockchain networks
Difference between public and private blockchain
This would help lay the foundation as we move towards Hyperledger, which is one of the most widely used enterprise blockchain platforms.
Definitions
Let us start by defining certain important terms that would be used repeatedly in this book. These terms are used as common jargon while discussing blockchain and would thus benefit you in understanding the chapters better:
Cryptocurrency
It is defined as any digital or virtual currency leveraging cryptography for security. Many researchers, financial institutions, academics, and others are considering cryptocurrency as the money of future or a twenty-first-century unicorn. Cryptocurrencies are based on blockchain technology using decentralized systems.
A striking feature of cryptocurrencies is they are neither issued by a government authority nor controlled by any organization. This makes them immune to third-party interventions or manipulations. The first blockchain-based cryptocurrency, conceptualized in 2008, was bitcoin.
Main features of a cryptocurrency are as follows:
It serves as a digital asset that is used as a medium of exchange.
It controls supply and secures transactions by use of advanced cryptography. These cryptography techniques are comprised of hash functions and digital signatures.
It is a subset of alternate currencies.
The underlying technology that enables the exchange of digital coins or assets between individuals is termed as blockchain.
Bitcoin
The term crypto refers to encryption algorithms and techniques like public key/ private key pairs. These technologies were combined with hash functions to develop the first well-known (and currently most popular) cryptocurrency called bitcoin that was launched in 2008-09 by an individual/corporation under the pseudonym Satoshi Nakamoto.
Bitcoin was released as virtual money or token with an intent to disrupt the financial markets and as an alternative to paper-based currency. It leverages a collection of cryptographic concepts and blockchain technology to store and transmit value among users.
Bitcoin's modus operandi is a combination of the following key components:
Proof-of-Work (PoW) consensus algorithm that serves as a decentralized peer-to-peer network.
Blockchain technology that is used as a transaction ledger.
A decentralized and mathematically bound mining and token issuance method.
A verification method used with the help of transaction scripts.
Blockchain
The best way to define a blockchain is by drawing an analogy between a blockchain and a commuter train. We are all aware of how a train moves to transport people— it is structured in the form of multiple compartments and each compartment is linked to the next. Thus, if one compartment is removed from the middle of a train, the entire train will collapse because of loss of connectivity. A blockchain operates in a similar manner. It consists of blocks (instead of compartments) that are connected in a linear fashion such that each block, apart from carrying its own data, also has a signature (in the form of a hash function) to the previous block. This ties a new block to the previous one. If one of the blocks is removed from the blockchain, the entire chain will collapse because of loss of connectivity, just like in a train.
The first type of blockchain, that is, Blockchain 1.0, comprised of simple ledgers that could only record transactions. This basically refers to the Bitcoin blockchain that was implemented to simply record transactions in an immutable manner. As Bitcoin gained popularity, the industry realized that a blockchain is capable of much more. Thus, Blockchain 2.0 evolved where smart contracts were created. Smart Contract is a framework that enables users to execute logical code for various programs on a blockchain. Thus, several operations can run on this new technology. This concept came to market with the advent of Ethereum. Now, enterprises are looking at leveraging blockchain and distributed ledger technologies to create enterprise-grade applications. One of the most widely used environments for this is Hyperledger, which we will cover in detail in the later chapters of this book.
Following are some of the commonly used definitions of blockchain:
A blockchain is a distributed database of records or public ledger of all transactions or digital events that have been executed and shared among participating parties.
A blockchain is referred to as a peer-to-peer distributed ledger that has a cryptographically calculated algorithm with consensus (like PoW) that makes it immutable.
A blockchain is defined as a data structure with a linked-list-format connecting blocks of transactions.
How Bitcoin works
Bitcoin allows people to send money (or value in the form of tokens) in a way that is similar to sharing information via an email or text—that is, online! To understand how a transaction takes place within the Bitcoin network, let's consider an example. User A wants to transfer 5 bitcoins to User B. Following are the steps that need to be followed to settle the transaction:
Step 1: User A and User B need to create their wallets. Thus, each user will have their own unique public and private key pair (also called addresses).
Step 2: User A (sender) requests the public key/address of User B (receiver) and sends bitcoins (or any other cryptocurrency).
Step 3: The transaction is confirmed and recorded within the blockchain ledger.
These transactions are recorded using a large distributed set of computers over the Internet. This network is neither closed nor under the control of one party. As soon as User A (from the preceding example) initiates the transfer of bitcoins to User B, a transaction message is generated and sent across the blockchain network. The transaction message contains the time, date, participants' unique wallet addresses, and the amount. This message is encrypted using the sender's unique private key known only to the sender. When the new transaction is sent to the network, each node verifies the transaction using a complicated state-of-the-art technology, which is based on mathematics. Each node of the blockchain tests the signature by trying to decrypt it. If successful, they know that the true account owner created the signature. The mathematical principle also ensures that nodes automatically and continuously reach consensus about the current state of the ledger and every transaction in it.
The nodes are distributed all across the globe, and each node contains a copy of the exact same ledger. The maintainers of these nodes are called miners. Thus, when a new message with a valid signature is sent, each miner updates their personal ledger with the transaction information. Since these ledgers are distributed, traffic delays lead to differences in the ledger. Thus, for the world to decide which version of the ledger to use, a kind of voting system is followed. But unlike traditional voting, which involves ballot boxes, blockchain technology relies on mathematical puzzles that each miner has to solve. The first miner to solve the puzzle broadcasts the solution and everybody updates to that solution, making the vote a mathematical race.
The private keys serve like signatures on a cheque book. But instead of relying on handwriting, it relies on mathematics to ensure the integrity of the blockchain. Thus, if someone tries to send an unauthorized transaction, the nodes will not reach consensus, refusing to incorporate the concerned transaction into the blockchain. This way every node of the blockchain contains the entire copy of the ledger right from the genesis block (which is the first block ever mined) to the most recent block. Thus, everyone has access to a shared single source of truth called blockchain, which we can trust with the authenticity of all the transactions ever made.
Bitcoin is not similar to traditional banking or payment systems. In the traditional transaction method, a centralized authority keeps track of money, but in the Bitcoin system, there is no issuance authority. Instead, all tracking and settlement are achieved by cryptographic concepts and blockchain technology over a network maintained by the participants themselves.
Wallets
Before using bitcoins, the user needs to install a wallet. A digital wallet is required because bitcoins only exist in a digital, and not physical form.
Following are some types of wallets:
Software wallet: It is a Bitcoin application that can be downloaded on the computer and allows users to control and secure their bitcoins.
Web wallet: Web wallets refer to wallets owned by third-party platforms like exchanges. Web wallets are more convenient than software wallets since they can be accessed from any device by use of your private key or password.
Cold wallet: Cold wallet refers to any wallet that is not connected to the Internet. It can be a piece of paper with your private key on it, or you can have wallets on USB drives, and so on.
Hardware wallet: There are companies who have created hardware devices to store private keys. Every time a user wants to transact, they need to plug the hardware wallet into the computer so the private key gets connected to the Internet, thereby allowing the user to access their bitcoins. When unplugged, the connections breaks, and bitcoins can no longer be transacted.
Multi-signature wallets: In this kind of wallet, one wallet has multiple private keys, and only a combination of those keys can open that wallet. Thus, it serves as an escrow account.
Basics of blockchain
A blockchain serves as a ledger that collects and records transactions validated by the network in elementary units called blocks. Once validated by the network's consensus mechanism, these blocks are added to an existing sequential chain of cryptographic hash-linked blocks, to ensure the integrity of the data—thus the name blockchain. Often people get confused between Bitcoin and blockchain and use the terms interchangeably. However, this is a misconception! Bitcoin is a cryptocurrency that uses the blockchain technology to record all valid transactions across the network. Thus, Bitcoin is merely one of the applications of blockchain.
Mining in blockchain
The process of creating a block, validating transactions, and recording the block with transaction details is referred to as mining. These transactions are recorded in a block through hashing, which is a method of converting text (or any data) of any length to a fixed-length value. All the transactions in a blockchain are hashed using the SHA-256 algorithm. SHA-256 always consists of 64 symbols and is 256 bytes in size.
Figure 1.1 shows the word Hello with different hash values:
Figure 1.1
The purpose of mining is to calculate the hash for every block that is generated. However, the rise in miners increases the computing power required to create an individual block. The maximum time for generating a block within the Bitcoin blockchain is 10 minutes. The level of mining difficulty is automatically calculated and adjusted every 2016 blocks. This has been ingrained within the Bitcoin code.
Each block includes the following fields:
A random number (hash value), block size, block header, a transaction counter, and transactions that contain information about all transactions confirmed in the block.
The block header has the following components: version, previous block header hash, Merkle root hash, timestamp, difficulty target, and nonce value.
Merkle root is the topmost hash in the block of transactions and is calculated using the Merkle tree algorithm, also called a binary hash tree. The steps to compute the same are as follows:
Step 1: Compute hashes for all the transactions in a block.
Step 2: Divide the transactions into pairs, and calculate the hash for every pair.
Step 3: Continue the above step until a single hash code is created, which is called the root.
Figure 1.2 is a Merkle binary hash tree:
Figure 1.2
Cryptography
All information/data in Bitcoin, Ethereum, and other blockchain platforms is verified by a signature produced using the Elliptic Curve Digital Signature Algorithm (ECDSA). This algorithm uses cryptography as the main asset.
The method of signing and verifying a transaction is executed through cryptography keys. There are two types of keys—a private key that is used for signing a transaction and a public key used to verify it. A private key is randomly generated when a wallet is created. A public key is mathematically derived from the private key using elliptic curve multiplication on a finite field. The private key is meant to be known only to the person who signs the transaction. The public key, on the other hand, is available to anyone who wants to verify the same.
Let's consider an example:
Two people A and B want to transfer some information through the Internet. Each holds a private key/public key pair. The prime use of cryptography is to create a secure digital transaction. Thus, A will send the information to B using B's public key. Upon receiving this encrypted information, B will decrypt the same using her private key. Encryption is the core concept used in cryptography as it renders the message unreadable for others on the network, who lack appropriate permission. Two types of encryptions are symmetric cryptography and asymmetric cryptography:
Symmetric cryptography uses one key for both encryption and decryption.
Asymmetric cryptography needs two keys—a public key and a private key. The private key is not supposed to be shared, making it more secure compared to symmetric cryptography.
The major components used in a blockchain are as follows:
P2P network: A peer-to-peer network (P2P) helps maintain a consistent copy of the distributed ledger. All transactions captured on the blockchain are maintained across the network of nodes running the blocks within the distributed ledger.
Private key cryptography: This component is used by a blockchain for security and hash functions that make it immutable.
Blockchain program: This component is used by a blockchain as a protocol to execute steps that make it secure.
Building blocks of blockchain
Let us understand the concept one by one.
Blocks
If we consider a blockchain to be a ledger or a book, each block would represent a table or a page, respectively, which records a collection of confirmed transactions.
Each block stored in the blockchain is uniquely identified by a hash and is composed of a header and body.
Figure 1.3
The header contains information about its creation like time stamp, Merkle root, nonce, difficulty target, version, and a reference to the previous block. The body is a collection of approved transactions. Once a block is successfully validated (mined), it becomes part of the main chain:
Figure 1.4
Transactions
Transactions are the most fundamental building blocks of the blockchain system. They represent the transfer of value (cryptocurrency) within the blockchain network between two addresses.
Before creating a transaction, the sender signs it using her private key (managed by their wallet) and specifies the destination address. Digital signatures and public keys are used to enable network users to validate the transaction and check whether the sender has the right to spend the bitcoins held by a specific address.
Smart contracts
Smart contracts are one of the most exciting concepts in blockchain technology, representing self-executing scripts stored on the blockchain itself. A smart contract takes the blockchain concept to the next stage, enabling it to translate business logic into inviolable contract terms, which can be autonomously executed without relying on a broker, lawyer, or other intermediaries.
Virtual machine
A virtual machine is a logical element implemented as part of a node application that every participant in the ecosystem runs. In order to understand the concept of virtual machine, let's draw an analogy with our regular computer. When a physical computer runs a computer program, the instructions in the program tell the computer to change its state. The change of state is identified by the user either by a dialog box, sound, or other means of transmission. A virtual machine is a representation of a machine (real or imaginary) created by a computer program and operated with instructions embodied in code. It is an abstraction of a machine, held inside a machine. Ethereum is a blockchain ecosystem that, like Bitcoin, implements a virtual machine. The virtual machine lives in the Ethereum node application called a wallet, and unlike Bitcoin, it can