[blockchain-030]ubuntu 16.04下的tendermint 0.16双节点网络搭建和abci server开发和测试

1. abci server的go代码
  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
  结果正确。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值