如果你想要入门闪电网络编程,又不在乎所谓正确、最佳的做法,这篇文很适合你。换言之,这篇指南具有很强的 主观性。如果你偏好 O’Reilly 式的权威文本,这篇文章可能不对你的胃口。但是,如果你想要了解闪电网络的最小开发环境及其基本内容,不妨读一读。我写本文的目的是提炼出创建闪电网络应用的基础知识点,让新手能够快速构建和实验。

我相信,只要掌握了基础知识点,你就能编写出更加复杂安全的应用。但是,每个人都得有个开始,我个人的感受是万事开头难,我认为将这些思想整合到一起可以帮助一些迷途羔羊缓解痛苦。

在深入介绍细节之前,请允许我简单介绍一下自己的背景:

大约一个月之前,我辞去了原本稳定的数据架构师工作,开始研究日新月异的

闪电网络的架构

一文读懂闪电网络应用开发速成指南

-图源:lnrouter.app-

闪电网络的基础设计是利用通道实现节点间的一对一连接。开通通道需要存入一定数量的

我之所以这么说,是因为你的应用需要拥有节点的某些权限,才能完成一些重要操作,例如,通过 API/gRPC 调用创建发票和监控付款。如果有节点运营者授予你节点的访问权限,你同样可以完成这些操作,但还是自己运营一个节点比较好。

能够用于闪电网络开发的节点必须运行两个进程:(1)同步到

-你看!是不是等不及想同步了!(Polar 界面)-

Polar 的优点在于,当你准备好将应用转移到测试网或主网后端时,你只需要更新一些配置即可。我已经可以做到在本地、测试网和主网后端之间轻松切换,只需在应用中添加或注释掉几行代码即可。(我最后会得到 .env 文件。当然了,测评工具不是本文的目的。)

Polar 也支持 lnd、c-lighting 和 eclair 节点。这就意味着你可以灵活尝试其它实现。

再重申一遍:使用 Polar 就好。这是一种快速且简单的入门方法。再者说,万一你根本不喜欢在闪电网络上开发呢?早日发现这一点,总好过在一个你不一定会使用的系统上浪费过多时间和金钱。话说回来,如果你发现自己沉迷于 Stephan Livera(知名

点击 “Create Network(创建网络)”,即可在 Polar 中轻松创建模拟闪电网络环境。你可以随意命名这个网络(我个人认为 “test(测试)” 是个聪明的选择)并添加两个 lnd 节点和一个 Bitcoin Core 节点。实际上,对于刚入门的人来说,这些只是最低配,之后还可以添加更多节点。你创建好网络后就可以启动它。首次启动网络时需要的时间可能会长一些,因为你必须下载所有 Docker 镜像。顺带一提,你需要在自己的设备上运行 Docker。就像我之前说的,这里还是得靠自己摸索。

最后,你会看到一个类似下图的 Polar 界面:

一文读懂闪电网络应用开发速成指南

在上图所示界面中,我们可以看到 Alice 和 Bob 的 Ind 节点,而且这两个节点都与 Bitcoin Core 后端进程相连。另外还要注意的是,这时的区块高度是 1。这是我们的创世块!不同于实时

如果一切按计划进行,你就会看到区块高度和 Alice 的钱包余额发生了变化。如果没有,请寻求帮助。这不是你的错。3

现在,我们可以在 Alice 和 Bob 之间开启通道。现在,Alice 已经有钱了,我们可以让她开启一个与 Bob 的 “Outgoing(转出)” 通道。所谓的转出通道,就是 Alice 可以通过该通道转给 Bob 一定数量的

现在,我们可以使用该 Ind 节点的 lncli 工具开启通道、创建发票和付款了。首先,运行下方命令来了解大致情况:

lncli --help

我们可以运行下方命令在 Alice 和 Bob 之间开启一条余额为 10 万 satoshi 的通道:

lncli openchannel --node_key <bob's public node key> --local_amt 100000

你会看到一个带有 “funding_txid” 的响应,对应的是 Alice 和 Bob 广播到我们的模拟

现在,我们只关注 “payment_request” 部分,因为这部分数据包含 Alice 向 Bob 付款所需的一切信息,即,付款金额和收款方地址5。

如果我们切回 Alice 的节点终端,就可以得到付款请求并将它作为参数传递给下方命令:

lncli sendpayment –pay_req <payment_request>结果得到:

一文读懂闪电网络应用开发速成指南

成功。

开始你的冒险征程

一文读懂闪电网络应用开发速成指南

这时,你应该已经具备了足够的基础知识和工具,可以开始构建应用了。上图概述了一个简单的示例应用,使用的正是我们在 Polar 中用来创建并支付发票的 API 调用。这就是搭建一个最基础的应用架构所需的一切。当然了,这只是一个例子,我们在开发过程中还会遇到许多其它问题(目前还只是开始),但是你会慢慢弄清楚自己需要什么以及如何解决这些问题。

一些额外的建议和参考:

有很多库可以帮助开发者少写些样板代码、直奔主题。就我本人而言,学习如何使用这些库带给我的更多是挫败感,而非更高的效率。问题主要出在我身上。抽象确实很棒,但前提是你要对被抽象的内容有基本了解。我在起步时还没有领悟到这一点。我觉得 Ind 的 API 文档学起来最容易。当我按照这个指南使用 Javascript 编写 gRPC 客户端时,我就已经步入正轨了。

如果你想看一个更具体的应用示例,不妨看看 Lightning Labs 构建者指南的教程。如果你熟悉教程中用到的工具 express、mobx 和 React,那么我很推荐这个教程。如果你不熟悉这些工具,你可能不会从这篇教程中得到很大帮助,但还是能够学到一些东西。我喜欢这个教程的一个原因是,它展示了利用闪电网络(和密码学证明)构建应用可以实现的一些有趣功能。

脚注

如果你想运行节点,Umbrel 很适合初学者。我听说 MyNode、RaspiBolt 和 RaspiBlitz 也不错。如果你喜欢修补软件系统(或 SimCity(模拟城市游戏)),那么运行节点往坏了说是一种有趣的消遣,往好了说是一场高成本且无休止的优化游戏(需要付出真金白银的那种)。

你还可以在测试网上进行实验,通过来源链接:https://ethfans.org/

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注