学习区块链必读:如何10分钟搭建Libra

导读:Libra作为Facebook发布的区块链系统,自开源以来受到大家的广泛关注

。本文作者先简要介绍了Libra的一些特点和基本使用方法,适合对区块链有兴趣的广大工程师阅读。

Libra发布也有一段时间了,虽然美国国会各种危难,但是Facebook在这段时间里依然对其改进不少,例如Libra发布时使用了move ir,现在已经基本完全增强并公开了move语言。Libra本身的目的在于支付手段,可以非常方便的进行零成本转账。

Libra使用Rust语言开发,个人猜测Libra开发团队使用Rust语言的主要原因在于Rust语言的安全性。Move语言是Libra的智能合约语言,由于Libra的目标是支付手段,因此设计Move时以安全性为第一考量。对于普通开发者来说,了解并学习Libra并不需要掌握Rust语言。不过如果需要深入理解Libra的细节,可以考虑学习Rust语言。关于如何学习Rust语言,网上有很多资料,这里不在赘述。

接下来,简单介绍如何从源代码开始编译并使用Libra。这里所有的操作都是基于macOS或者Linux,需要提前安装git,如果是macOS,需要提前安装homebrew,如果是Linux需要安装yum或者apt-get。

编译

从github clone libra源代码。

<code>git clone https://github.com/libra/libra.git/<code> 

然后,执行如下命令,进行安装依赖。

<code>cd libra/<code><code>./scripts/dev_setup.sh/<code>

通过setup脚本,主要做了:

  • 安装rustup,这是rust语言的安装程序

  • 安装对应版本的rust-toolchain(记录在rust-toolchain文件中)

  • 安装cmake

  • 安装protoc,从系统架构来看,libra实际上典型的微服务架构,多个微服务之间通过grpc通信,因此需要protoc

  • 安装go,编译protobuf的时候需要

执行如下命令进行编译。

<code>source ~/.cargo/env/<code><code>cargo build/<code><code>cargo test/<code>

如果上述步骤都成功,那么恭喜你,接下来就可以玩Libra了。通常如果本地存在PB版本太低的时候,可能会编译失败,处理方法就是升级PB。如果有其他问题,可以Google解决,如果还无法解决,可以在本文后

留言

使用测试网络

Libra测试网络已经上线,通过以下脚本可以使用libra测试网络。

<code>./scripts/cli/start_cli_testnet.sh/<code>
一旦连到testnet,如下图所示:
学习区块链必读:如何10分钟搭建Libra

如果不想使用libra测试网络,也可以自己启动本地网络。


使用本地网络

通过如下命令可以使用本地网络。

<code>cd libra/<code><code>cargo run -p libra_swarm -- -s -n 4/<code>

如果运行成功,也会出现上面图片中类似的输出。

通过libra_swarm只是启动了本地单节点网络,通常用于方便测试。对于区块链来说,正常的网络都是有多个节点,搭建多测试节点的步骤较为复杂。

首先生成faucet密钥

<code>./target/debug/generate-keypair -o data/libra_local_network/mint.key/<code>

生成节点配置,我们在这里使用三节点网络,

<code>./target/debug/libra-config -b config/data/configs/node.config.toml -m data/libra_local_network/mint.key -n3 -o data/nodes/<code>

分别启动节点:

<code>./target/debug/libra-node -f data/nodes/0/node.config.toml /<code><code>./target/debug/libra-node -f data/nodes/1/node.config.toml/<code><code>./target/debug/libra-node -f data/nodes/3/node.config.toml/<code>

通过如下命令启动cli并连到第一个节点:

<code>./target/debug/client -a localhost -p 49479 -s "data/nodes/0/consensus_peers.config.toml" -m "data/libra_local_network/mint.key"/<code> 

需要注意的是,端口号要和data/nodes/0/node.config.toml中admission_control部分admission_control_service_port 端口保持一致。正常启动后,也能看到类似上图的输出。

创建帐号

完成上述步骤后,我们就可以创建帐号了。

<code>libra% account create/<code>

命令成功运行后,会有如下输出:

学习区块链必读:如何10分钟搭建Libra

#0代表帐号索引,16进制的字符串是帐号地址。可以使用account list命令来查看已经创建的账户。

接下来使用account mint命令给账户挖钱。

<code>account mint 0 10000/<code>

0是账户索引,10000是我们要挖10000个libra币。这个命令是为了测试方便而存在的。完成后可以查看账户余额:

<code>query balance 0/<code>

其中0也是账户索引。

转账

再通过上述步骤创建一个新账户,然后通过第一个账户向第二个账户转账:

<code>transfer 0 1 10/<code>

和之前一样,0和1都是账户索引,10是转账金额。这个命令的作用就是第一个账户向第二个账户转账10个libra币。可以通过query balance来查看是否转账成功,各位读者可以自行验证。

使用move语言

关于move语言的语法细节,可以参考libra官方文档,这里不在赘述。Move将其基本组织结构分为module和script,module相当于其他语言中的库,script中包含main函数可以引用多个module,是执行合约的入口。module如下所示,主要作用是将libra币move到另一个帐号:

<code>module MyModule {/<code><code> import 0x0.LibraCoin;//引入官方的module/<code>
<code> public id(c: LibraCoin.T): LibraCoin.T {/<code><code> return move(c);/<code><code> }/<code><code>}/<code>

script如下所示,主要作用是将libra币从交易发送方move出来,然后move回交易发送方:

<code>import 0x0.LibraAccount;/<code><code>import 0x0.LibraCoin;/<code><code>import {{sender}}.MyModule;/<code>
<code>main(amount: u64) {/<code><code> let coin: LibraCoin.T;/<code><code> coin = LibraAccount.withdraw_from_sender(move(amount));/<code>
<code> LibraAccount.deposit(get_txn_sender, MyModule.id(move(coin)));/<code><code> return;/<code><code>}/<code>

可以通过如下命令,编译module:

<code>dev compile 0 <path> module/<path>/<code><code>Successfully compiled a program at /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpigAZCx/<code>

然后发布module:

<code>dev publish 0 /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpigAZCx/<code>
发布成功后,会输出Successfully published module.

通过如下命令编译script:

<code>dev compile 0 <path>>/<code><code>Successfully compiled a program at /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpDZhL21/<code>

通过如下命令执行脚本:

<code>dev execute 0 /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpDZhL21 10/<code>

其中0代表账户索引,/var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpDZhL21是编译后的文件输出,10是脚本参数,在这个脚本里就是amount。如果成功执行脚本,也会输出Successfully finished execution。

关于Libra本身我们就介绍到这里,最后简单介绍我们团队现在的项目--stargate[1],现在是一个基于libra的二层项目,主要致力于开发libra之上的交易通道,后期会用我们自己的一层网络替代libra,欢迎各位有识之士拍砖。

文中链接:

[1]https://github.com/starcoinorg/stargate

高可用架构

改变互联网的构建方式


分享到:


相關文章: