Problem Statement

7 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$99.99
List Price:  $139.99
You save:  $40
€96.96
List Price:  €135.76
You save:  €38.79
£80.49
List Price:  £112.69
You save:  £32.19
CA$144.46
List Price:  CA$202.25
You save:  CA$57.79
A$160.83
List Price:  A$225.17
You save:  A$64.33
S$136.99
List Price:  S$191.80
You save:  S$54.80
HK$777.77
List Price:  HK$1,088.91
You save:  HK$311.14
CHF 90.85
List Price:  CHF 127.20
You save:  CHF 36.34
NOK kr1,136.39
List Price:  NOK kr1,591
You save:  NOK kr454.60
DKK kr723.41
List Price:  DKK kr1,012.81
You save:  DKK kr289.39
NZ$178.18
List Price:  NZ$249.46
You save:  NZ$71.28
د.إ367.26
List Price:  د.إ514.18
You save:  د.إ146.92
৳12,128.31
List Price:  ৳16,980.12
You save:  ৳4,851.81
₹8,576.54
List Price:  ₹12,007.50
You save:  ₹3,430.96
RM449.95
List Price:  RM629.95
You save:  RM180
₦154,533.88
List Price:  ₦216,353.62
You save:  ₦61,819.73
₨27,801.31
List Price:  ₨38,922.95
You save:  ₨11,121.63
฿3,449.55
List Price:  ฿4,829.51
You save:  ฿1,379.96
₺3,537.66
List Price:  ₺4,952.87
You save:  ₺1,415.20
B$618.15
List Price:  B$865.44
You save:  B$247.28
R1,871.01
List Price:  R2,619.49
You save:  R748.48
Лв189.93
List Price:  Лв265.91
You save:  Лв75.98
₩146,672.33
List Price:  ₩205,347.13
You save:  ₩58,674.80
₪364.92
List Price:  ₪510.90
You save:  ₪145.98
₱5,820.16
List Price:  ₱8,148.46
You save:  ₱2,328.30
¥15,718.92
List Price:  ¥22,007.12
You save:  ¥6,288.20
MX$2,062.93
List Price:  MX$2,888.18
You save:  MX$825.25
QR363.91
List Price:  QR509.49
You save:  QR145.58
P1,387.42
List Price:  P1,942.44
You save:  P555.02
KSh12,926.70
List Price:  KSh18,097.90
You save:  KSh5,171.20
E£5,077.49
List Price:  E£7,108.69
You save:  E£2,031.20
ብር12,747.15
List Price:  ብር17,846.53
You save:  ብር5,099.37
Kz91,190.88
List Price:  Kz127,670.88
You save:  Kz36,480
CLP$100,306.99
List Price:  CLP$140,433.80
You save:  CLP$40,126.81
CN¥731.98
List Price:  CN¥1,024.81
You save:  CN¥292.82
RD$6,097.60
List Price:  RD$8,536.88
You save:  RD$2,439.28
DA13,576.62
List Price:  DA19,007.81
You save:  DA5,431.19
FJ$232.59
List Price:  FJ$325.64
You save:  FJ$93.04
Q770.19
List Price:  Q1,078.30
You save:  Q308.10
GY$20,875.31
List Price:  GY$29,226.27
You save:  GY$8,350.96
ISK kr13,976.60
List Price:  ISK kr19,567.80
You save:  ISK kr5,591.20
DH1,006.87
List Price:  DH1,409.67
You save:  DH402.79
L1,858.26
List Price:  L2,601.64
You save:  L743.38
ден5,964.46
List Price:  ден8,350.49
You save:  ден2,386.02
MOP$799.84
List Price:  MOP$1,119.81
You save:  MOP$319.96
N$1,873.51
List Price:  N$2,622.99
You save:  N$749.48
C$3,673.10
List Price:  C$5,142.49
You save:  C$1,469.38
रु13,705.64
List Price:  रु19,188.44
You save:  रु5,482.80
S/374.69
List Price:  S/524.59
You save:  S/149.89
K399.88
List Price:  K559.85
You save:  K159.96
SAR375.52
List Price:  SAR525.74
You save:  SAR150.22
ZK2,780.17
List Price:  ZK3,892.35
You save:  ZK1,112.18
L482.45
List Price:  L675.45
You save:  L193
Kč2,440.45
List Price:  Kč3,416.73
You save:  Kč976.28
Ft40,319.96
List Price:  Ft56,449.56
You save:  Ft16,129.60
SEK kr1,111.16
List Price:  SEK kr1,555.68
You save:  SEK kr444.51
ARS$103,239.67
List Price:  ARS$144,539.67
You save:  ARS$41,300
Bs689.83
List Price:  Bs965.79
You save:  Bs275.96
COP$436,758.87
List Price:  COP$611,479.89
You save:  COP$174,721.02
₡50,884.43
List Price:  ₡71,240.24
You save:  ₡20,355.80
L2,537.04
List Price:  L3,551.96
You save:  L1,014.92
₲781,454.93
List Price:  ₲1,094,068.17
You save:  ₲312,613.23
$U4,391.87
List Price:  $U6,148.80
You save:  $U1,756.92
zł414.23
List Price:  zł579.94
You save:  zł165.71
Already have an account? Log In

