tendermint區塊鏈五分鐘入門

ezpod發表於2019-01-09

區塊鏈應用已經從單純電子現金髮展到去中心化投票等更多的領域,但是區塊鏈這樣的分散式系統的開發還存在一些困難的問題:安全、可靠性、敏捷度、以及一致性保證等等。Tendermint的目的就是致力於解決分散式系統開發中像公示演算法這樣的技術難點,而讓Tendermint區塊鏈應用開發者可以將關注點集中在業務邏輯上。

如果希望快速掌握基於Tendermint的區塊鏈開發,推薦匯智網的線上互動課程:Tendermint區塊鏈開發詳解,技術問題可諮詢課程助教。

Tendermint簡介

Tendermint萌芽於比特幣、以太坊這樣的加密貨幣,它的目標是提供一個比比特幣的工作量證明(PoW)更加高效和安全的共識演算法。簡單地說,Tendermint是一個可供二次開發的軟體包,可以在多臺機器上安全、一致地實現應用狀態的複製。

  • Tendermint可以在不超過1/3的機器失效時依然正常工作,無論失效的原因 是什麼。Tendermint實現了拜占庭容錯。
  • 任何正常工作的機器都會收到相同的交易日誌,並分別推匯出相同的狀態

Tendermint的特性如下圖所示:

Tendermint包含兩個主要的元件:

  • 區塊鏈共識引擎,即:Tendermint核心
  • 應用與區塊連結口,即:Application BlockChain Interface

Tendermint核心可以託管任意的應用狀態,因此可以使用任何語言開發區塊鏈軟體:Haskell、GoLang、或者Rust都可以用來開發ABCI應用。

其他區塊鏈的一個問題是,它們都是單體設計思維的軟體。以比特幣為例,比特幣的設計就是單體的,其區塊鏈技術棧都包含在單一程式裡,需要處理從P2P連結到交易廣播、達成共識乃至檢查賬戶餘額的一切事情。

單體應用通常不容易擴充套件、升級或再利用,而Tendermint則致力於將區塊鏈技術棧的兩個核心元件與其他部分解耦:共識引擎和P2P連線 —— 事實上這也是開發區塊鏈的最困難的兩個技術環節 —— 從而可以使用任何開發語言來開發ABCI應用。

廢話不多說了,讓我們擼起袖子開幹!

Tendermint開發環境搭建與測試

STEP 1:下載Tendermint核心

tendermint核心採用Go開發,有官方預編譯程式,下載地址:Tendermint Core

下載後直接解壓,並將tendermint程式目錄新增到環境變數PATH的設定裡。

STEP 2:初始化Tendermint

執行如下命令初始化Tendermint:

~$ tendermint init

應當可以在終端看到tendermint的輸出資訊:

I[10–18|20:14:08.996] Generated private validator module=main path=/Users/niharikasingh/.tendermint/config/priv_validator.json
I[10–18|20:14:08.996] Generated node key module=main path=/Users/niharikasingh/.tendermint/config/node_key.json
I[10–18|20:14:08.996] Generated genesis file module=main path=/Users/niharikasingh/.tendermint/config/genesis.json

STEP 3:啟動Tendermint節點

使用node子命令啟動Tendermint節點:

~$ tendermint node -proxy_app=kvstore

-proxy_app執行標誌用來指定一個內建的ABCI應用,例如kvstore是tendermint程式內建的鍵值對狀態機。你應該可以看到如下的tendermint程式輸出:

I[10–18|20:16:40.037] Starting multiAppConn module=proxy impl=multiAppConn
...
I[10–18|20:16:42.051] enterPropose: Our turn to propose module=consensus height=2 round=0 proposer=601302EBD1F8B4BCE9F99B219965F2796AB6BB10 privValidator=”PrivValidator{601302EBD1F8B4BCE9F99B219965F2796AB6BB10 LH:1, LR:0, LS:3}”
I[10–18|20:16:42.055] Signed proposal module=consensus height=2 round=0 proposal=”Proposal{2/0 1:48B45F4423A5 (-1,:0:000000000000) F52DF1F111D8 @ 2018–10–18T14:46:42.051967933Z}”
I[10–18|20:16:42.056] Received proposal module=consensus proposal=”Proposal{2/0 1:48B45F4423A5 (-1,

STEP 4:提交交易

要提交一個交易,可以使用curl向Tendermint節點的RPC服務發出請求,例如:

~$ curl http://localhost:26657/broadcast_tx_commit?tx=\"niharika\"

響應結果如下:

{
  "jsonrpc":"2.0",
  "id": "",
  "result": {
    "check_tx": {
      "gasWanted": "1"
    },
    "deliver_tx": {
      "tags": [
        {
          "key": "YXBwLmNyZWF0b3I=",
          "value": "amFl"
        },
        {
          "key": "YXBwLmtleQ==",
          "value": "bmloYXJpa2E="
        }
      ]
    },
    "hash": "EAAD936D3EDCCCF5DD214E02BB4065E5511CA5AC",
    "height": "3533"
  }
}

注意結果中的value欄位,例如bmloYXJpa2E,這其實是字串niharika的base64編碼。

現在讓我們查詢一下:

~$ curl -s 'localhost:26657/abci_query?data="niharika"'

響應結果如下:

{
  "jsonrpc":"2.0",
  "id": "",
  "result": {
    "response": {
      "log": "exists",
      "index": "-1",
      "key": "bmloYXJpa2E=",
      "value": "bmloYXJpa2E="
    }
  }
}

很好,看起來我們的Tendermint核心與ABCI介面的工作一切正常!

在本文中,我們成功安裝並啟動了tendermint核心,然後通過節點旳ABCI介面提交了一個交易來更新內建鍵值庫應用的狀態,最後通過ABCI介面查詢了ABCI應用的狀態。這就是基於Tendermint進行應用開發的核心模型:可以使用任何開發語言來代替curl完成這些操作,實現自己的ABCI應用!


原文連結:自主可控區塊鏈神器Tendermint五分鐘入門 - 匯智網

相關文章