本文面向零区块链基础入门XuperChain的开发者,介绍了如何部署XuperChain基础可用环境以及XuperChain服务部署基本操作和配置,帮助开发者们快速了解XuperChain部署流程和基本功能,完成上链第一步。
本文主要分为两大模块:XuperChain环境部署和Xuperchain服务部署。
**XuperChain环境部署**
第一步 准备环境
XuperChain主要由Golang语言开发,首先需要准备编译运行的环境:
(1)根据您使用的电脑操作系统,安装go语言编译环境 (推荐使用的版本为1.14或1.15):https://go.dev/dl/
(2)安装Git,帮助有效、高速地完成项目版本管理:https://git-scm.com/download
第二步 编译XuperChain
(1) 完成XuperChain编译运行环境后,使用Git将XuperChain源代码下载到本地:https://github.com/xuperchain/xuperchain
(2)完成源代码下载后,在XuperChain目录下执行以下命令:
$ cd xuperchain
$ git checkout v5.1.0
$ make
执行命令后,在output目录可以得到bin、conf、data 三个文件夹以及一个 control.sh 脚本,各目录的功能如下表:
经过以上的操作就已经完成对XuperChain编译环境的基本部署。
**Xuperchain服务部署**
完成XuperChain基本环境部署后,接下来将对XuperChain服务进行部署,此部分内容将以XuperChain单节点single共识的链为例操作,教大家如何快速启动一条链,并在链上使用一些基本功能。
启动单节点 single 共识的链
XuperChain的最新版本为启动服务提供了方便的脚本,只需要在output下执行一条命令【controll.sh】即可启动单节点 single 共识的链。
# 启动xuper链
$ bash control.sh start
/home/ubuntu/go/src/github.com/xuperchain/output/bin/xchain
/home/ubuntu/go/src/github.com/xuperchain/output/conf/env.yaml
2021/08/10 19:26:57 start create chain.bc_name:xuper genesis_conf:./data/genesis/xuper.json env_conf:./conf/env.yaml
2021/08/10 19:26:57 create ledger succ.bc_name:xuper start xchain. cmd:nohup /home/ubuntu/go/src/github.com/xuperchain/output/bin/xchain startup --conf /home/ubuntu/go/src/github.com/xuperchain/output/conf/env.yaml >/home/ubuntu/go/src/github.com/xuperchain/output/logs/nohup.out 2>&1 &
.start proc succ.
start finish.pid:17242
Done!
【control.sh】脚本提供了 start、stop、restart、forcestop 四个命令,可以通过执行【bash control.sh help】命令查看。
按照默认配置,Xuperchain服务会监听37101端口,可以使用如下命令查看Xuperchain服务的运行状态:
# check服务运行状况
$ bin/xchain-cli status -H 127.0.0.1:37101
{
"blockchains": [
{
"name": "xuper",
"ledger": {
"rootBlockid": "d93c260ea5639a55e1fcad3df494495efad5c65d46e846b6db3a9194a4212886",
"tipBlockid": "9555ca5af579db67734f27013dfaae48d93e4c3e8adcf6ca8f3dc1adb06d0b6f",
"trunkHeight": 137
},
....
"9555ca5af579db67734f27013dfaae48d93e4c3e8adcf6ca8f3dc1adb06d0b6f"
]
}
],
"peers": null,
"speeds": {}
}
XuperChain基本功能使用
第一步 创建账号
在XuperChain中,账号类型分为“普通账号”和“合约账号”。
普通账号由程序离线生成,在本地保存;合约账号是XuperChain中用于智能合约管理的单元,由普通账户发起交易,在链上生成的一个16位数字的账户,存储在链上。发起合约相关交易,比如合约调用时,需要使用合约账户。
创建账号的操作如下:
# 创建普通用户, 生成的地址,公钥,私钥在--output 指定位置
$ bin/xchain-cli account newkeys --output data/bob
create account using crypto type default
create account in data/bob
## 创建合约账号
bin/xchain-cli account new --account 1111111111111111 --fee 2000
账号创建完成后会在data/bob目录下会看到文件address,publickey,privatekey生成,这就是本次创建账号的地址、公钥和私钥,在下面的操作中将会用到。
第二步 查询资源余额
以普通账号为例,使用如下命令查询账号资源余额,其中-H参数为Xuperchain服务的地址。
# 根据账户存储的路径,查询该账户的余额。--keys为要查询的账户的地址
$ bin/xchain-cli account balance --keys data/keys
100000000000338000000
# 根据地址查询该账户余额
$ bin/xchain-cli account balance TeyyPLpp9L7QAcxHangtcHTu7HUZ6iydY
100000000000401000000
第三步 转账
转账操作需要提供源账号的私钥目录,也就类似“创建新账号”中生成的目录,这里注意到并不需要提供目标账号的任何密钥,只需要提供地址即可。命令执行的返回是转账操作的交易id(txid)。
# --keys 从此地址 转给 --to地址 --amount 金额
$ bin/xchain-cli transfer --to czojZcZ6cHSiDVJ4jFoZMB1PjKnfUiuFQ --amount 10 --keys data/keys/ -H 127.0.0.1:37101
24d53ea6e61ede8dc4fe65a04fd30da17c079a359e700738f8795dfddc55ffb4
第四步 查询账号交易信息
通过以下命令可以查询交易的信息,包括交易状态、交易的目标账号、交易的金额、所在的区块(如果已上链)等内容。
# 可查询上一步生成的txid的交易信息
$ bin/xchain-cli tx query 24d53ea6e61ede8dc4fe65a04fd30da17c079a359e700738f8795dfddc55ffb4 -H 127.0.0.1:37101
{
"txid": "24d53ea6e61ede8dc4fe65a04fd30da17c079a359e700738f8795dfddc55ffb4",
"blockid": "e83eae0750d0f48cc2b45f25d853fb587d124552851bf6693757e0715837b377",
"txInputs": [
{
"refTxid": "2650aa0c0e8088def98093a327b475fa7577fa8e266c5775435f7c022fe0f463",
"refOffset": 0,
"fromAddr": "TeyyPLpp9L7QAcxHangtcHTu7HUZ6iydY",
"amount": "1000000"
}
],
......
"authRequireSigns": [
{
"publickey": "{\"Curvname\":\"P-256\",\"X\":36505150171354363400464126431978257855318414556425194490762274938603757905292,\"Y\":79656876957602994269528255245092635964473154458596947290316223079846501380076}",
"sign": "30460221009509e35b1341284b5d1f22b48c862ecfe2856056196c5650bc203b8a4ed0d454022100f8d286c63ad8eb3bc605bc08da4ff417aaff3c0433a31039f608bb47a90b1267"
}
],
"receivedTimestamp": 1628596303271475925,
"modifyBlock": {
"marked": false,
"effectiveHeight": 0,
"effectiveTxid": ""
}
}
第五步 查询block信息
通过block id可以查询区块的相关信息,包括区块内打包的交易、所在链的高度、前驱/后继区块的id等内容。
# 可查询上一步交易所在的block id信息
$ bin/xchain-cli block e83eae0750d0f48cc2b45f25d853fb587d124552851bf6693757e0715837b377 -H 127.0.0.1:37101
{
"version": 1,
"blockid": "e83eae0750d0f48cc2b45f25d853fb587d124552851bf6693757e0715837b377",
"preHash": "41c74e22ccea7dcf1db6ba0d7e1eefd6cfbd7bac7659c3d8cd33d2a009201003",
"proposer": "TeyyPLpp9L7QAcxHangtcHTu7HUZ6iydY",
"sign": "3044021f349da2d5c238175a6e7df23262eeb122014f0a0040fc4ce109a3ab2c22b2700221009d92198061193fcd47e25c8f5c2b54e1ea2ffb4aaab675384c4d6408ab2b63de",
"pubkey": "{\"Curvname\":\"P-256\",\"X\":36505150171354363400464126431978257855318414556425194490762274938603757905292,\"Y\":79656876957602994269528255245092635964473154458596947290316223079846501380076}",
"merkleRoot": "d22d2423a93911e42f96370167d878f6780fea44fac6a13771c7532e1969c949",
"height": 492,
......
"txCount": 2,
"merkleTree": [
"4a7e42654cf79d6525f6b6d55673b57a92048ee96de950e962db99b102e048a4",
"24d53ea6e61ede8dc4fe65a04fd30da17c079a359e700738f8795dfddc55ffb4",
"d22d2423a93911e42f96370167d878f6780fea44fac6a13771c7532e1969c949"
],
"inTrunk": true,
"nextHash": "a541ed97789537166bec5778aad7ba0f68e52a04d1073b244ee1ea6cd38d8f63",
"failedTxs": null,
"curTerm": 0,
"curBlockNum": 0,
"justify": {}
}
到这里,你已经完成了XuperChain编译运行的环境部署,构建了第一条链并完成了建链后的一些基本操作!如果你对以上操作有任何疑问的,欢迎添加百度超级链小助手,进入技术交流群跟我们一同探讨!