Skip to content

Latest commit

 

History

History
100 lines (73 loc) · 3.5 KB

adr-037-deliver-block.md

File metadata and controls

100 lines (73 loc) · 3.5 KB

ADR 037: Deliver Block

Author: Daniil Lashin (@danil-lashin)

Changelog

13-03-2019: Initial draft

Context

Initial conversation: https://github.com/tendermint/tendermint/issues/2901

Some applications can handle transactions in parallel, or at least some part of tx processing can be parallelized. Now it is not possible for developer to execute txs in parallel because Tendermint delivers them consequentially.

Decision

Now Tendermint have BeginBlock, EndBlock, Commit, DeliverTx steps while executing block. This doc proposes merging this steps into one DeliverBlock step. It will allow developers of applications to decide how they want to execute transactions (in parallel or consequentially). Also it will simplify and speed up communications between application and Tendermint.

As @jaekwon mentioned in discussion not all application will benefit from this solution. In some cases, when application handles transaction consequentially, it way slow down the blockchain, because it need to wait until full block is transmitted to application to start processing it. Also, in the case of complete change of ABCI, we need to force all the apps to change their implementation completely. That's why I propose to introduce one more ABCI type.

Implementation Changes

In addition to default application interface which now have this structure

type Application interface {
    // Info and Mempool methods...

    // Consensus Connection
    InitChain(RequestInitChain) ResponseInitChain    // Initialize blockchain with validators and other info from TendermintCore
    BeginBlock(RequestBeginBlock) ResponseBeginBlock // Signals the beginning of a block
    DeliverTx(tx []byte) ResponseDeliverTx           // Deliver a tx for full processing
    EndBlock(RequestEndBlock) ResponseEndBlock       // Signals the end of a block, returns changes to the validator set
    Commit() ResponseCommit                          // Commit the state and return the application Merkle root hash
}

this doc proposes to add one more:

type Application interface {
    // Info and Mempool methods...

    // Consensus Connection
    InitChain(RequestInitChain) ResponseInitChain           // Initialize blockchain with validators and other info from TendermintCore
    DeliverBlock(RequestDeliverBlock) ResponseDeliverBlock  // Deliver full block
    Commit() ResponseCommit                                 // Commit the state and return the application Merkle root hash
}

type RequestDeliverBlock struct {
    Hash                 []byte
    Header               Header
    Txs                  Txs
    LastCommitInfo       LastCommitInfo
    ByzantineValidators  []Evidence
}

type ResponseDeliverBlock struct {
    ValidatorUpdates      []ValidatorUpdate
    ConsensusParamUpdates *ConsensusParams
    Tags                  []kv.Pair
    TxResults             []ResponseDeliverTx
}

Also, we will need to add new config param, which will specify what kind of ABCI application uses. For example, it can be abci_type. Then we will have 2 types:

  • advanced - current ABCI
  • simple - proposed implementation

Status

In review

Consequences

Positive

  • much simpler introduction and tutorials for new developers (instead of implementing 5 methods whey will need to implement only 3)
  • txs can be handled in parallel
  • simpler interface
  • faster communications between Tendermint and application

Negative

  • Tendermint should now support 2 kinds of ABCI