超零协议(SERO)轻松入门——基于CENTOS7

SERO   |     |   244 次阅读

  1. 机器配置

以目前Beta上链的规模,满足以下配置
CPU 4线程以上
MEM 4GB以上
DISK 50G以上
就能很好的运行了。
1. #本文中测试机配置
2. ----------------------------
3. OS : CENTOS7.3
4. CPU : Xeon E5-26xx v4 (C2T2)
5. MEM : 4GB
6. DISK: 50GB
7. ----------------------------

  1. 准备环境

安装Go语言和Git客户端
1. $ sudo yum install golang
2. $ sudo yum install git
注意,只支持 v1.10.x 以及以下golang版本,v1.11.x 不支持。
安装需要的C++依赖库
1. #安装boost库
2. $ sudo yum install boost
3. #可能还需要安装 gmp、libgomp、procps-ng
4. $ sudo yum install gmp libgomp procps-ng

  1. 获取代码

创建GOPATH目录
1. $ pwd
2. ... /root
3.

4. $ mkdir gopath
5. $ mkdir gopath/src
6. $ mkdir gopath/src/github.com
7. $ mkdir gopath/src/github.com/sero-cash
8. $ export GOPATH=/root/gopath
9. $ cd gopath/src/github.com/sero-cash
访问go-sero项目链接,克隆代码:https://github.com/sero-cash/go-sero
1. $ git clone https://github.com/sero-cash/go-sero.git
访问go-czero-import项目链接,克隆代码:https://github.com/sero-cash/go-czero-import
1. $ git clone https://github.com/sero-cash/go-czero-import.git

  1. 编译gero

  2. $ ls

  3. ... go-sero go-czero-import

  4. $ cd go-sero

  5. $ make all

  6. $ ls build/bin/gero

  7. ... build/bin/gero
    可以见到build/bin下生成了可执行文件gero,如果要重新编译则执行

  8. $ make clean

  9. $ make all

  10. 配置

有了gero可执行文件,我们就能运行SERO的后台服务与交互式控制台。
首先配置运行gero的环境
创建SERO数据存储目录
1. $ mkdir ~/sero-data
设置动态库加载路径
1. $ export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$GOPATH/src/github.com/sero-cash/go-czero-import/czero/lib

  1. 启动后台服务

用gero可执行程序,目前可以启动四种不同类型的模式:
启动dev模式
1. $ build/bin/gero --dev --datadir "~/sero-data" --ipcpath "~/sero-data/gero.ipc" > ~/sero-data/debug.log
在这种模式下只能通过手工连接其他的dev节点,挖矿难度非常小,且无限制。
启动alpha模式
1. $ build/bin/gero --alpha --datadir "~/sero-data" --ipcpath "~/sero-data/gero.ipc" > ~/sero-data/debug.log
这种模式下会自动链接AlphaNet网络,并开始同步数据,AlphaNet网络是SERO内部测试网,挖矿需要许可证,如果有测试需求,可以发邮件给gordon@sero.vip申请 挖矿许可证 或者 测试用SERO币
启动beta模式
1. $ build/bin/gero --datadir "~/sero-data" --ipcpath "~/sero-data/gero.ipc" > ~/sero-data/debug.log
这种模式下会自动链接BetaNet网络,并开始同步数据,BetaNet网络是SERO团队提供给社区公测用的网络,挖矿同样需要许可证,如果有测试需求,可以发邮件给gordon@sero.vip申请 挖矿许可证 或者 测试用SERO币
启动Main模式
此模式目前不支持,当主网络上线时,才会提供出来 ...
结果输出

只要看到IPC endpoint opened那句,就说明服务启动已经成功,现在可以启动控制台来连接后台服务。

  1. 启动控制台

当加入attach参数时,gero可以作为控制台启动。
1. #后台启动gero服务
2. $ nohup build/bin/gero --dev --datadir "~/sero-data" --ipcpath "~/sero-data/gero.ipc" > ~/sero-data/gero.log &
3. #启动控制台
4. $ build/bin/gero --datadir "~/sero-data" attach
attach会让gero启动一个JS虚拟机驱动的交互式控制台

在其中可以运行复杂的js控制程序,退出控制台的指令是
1. > exit

  1. 账户管理

