Tendermint
由于工作原因2年前开始接触Hyperledger Fabric,其社区还是很活跃的,已经从当年的v0.7发展到如今v2.0了。但不得不说Fabric的体量还是挺大的,对于二次开发来说有一定难度。所以最近开始转向Tendermint,因为Tendermint更简单、易于理解、性能更高(当然这是Tendermint自己标榜的),不过事实上相对于Fabric确实更易于理解,更方便开发区块链的应用系统。
摘要
Tendermint由两个主要部分组成,一个负责共识,一个负责应用程序接口,共识引擎称作Tendermint Core,应用程序接口称作ABCI(Application BlockChain Interface),利用ABCI可以开发自己业务逻辑。而Tendermint Core负责共识、p2p通信和状态复制。也就是说区块链的核心功能由Tendermint Core完成,而你自己的业务逻辑可以使用ABCI开发,而且可以使用任何语言进行业务逻辑开发(Tendermint Core 与 ABCI的接口使用RESTful)。
Tendermint使用golang开发的,虽然你可以利用任何开发语言进行业务逻辑开发,但如果你的业务逻辑(ABCI)也使用golang开发,那么可以将你的程序集成在Tendermint Core上,使用--proxy_app
参数来进行代理,这样你就可以干净利索的发布你的区块链应用了。
单机部署
获取源码
mkdir -p $GOPATH/src/github.com/tendermint
cd $GOPATH/src/github.com/tendermint
git clone https://github.com/tendermint/tendermint.git
cd tendermint
设置环境变量
echo export GOPATH=\"\$HOME/go\"
echo export PATH=\"\$PATH:\$GOPATH/bin\"
echo export GO111MODULE=on
编译
# 获取依赖和相关工具
make tools
# 编译并安装到$GOPATH/bin下
make install
# 编译并安装到./build下
make build
验证
(base) frank@deepin:~/project/go/tendermint/bin$ ./tendermint version
0.32.8-7be74c73
至此你的tendermint部署完成。
运行
(base) frank@deepin:~/project/go/tendermint/bin$ ./tendermint init
I[2020-01-29|16:34:14.742] Generated private validator module=main keyFile=/home/frank/.tendermint/config/priv_validator_key.json stateFile=/home/frank/.tendermint/data/priv_validator_state.json
I[2020-01-29|16:34:14.742] Generated node key module=main path=/home/frank/.tendermint/config/node_key.json
I[2020-01-29|16:34:14.743] Generated genesis file module=main path=/home/frank/.tendermint/config/genesis.json
tendermint init
命令初始化了tendermint运行需要的必要配置和相关文件。
(base) frank@deepin:~/.tendermint$ pwd
/home/frank/.tendermint
(base) frank@deepin:~/.tendermint$ tree
.
├── config
│ ├── config.toml
│ ├── genesis.json
│ ├── node_key.json
│ └── priv_validator_key.json
└── data
└── priv_validator_state.json
2 directories, 5 files
如果只运行单机模式你不需要有任何修改。
(base) frank@deepin:~/project/go/tendermint/bin$ ./tendermint node --proxy_app=kvstore
I[2020-01-29|16:50:44.382] Version info module=main software=0.32.8 block=10 p2p=7
I[2020-01-29|16:50:44.402] Starting Node module=main impl=Node
I[2020-01-29|16:50:44.420] Started node module=main nodeInfo="{ProtocolVersion:{P2P:7 Block:10 App:1} DefaultNodeID:64c7a4a9c8fc2b8a524ae837b82fdc3e2d312e3d ListenAddr:tcp://0.0.0.0:26656 Network:test-chain-2uWypP Version:0.32.8 Channels:4020212223303800 Moniker:deepin Other:{TxIndex:on RPCAddress:tcp://127.0.0.1:26657}}"
--proxy_app
参数表示tendermint core代理abci的应用,kvstore则是Tendermint自带的ABCI例子。
有疑问加站长微信联系(非本文作者)