1. abci server的go代码
1.1 基于tendermint 0.16.0
1.2 目录结构
server
├── main.go
├── MyApplication.go
└── server
其中,server是编译出来的二进制可执行文件。
1.3 main.go源码如下
-------------
1.4 MyApplication.go源码如下
------------
------------
2.配置两节点的tendermint网络
2.1 初始化节点1
2.1.1 节点1的ip地址 192.168.199.181
2.1.2 将tendmint可以执行行文件复制到/home/bri/目录
2.1.3 执行命令: ./tendermint init 这个命令,会在~/.tendermint下生成config目录和data目录。
2.2 初始化节点2
2.1.1 节点1的ip地址 192.168.199.115
2.1.2 将tendmint可以执行行文件复制到/home/bri/目录
2.1.3 执行命令: ./tendermint init 这个命令,会在~/.tendermint下生成config目录和data目录。
2.3 配置节点1和节点2
2.3.1 配置节点1和节点2只需要修改一个文件,就是.tendermint/config/genesis.json,两个节点的genesis.json文件是相同的。
2.3.2 注意:节点1和节点2是分别初始化的,因此它们有不同的genesis.json文件。不同之处是: 1. chain_id不一样 2.validators这个参数分别只有一个。因此,修改genesis.json文件,就是把chain_id修改成同一个,把两个节点的validators合并起来。
2.3.3 合并后的genesis.json文件内容如下:
-----------------------
3. 启动两节点tendermint网络
3.1 在两个节点的分别开一个终端,cd到/home/bri目录,均运行1.2节的 ./server程序,启动abci server
3.2 在两个节点分开开一个终端,cd到/home/bri目录,均运行
./tendermint node --consensus.create_empty_blocks=false --p2p.persistent_peers=192.168.199.181:46656,192.168.199.115:46656
其中,--consensus.create_empty_blocks=false是不创建空块。
4. 向两节点tendermint网络提交数据
http://192.168.199.181:46657/broadcast_tx_commit?tx="18717917555张三"
貌似两台机器的log都发生了变动。
分别检查两台机器的记录
http://192.168.199.181:46657/blockchain?minHeight=1&maxHeight=3
http://192.168.199.115:46657/blockchain?minHeight=1&maxHeight=3
结果正确。
再提交一条记录http://192.168.199.181:46657/broadcast_tx_commit?tx="18717917555张三1"
分别检查两台机器的记录
http://192.168.199.181:46657/blockchain?minHeight=1&maxHeight=4
http://192.168.199.115:46657/blockchain?minHeight=1&maxHeight=4
结果正确。
1.1 基于tendermint 0.16.0
1.2 目录结构
server
├── main.go
├── MyApplication.go
└── server
其中,server是编译出来的二进制可执行文件。
1.3 main.go源码如下
-------------
package main
import (
"fmt"
"github.com/tendermint/abci/server"
"github.com/tendermint/abci/types"
cmn "github.com/tendermint/tmlibs/common"
)
func main() {
var app types.Application
app = NewMyApplication()
flagAddrD := "tcp://0.0.0.0:46658"
flagAbci := "socket"
srv, _ := server.NewServer(flagAddrD, flagAbci, app)
if err := srv.Start(); err != nil {
fmt.Println(err)
fmt.Println("start error")
}
// Wait forever
cmn.TrapSignal(func() {
// Cleanup
srv.Stop()
})
fmt.Println("Hello World!")
}
-------------
1.4 MyApplication.go源码如下
------------
package main
import (
"encoding/binary"
"fmt"
"github.com/tendermint/abci/example/code"
"github.com/tendermint/abci/types"
)
type MyApplication struct {
types.BaseApplication
}
var _ types.Application = (*MyApplication)(nil)
func NewMyApplication() *MyApplication {
return &MyApplication{}
}
func (app *MyApplication) DeliverTx(tx []byte) types.ResponseDeliverTx {
fmt.Println("server run deliver now", string(tx))
return types.ResponseDeliverTx{Code: code.CodeTypeOK}
}
func (app *MyApplication) CheckTx(tx []byte) types.ResponseCheckTx {
fmt.Println("server run CheckTx now")
return types.ResponseCheckTx{Code: code.CodeTypeOK}
}
func (app *MyApplication) Commit() types.ResponseCommit {
hash := make([]byte, 8)
binary.BigEndian.PutUint64(hash, uint64(13456))
fmt.Println("server run commit now")
return types.ResponseCommit{Data: hash}
}
------------
2.配置两节点的tendermint网络
2.1 初始化节点1
2.1.1 节点1的ip地址 192.168.199.181
2.1.2 将tendmint可以执行行文件复制到/home/bri/目录
2.1.3 执行命令: ./tendermint init 这个命令,会在~/.tendermint下生成config目录和data目录。
2.2 初始化节点2
2.1.1 节点1的ip地址 192.168.199.115
2.1.2 将tendmint可以执行行文件复制到/home/bri/目录
2.1.3 执行命令: ./tendermint init 这个命令,会在~/.tendermint下生成config目录和data目录。
2.3 配置节点1和节点2
2.3.1 配置节点1和节点2只需要修改一个文件,就是.tendermint/config/genesis.json,两个节点的genesis.json文件是相同的。
2.3.2 注意:节点1和节点2是分别初始化的,因此它们有不同的genesis.json文件。不同之处是: 1. chain_id不一样 2.validators这个参数分别只有一个。因此,修改genesis.json文件,就是把chain_id修改成同一个,把两个节点的validators合并起来。
2.3.3 合并后的genesis.json文件内容如下:
-----------------------
{
"genesis_time":"0001-01-01T00:00:00Z",
"chain_id":"test-chain-CzMmXJ",
"validators":[
{
"pub_key":
{
"type":"ed25519",
"data":"4720273873C785DB45195E96FE6328CC43D8B7FF81C5C5CE2B2382131B208AFF"
},
"power":10,
"name":""
},
{
"pub_key":
{
"type":"ed25519",
"data":"6F391ECC7B85AB9C7F9A19DE6A596BF268AFCFAE515051AF9490B40C12A630FC"
},
"power":10,
"name":""
}],
"app_hash":""
}
-----------------------
3. 启动两节点tendermint网络
3.1 在两个节点的分别开一个终端,cd到/home/bri目录,均运行1.2节的 ./server程序,启动abci server
3.2 在两个节点分开开一个终端,cd到/home/bri目录,均运行
./tendermint node --consensus.create_empty_blocks=false --p2p.persistent_peers=192.168.199.181:46656,192.168.199.115:46656
其中,--consensus.create_empty_blocks=false是不创建空块。
4. 向两节点tendermint网络提交数据
http://192.168.199.181:46657/broadcast_tx_commit?tx="18717917555张三"
貌似两台机器的log都发生了变动。
分别检查两台机器的记录
http://192.168.199.181:46657/blockchain?minHeight=1&maxHeight=3
http://192.168.199.115:46657/blockchain?minHeight=1&maxHeight=3
结果正确。
再提交一条记录http://192.168.199.181:46657/broadcast_tx_commit?tx="18717917555张三1"
分别检查两台机器的记录
http://192.168.199.181:46657/blockchain?minHeight=1&maxHeight=4
http://192.168.199.115:46657/blockchain?minHeight=1&maxHeight=4
结果正确。