赞
踩
此文章基于fisco-bocs官方技术文档进行整理并加以解释,在这里可以快速理解命令的含义和更快地上手,可以当作命令词典使用。
|-- apps # 控制台jar包目录 | -- console.jar |-- lib # 相关依赖的jar包目录 ├── conf │ ├── config-example.toml # 配置文件 │ ├── group-generate-config.toml # 创建群组的配置文件,具体可参考命令genrateGroupFromFile │ └── log4j.properties # 日志配置文件 |-- contracts # 合约所在目录 | -- solidity # solidity合约存放目录 | -- HelloWorld.sol # 普通合约:HelloWorld合约,可部署和调用 | -- TableTest.sol # 使用CRUD接口的合约:TableTest合约,可部署和调用 | -- Table.sol # 提供CRUD操作的接口合约 | -- console # 控制台部署合约时编译的合约abi, bin,java文件目录 | -- sdk # sol2java.sh脚本编译的合约abi, bin,java文件目录 |-- start.sh # 控制台启动脚本 |-- get_account.sh # 账户生成脚本 |-- get_gm_account.sh # 账户生成脚本,国密版 |-- sol2java.sh # solidity合约文件编译为java合约文件的开发工具脚本
bash get_account.sh
bash get_account.sh -p
默认启动控制台
bash start.sh
指定群组号启动
bash start.sh [群组号]
使用pem格式私钥文件启动
bash start.sh [群组号] -pem [私钥文件路径]
使用p12格式文件启动
bash start.sh [群组号] -p12 [私钥文件路径]
help([-h, -help, --h, --H, --help, -H, h]):提供帮助信息。
[group:1]> help * help([-h, -help, --h, --H, --help, -H, h]) Provide help information * addObserver Add an observer node * addSealer Add a sealer node * call Call a contract by a function and parameters * callByCNS Call a contract by a function and parameters by CNS * create Create table by sql * delete Remove records by sql * deploy Deploy a contract on blockchain * deployByCNS Deploy a contract on blockchain by CNS * desc Description table information * quit([quit, q, exit]) Quit console * freezeAccount Freeze the account * freezeContract Freeze the contract ........... ---------------------------------------------------------------------------------------------
注:
[group:1]> getBlockByNumber -h
Query information about a block by block number.
Usage:
getBlockByNumber blockNumber [boolean]
* blockNumber -- Integer of a block number, from 0 to 2147483647.
* boolean -- (optional) If true it returns the full transaction objects, if false only the hashes of the transactions.
newAccount [加密格式/(pem/p12)]
注:
无参数默认是pem格式
freezeAccount [账户地址]
unfreezeAccount [账户地址]
loadAccount [账户私钥路径] [加密格式(pem/p12)]
注:
不指定加密格式,默认是pem格式
getNodeInfo:查询指定节点的信息。
getNodeInfo [IP:channel端口号]
removeNode:移除一个节点
removeNode [nodeId]
addObserver:添加一个观察者节点
addObserver [nodeid]
getObserverList:查询观察者节点的Node ID列表
addSealer:添加一个共识节点
addSealer [nodeid]
getSealerList:查询共识节点的Node ID列表。
getGroupPeers:查询共识节点和观察者节点的Node ID列表
switch
switch [群组号]
generateGroup:为指定节点生成一个组
generateGroup [节点IP:channel端口号] [新建群组的Id] [新建群组创世块时间戳] [新创建群组的共识节点列表]
注:
1.可通过命令echo $(($(date '+%s')*1000))获取时间戳;
2.多个共识节点ID之间用空格分割
群组配置示例group-generate-config.toml
如下:
# The peers to generate the group
[groupPeers]
peers=["127.0.0.1:20200", "127.0.0.1:20201"]
# The consensus configuration of the generated group
[consensus]
# The sealerList
sealerList=["b8acb51b9fe84f88d670646be36f31c52e67544ce56faf3dc8ea4cf1b0ebff0864c6b218fdcd9cf9891ebd414a995847911bd26a770f429300085f37e1131f36","11e1be251ca08bb44f36fdeedfaeca40894ff80dfd80084607a75509edeaf2a9c6fee914f1e9efda571611cf4575a1577957edfd2baa9386bd63eb034868625f"]
[genesis]
# The genesis timestamp, It is recommended to set to the current utcTime, which must be greater than 0
timestamp = "1590586645000"
generateGroupFromFile
命令的参数包括:
groupConfigFilePath
: 群组配置文件路径,控制台conf/group-generate-config.toml
是提供的群组配置文件模板,用户可根据实际场景拷贝、修改该配置模板,并加载修改后的群组配置文件;groupId
: 新创建的群组ID。[group:1]> generateGroupFromFile conf/group-generate-config.toml 3
* Result of 127.0.0.1:20200:
GroupStatus{
code='0x0',
message='Group 3 generated successfully',
status='null'
}
* Result of 127.0.0.1:20201:
GroupStatus{
code='0x0',
message='Group 3 generated successfully',
status='null'
}
queryGroupStatus [节点IP:channel端口] [群组号]
recoverGroup [节点IP:channel端口] [群组号]
removeGroup [节点IP:channel端口] [群组号]
startGroup [节点IP:channel端口] [群组号]
stopGroup [节点IP:channel端口] [群组号]
部署合约。(默认提供HelloWorld合约和TableTest.sol进行示例使用) 参数:
合约路径:合约文件的路径,支持相对路径、绝对路径和默认路径三种方式。用户输入为文件名时,从默认目录获取文件,默认目录为: contracts/solidity
,比如:HelloWorld。
`deploy [合约路径]`
# 部署HelloWorld合约,默认路径
[group:1]> deploy HelloWorld.sol
contract address:0xc0ce097a5757e2b6e189aa70c7d55770ace47767
# 部署HelloWorld合约,相对路径
[group:1]> deploy contracts/solidity/HelloWorld.sol
contract address:0xd653139b9abffc3fe07573e7bacdfd35210b5576
# 部署HelloWorld合约,绝对路径
[group:1]> deploy /root/fisco/console/contracts/solidity/HelloWorld.sol
contract address:0x85517d3070309a89357c829e4b9e2d23ee01d881
注:
- 部署用户编写的合约,可以将solidity合约文件放到控制台根目录的
contracts/solidity/
目录下,然后进行部署即可。按tab键可以搜索contracts/solidity/
目录下的合约名称。- 若需要部署的合约引用了其他合约或library库,引用格式为
import "./XXX.sol";
。其相关引入的合约和library库均放在contracts/solidity/
目录。- 如果合约引用了library库,library库文件的名称必须以
Lib
字符串开始,以便于区分是普通合约与library库文件。library库文件不能单独部署和调用。deployByCNS:通过CNS在区块链上部署一个合约
call [合约路径] [合约地址] [合约接口名] [合约接口参数]
注:参数:由合约接口参数决定。**参数由空格分隔,其中字符串、字节类型参数需要加上双引号;数组参数需要加上中括号,比如[1,2,3],数组中是字符串或字节类型,加双引号,例如[“alice”,”bob”],注意数组参数中不要有空格;布尔类型为true或者false。**
callByCNS [合约路径] [合约地址] [合约接口名] [合约接口参数]
getContractStatus [合约地址]
listAbi [合约文件路径]
listDeployContractAddress [合约文件路径]
getBlockByHash [区块哈希] [true/fasle]
注:
true表示会返回一个交易对象,false会返回只返回交易哈希,不写默认为false
getBlockByNumber [区块号] [true/false]
注:
true表示会返回一个交易对象,false会返回只返回交易哈希,不写默认为false
getBlockHashByNumber [区块号]
getBlockHeaderByHash [区块哈希] [true/fasle]
注:
如果为true,则还将返回签名列表,不写默认为false
getBlockHeaderByNumber [区块号] [true/false]
getTransactionByBlockHashAndIndex [区块哈希] [交易索引]
getTransactionByHash [交易哈希]
getTransactionReceipt [交易哈希]
getTotalTransactionCount:查询总交易数
这部分需要先理解fisco-bcos安全控制中的权限控制部分才能更好的使用
grantCNSManager:授予地址对CNS的权限
grantCommitteeMember:授予账户委员会成员身份。
grantContractStatusManager:授予用户合约授权。
grantContractWritePermission:授予账户对合约的写入权限。
grantDeployAndCreateManager:授予地址对部署合约和创建用户表的权限。
grantNodeManager:授予地址对节点配置的权限。
grantOperator:授予账户操作员身份。
grantSysConfigManager:授予地址对系统配置的权限。
grantUserTableManager:授予对指定表名和地址的用户表的权限。
revokeCNSManager:撤销对CNS的权限。
revokeCommitteeMember:从委员会成员中撤销账户。
revokeContractStatusManager:撤销用户对合约的授权。
revokeContractWritePermission:撤销账户对合约的写入权限。
revokeDeployAndCreateManager:撤销对部署合约和创建用户表的权限。
revokeNodeManager:撤销对节点配置的权限。
revokeOperator:撤销操作员身份。
revokeSysConfigManager:撤销对系统配置的权限。
revokeUserTableManager:撤销对指定表名和地址的用户表的权限。
revokeSysConfigManager:撤销对系统配置的权限。
revokeUserTableManager:撤销对指定表名和地址的用户表的权限。
- queryCommitteeMemberWeight:查询委员会成员的权重。
- updateCommitteeMemberWeight:更新委员会成员的权重。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。