Transcript

Hello, everyone. Welcome back to the course. In this session, we are going to discuss the consensus mechanism for the blockchain. This is one of the significant aspects and the unique selling point of blockchain consensus mechanism, make sure that there is a trust in the agreement, wherein all the parties agree on something to make it permanent over the blockchain. Unique consensus mechanisms has been designed to solve the problems and this is one of the reasons why blockchain is also getting so popular. In this session, we are going to discuss the Byzantine fault tolerance, which is used with the proof of work consensus.

Before we move into understanding details about Byzantine fault tolerance, let's understand what a consensus is. In elementary terms. We can define consensus as a voting mechanism where all the nodes connected to an Network vote on the validity of a block only then the block is confirmed over the blockchain. Till now we have seen that how a transaction gets executed, goes to the memory pool, and then is put inside a block. We have also learned how a block is created and miners do the nonce calculation to form the hash of the block. After the block has been built and confirmed over the blockchain, the block is broadcasted on the network for consensus.

Nodes connected to the network have the option to either include that transaction to their copy of ledger or to ignore it. When the majority of the nodes which comprise the network decide on a single state, the consensus is achieved. Let's understand consensus better by looking into the problem of two generals, which consensus is trying to solve let's first understand the major problem of The Internet which is the two generals problem. This problem defines the scheme where two generals are attacking an enemy. We can take one general as the leader and the other general has to follow. A general has their army.

But the strength of the military is not enough to defeat the enemy. They need to collaborate and attack at the same time to defeat the enemy. Now let's take a straight version of the problem where the enemy is located on a hilltop, and both the generals are present at the bottom of the hill on each side. Now to be successful, both the generals need to agree on a specific time for the attack. This can be achieved by sending a messenger across the hill to share the time of the attack. However, there is a probability that the enemy could capture this messenger and alter the message delivered to the other general this will lead to false attack The enemy, and both the generals will fail in their mission.

Even if somehow, one of the generals managed to send a messenger successfully over the hill to the other general. Still, the other general needs to acknowledge that they have received the message successfully. To provide the acknowledgement, the other general needs to send the messenger back through the enemy territory. The same scenario could be repeated for acknowledgment where the enemy could capture the messenger, and the message could be changed or never gets delivered to the first general. To confirm the acknowledgement. The first general again needs to send a real acknowledgement.

And this creates a never ending loop between the generals where they can never be sure that the message is correct. This is the current problem with our internet system. If two parties want to communicate anything among each other, then they need to go through the whole network space where multiple attackers might Present, they can attack the message or change the content of the message. The two general problem is non solvable problem. Now let's understand the two general problem with the help of a diagram. As you can see in the diagram, we have an enemy camp in the middle.

Gen one is on the left side of the enemy cam, and Gen two is on the right side of the enemy camp. Now to collaborate and fix a time of attack, they need to send a messenger through the enemy camp. This messenger could get caught in the enemy territory, and the message might be changed or never delivered to the general. Similarly, the other general needs to send back the acknowledgement, which again has to go through the enemy camp where the acknowledgement could be altered again, this is an ongoing process where the generals will never reach an agreement this to gender Problem is similar to how the internet is working. Whenever we are communicating with any party over the internet, we need to go through the enemy territory, which is the whole internet itself, containing the attackers. These attackers can take over the messages and change them as they desire.

They can also stop the message from delivering to the other party. The two general problem is non solvable problem related to the internet. A more generalized version of the two generals problem is related to the peer to peer network, which describes more than two generals attacking the enemy camp and agreeing on the time of the attack. Additionally, this problem states that one or more generals can be traitors, meaning that they can lie about their attack choice and the attack might never take place. To reach consensus in such a problem. General needs to agree on On the same decision, as we mentioned before, one general will be the leading general who issues the command, and the other generals will accept the same.

So instead of general approach, let's take a commanding general and lifting hands based approach. We're Commanding General, issues an order of attack, and every lawyer left in and needs to follow the order. solution to such problem was provided in the paper, the Byzantine generals problem by Leslie lamport, Robert shostack, and Marshall piece, which proves that the system can reach a consensus. As long as two by three of the actors are honest, if the traitors are more than one by three, the consensus is not reached, the armies are not able to coordinate their attack and the enemy events. If the commander is a traitor, the consensus is still achieved. But all the left end take the majority vote over the default value of the attack.

Instead of following the commander now let's go in understand how this problem can be solved using the Byzantine fault tolerance.

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.