Tendermint區塊鏈Weave SDK快速指南

  • 2019 年 11 月 14 日
  • 筆記

IOV Weave SDK是一個基於Tendermint共識引擎的區塊鏈開發框架,Weave提供了很多常用功能的預置模塊用於你自己的區塊鏈,同時也支持自定義擴展。

Weave的一些亮點包括基於Merkle樹的數據存儲、高度靈活的擴展支持系統以及核心邏輯的定製(例如手續費機制及簽名驗證機制)。Weave也支持利用創世文件進行定製的能力。此外,在鍵-值庫之上,Weave還提供了一個簡單的對象關係映射層(ORM),可以支持二級索引。Weave還包含了動態遷移功能,利用鏈上交易就可以切換某些邏輯模塊的啟用或關閉。

1、預置模塊

要快速掌握Tendermint區塊鏈開發,推薦匯智網的Tendermint區塊鏈開發詳解.。

Weave開發框架內置了開發一個應用區塊鏈所需的常用功能模塊:

  • Cash:錢包模塊,支持代幣及手續費扣除
  • Sigs:簽名模塊,用於驗證ed25519簽名
  • Multisig:多簽模塊,用於多簽名合約的支持,允許修改成員隸屬關係
  • AtomicSwap:原子交換模塊,支持跨鏈的原子交換
  • Escrow:託管模塊,仲裁者可以安全地持有代幣,或者基於超時規則釋放託管資金
  • Governance:治理模塊,管理鏈上提議的治理規則的選舉,或者直接修改應用參數
  • PaymentChannels:單向支付通道模塊,實現微支付和鏈上結算
  • Distribution:分配模塊,利用配置信息在多個參與者之間分配收入,可用於分配手續費收入
  • Batch:批處理模塊,用於將多個交易整合為單一原子操作,一個應用場景就是單一鏈上交換
  • Validators:驗證人模塊,用於PoA共識上下文中的驗證人集合更新,使用多簽或鏈上選舉模塊
  • Username:用戶名模塊,將用戶名映射為鏈上地址,支持反向查詢
  • MessageFee:消息手續費模塊,用於對抗垃圾信息
  • Utils:工具模塊,包含一組常用的輔助功能

2、Weave開發框架概述

要使用Weave開發框架,需要兩個組件:

  • blog:weave提供的定製ABCI博客應用
  • tendermint:區塊鏈共識引擎

如果你還沒接觸過Tendermint,建議參考匯智網的Tendermint開發教程

Weave的應用通信框架如下:

    +---------+                     +------------+                      +----------+      |   blog  |  <- (local) ABCI -> | Tendermint |   <- websocket ->    | client   |      +---------+                     +------------+                      +----------+

blog和tendermint運行在同一台計算機上,通過二進制TCP/IP協議或UNIX套接字通信,這兩者結合在一起構成了區塊鏈。在實際的生產環境中,你可能會有多個計算機運行這一後端,彼此之間通過自調節的p2p gossip協議通信來實現狀態的複製。對於應用開發而言,一個節點就夠了,但是單一節點是沒有容錯能力的。

你可以使用任何websocket客戶端連接tendermint的rpc,不過我們還是推薦使用IOV core,畢竟它和Weave是同一家的產品,對Weave開發框架的支持更好。

在安裝上述兩個組件之前,需要在你的計算機上先安裝如下組件:

  • golang 1.11.4+
  • tendermint 0.31.5
  • weave
  • docker

然後克隆blog代碼庫並根據兼容表檢出兼容的版本。例如:

# cd into to your workspace that is not in your $GOPATH  git clone https://github.com/iov-one/blog-tutorial  cd blog-tutorial  make install  # test it built properly  tendermint version  # 0.3X.X-YYYYYYYY  blog version  # v0.1X.X-YYYYYYYY

3、初始化應用區塊鏈

在啟動區塊鏈之前,我們需要利用創世區塊設置初始狀態。tendermint和blog都有一個目錄來保存配置信息和內部數據庫狀態。默認目錄為:~/.tendermint~/.blog。不過為了簡化考慮,我們將所有配置信息放到同一個目錄。

首先,創建一個默認的創世文件、用來簽名區塊的私鑰以及默認的配置文件:

# make sure you really don't care what was in this directory and...  rm -rf ~/.blog  # initialize state on default folder ~/.blog  make inittm

你可以瀏覽一下這個目錄,其中最重要的是~/.blog/config/genesis.json,在配置文件~/.blog/config/config.toml中也包含了很多選項。

在啟動區塊鏈之前,我們要為剛創建的賬戶添加一批代幣,同時也要啟用索引器,這樣我們就可以按id搜索交易了。但是我們沒有直接修改配置文件,而是用如下的命令:

blog init CASH bech32:tiov1qrw95py2x7fzjw25euuqlj6dq6t0jahe7rh8wp

確保你輸入的地址和上面一致。這個賬戶現在就有代幣了。在運行上述命令之後,你也可以看一下~/.blog/config/genesis.json。 比較重要的修改是"app_state"。

你可能會問,這個地址是哪裡來的。這是一個使用如下的測試助記詞生成的演示賬戶:

dad kiss slogan offer outer bomb usual dream awkward jeans enlist mansion

賬戶的派生路徑為:m/44'/988'/0'

4、啟動應用區塊鏈

我們已經有了私鑰,並且進行了配置,現在可以啟動我們的blog應用區塊鏈了:

# start the tendermint with default config  make runtm  blog start

上面的命令連接tcp://localhost:26658,如果你希望使用unix套接字,可以使用如下命令:

tendermint node --home ~/.blog --proxy_app=unix://$HOME/abci.socket > ~/.blog/tendermint.log &  blog start -bind=unix://$HOME/abci.socket

打開一個新的終端窗口,使用命令tail -f ~/.blog/tendermint.log,就可以看到我們的blog區塊鏈節點的輸出了:


原文鏈接:IOV Weave SDK快速教程 – 基於Tendermint的區塊鏈開發框架 – 匯智網