Skip to content
This repository has been archived by the owner on Aug 13, 2024. It is now read-only.

KIP-55 BlockGeneration Policy Core Consensus change proposals #55

Open
wants to merge 5 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
138 changes: 138 additions & 0 deletions KIPs/kip-1000.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,138 @@
---
kip: 1000
trustfarm-dev marked this conversation as resolved.
Show resolved Hide resolved
title: Klyatn Block generation consensus change proposals
author: KT Ahn "안씨아저씨" <[email protected]>
status: Draft
type: Core
category:
created: 2021-03-23
requires: None
---

## Simple Summary

한글로 된 버전은 클레이튼 [포럼의 토픽 #790](https://forum.klaytn.com/t/topic/790) 을 참조하여 주세요.


Current Klyatn Consensus block generation scheme has target on 1block / 1seconds.
trustfarm-dev marked this conversation as resolved.
Show resolved Hide resolved
It is very ideal for fast payments confirm and one finality.
But, It makes burden on validator nodes and endpoint nodes.
And, Almost block has 0 TX.

This IP(Improvement Proposal) is make klaytn networks more broaden and less burden on nodes.
Change default max (deadline) blocktime to 30seconds, and if there's at lease one of TX in TXpool, then generate blocks. it means 1tx/1block/1seconds or 1tx/1block/3seconds ... deadline 30seconds generate blocks.

1Block/1Seconds It makes consume the P2P Network Bandwidth Overhead and Computing power overheads.
because of so heavy block generation makes heavy block overhead itself.

Thus, It is one of big barrier for expand Klaytn ECO.
It means that whose hope to participates on Klyatn , they needs to spend many money for spend high performance node instance fees or high cost hw.

Also, beginner or no technition , it is hard to join the networks, even though they have good willings on klaytn.

So, it will finally blocking the Every nodes participates on Klaytn networks.
TX and Block increases remained nodes will very small (except klaytn organization and closed partners).
It will hazardous states on Klaytn blockchain networks, even though Klyan stance semi-public network or almost private domain network.

## Abstract

This standard outlines a apply deadline block generation policy.
In the aspect of many reasons for improve Klaytn networks.
Above [## Simple Summary] describes all.

## Motivation

Recent days, Klaytn has more interested on investors, developers, thirdparty company.
they have saying the slow sync problem.
I also tried to sync latest Klaytn EndPoint Node, very longer time spend, compared to Ethereum based chains. Compare with Overall TX counts.

## Specification

1. Deadline blocktime to 30 seconds.
2. if there's no TX , not generates block.
3. if there's atleast 1 TX generates block within deadline time.

Pseudo Code of KIP-1000 consensus.
`C` language Style

```
struct SimpleBlockInfo {
bignumber blocknumber;
bytes512 blockhash;
datetime generatetime;
};
struct SimpleBlockInfo __G_lastBlockinfo;

void updateLastBlockInfo(BlockObj Block)
{
__G_lastBlockinfo.blocknumber = Block->blocknumber;
memcpy( <<ptr>> (__G_lastBlockinfo.blockhash) , Block->blockhash , 512);
__G_lastBlockinfo.generatetime = Block->generatetime;
}

struct SimpleBlockInfo <<ptr>> getLastBlockInfo( struct <<ptr>>lastBlockinfo )
{
lastBlockinfo->blocknumber = __G_lastBlockinfo.blocknumber;
memcpy( <<ptr>> (lastBlockinfo->blockhash) , <<ptr>> __G_lastBlockinfo.blockhash , 512);
lastBlockinfo->generatetime = __G_lastBlockinfo.generatetime;
return <<ptr>> lastBlockinfo; // self referencing pointer for outer function usability
}

OnBlockReceived( BlockObj Block)
{
// updates blockinformation
updateLastBlockInfo(Block);

// ToDo :: legacy jobs.
...
}

OnBlockGeneration( BlockObj newBlock ) {
// check conditions
// 1> timehas spend over 30Seconds or not
// 2> check TXpool is not empty
// 3> is this newblocknumber and blockhash is different than lastblock

struct SimpleBlockInfo lastBlockinfo;

getLastBlockInfo( <<ptr>>lastBlockinfo );

// check blocknumber and blockhash
if ( (lastBlockinfo.blocknumber == newBlock->blocknumber)
|| (lastBlockinfo.blockhash == newBlock->blockhash ) )
{
debugLog("new block is same as last one ", newBlock->blocknumber , "\n");
return;
}

// check Time Spend 30Seconds deadline
if ( diffTime( now(), lastBlockinfo.generatetime) >= 30 )

// TODO :: GenerateBlock()
LegacyGenerateBlock(newBlock);

updateLastBlockInfo(newBlock);
return;
)

// check TX has empty or not
if ( (newBlock->TxPool->count == 0) || (newBlock->TxPool->Txlist == NULL) )
return;

// TODO:: GenerateBlock()
LegacyGenerateBlock(newBlock);

updateLastBlockInfo(newBlock);
return;
}

```


## History

1. First Draft :: reference ideation and suggestion links [Forum Topic #790](https://forum.klaytn.com/t/topic/790)

## Copyright

Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).