创建账户指令
1. > personal.newAccount("[PASSWORD]")
2. ... "[PK]"
其中 [PASSWORD] 是这个账户的密码,因为SERO不会直接存储用户的私钥,当5分钟没有任何操作,账户会被锁定,这时要用该账户进行转账,则需要用此密码对账户解锁。创建用户指令会返回该用户公钥。这个公钥可以作为转账地址。
查看所有公钥
1. > sero.accounts
2. ... ["[PK0]","[PK1]",...,"[PKn]"]
这个属性返回当前钱包中所有账户的公钥。
解锁账户
1. > personal.unlockAccount("[PK]","[PASSWORD]")
其中[PK]是该用户公钥
获取账户资产余额
1. > sero.getBalance("[PK]")
2. ... {tkn:{...},tkt:{...}}
其中tkn按分类显示账户所有Token余额,tkt按分类显示账户所有持有的Ticket。

  1. 挖矿

启动挖矿
1. > miner.start()
停止挖矿
1. > miner.stop()
控制台休眠
1. > admin.sleepBlocks(num)
参数num是需要休眠的区块数,这个方法一定要在挖矿开启的情况下调用,否则将一直阻塞系统。
需要说明的是,挖矿所获得的奖励,默认条件下,会进入sero.accounts的第0个账户的 公钥 生成的 暂存地址(PKr) 中。

  1. 生成交易

当accounts[0]中已经有挖矿所得的奖励的时候,既可以转账给其他账户。
转账指令
sero.sendTransaction({
from:"[SRC_PK]",
to:"[TARGET_PK]",
value:[NUM_OF_TA]
})
... "[TX_ID]"
1. 其中[SRC_PK]是资金发出方公钥,[TARGET_PK]是资金接受方公钥,[NUM_OF_TA]是最小单位的金额,SERO的最小单位是TA,换算单位是 1 SERO = 10^18 TA。返回值[TX_ID]是生成交易的ID。

交易生成之后,将同步给当前网络的其他节点,等待打包进区块中。在打包进区块之后,可以用下面的指令查询交易的详情。
获取交易详情
1. > sero.getTransaction("[TX_ID]")
2. ...[TX_DETAIL]

其中[TX_DETAIL]主要格式于下:
1. {
2. from: "[SENDER PKr]",
3. stx: {
4. Desc_Z_Ins: [{
5. Anchor: "[MERKLE AUTH ROOT]",
6. AssetCM: "[ASSET COMMITMENT]",
7. Nil: "[NULLIFIER ID]",
8. Trace: "[TRACE ID]"
9. Proof: "[ZKP PROOF]"
10. }],
11. Desc_Z_Outs: [{
12. AssetCM: "[ASSET COMMITMENT]",
13. OutCM: "[OUTPUT COMMITMENT]",
14. PKr: "[RECIVER PKr]",
15. Proof: "[ZKP PROOF]"
16. }],
17.
18. }
19. }

  1. 发布智能合约

SERO发布智能合约与以太坊的步骤是相似的。
编译智能合约
使用SERO自己的智能合约编辑器,我们打开下面的链接:
http://remix.web.sero.cash

加载完毕后可以看到其中有一个发行匿名货币的例子seroToken.sol。

右上角选择seroToken,并点击Details。

点击弹出框WEB3DEPLOY旁边的拷贝按钮。
修改初始化参数

在文本编辑器中修改初始化变量。
安装智能合约

然后整个粘贴到控制台中,并回车,控制台立即会发送一笔交易来安装此智能合约。
查看智能合约账户

交易成功后,既可以通过sero.getBalance查看该智能合约所发行的token。
调用智能合约

用智能合约本身定义的transfer方法,可以将智能合约的匿名币发送给个人账户中。
转发匿名资产
现在HELLOCOIN的Token已经在account[0]的账户中,account[0]可以用普通的交易将它发送给其他的账户。但是一定记住必须在参数中指定币名cy:"HELLOCOIN"
1. sero.sendTransaction({from:sero.accounts[0],to:sero.accounts[1],value:500,cy:"HELLOCOIN"})

最后在accounts[1]的账户中可以看到他收到了500个HELLOCOIN的资产。

这笔交易也是匿名的。
最后
入门课先上到这儿,接下来我们会详细的讲解SERO跟以太坊在使用方式最主要的差异,以及Token和Ticket两种匿名资产在智能合约调用中的使用方式。
如果对SERO的原理和零知识证明算法感兴趣,可以在SERO的官网下载我们的白皮书。有任何建议也可以发送电子邮件到 gordon@sero.vip 咨询。
欢迎加入SERO的gitter社区,一起将SERO变得更好。

 
0 人喜欢