如何成为Bitcoin Core贡献者?最全的比特币开发者指南都在这里了

写在前面:本文作者为Amiti Uttarwar,是Bitcoin Core开发者,就职于Xapo,曾是Coinbase的软件工程师。根据自身的经历,她在文章中分享了为比特币做贡献的秘籍,其中包含了大量的学习资料,干货满满,对有需要的人来说很有帮助。P.S. 这是个优秀的小姐姐哦~

如何成为Bitcoin Core贡献者?最全的比特币开发者指南都在这里了

在过去的一年里,我进入了为Bitcoin Core做贡献的奇妙兔子洞。在这个过程中,我很幸运地从许多人那里得到了指导和支持,我自己也学到了一些技巧。在这篇文章中,我想分享一些我发现的有效工具。

成为Bitcoin Core贡献者只是帮助推进这个协议的其中一种方式。其他选择包括(并且远远超出)参与邮件列表讨论、研究攻击向量或扩容技术、为闪电网络客户端做贡献,或开发相关工具,如secpk256k1代码库或更好的测试基础设施。但这篇文章不涉及这些话题。

这篇文章是关于Bitcoin Core的,通过我的体验,我希望它能帮助你找到自己的贡献方式。

开始之前

首先,读白皮书。讲真,如果你还没有读过,那就别看这篇文章了,直接去读白皮书吧。

理解比特币运作的基础概念是必要的。了解的渠道有很多。我会从读其中一本书开始(Mastering Bitcoin、Programming Bitcoin或Grokking Bitcoin)。如果是线上资料,我会访问Jameson Lopp的资源列表或Chaincode实验室的课程。前者更宽泛,但后者专门针对协议开发。

如果你的目标是为Bitcoin Core做出贡献,不要试图学习每个概念的细节。有许多主题的差别不大。目标是获得高层次的理解,并接触系统的不同部分。彻底消化这个分布式共识系统的基本原理是需要时间的。

Bitcoin Optech周报是了解生态系统技术发展的“最佳”方式。Dave Harding在保证其更新。我强烈推荐订阅这个内容。

选择放弃什么

一旦你决定为Bitcoin Core做出贡献,这个过程就不会停止。这个项目有足够的复杂度和开发工作,足以让任何人忙上好几辈子。选择如何分配你的注意力,这有助于确定你“不想”关注什么(至少现在不想)。

要做出改变,开发的广度和深度都很重要。找到正确的平衡是一门随着时间而发展的艺术。广度增加了对新概念的接触,并有助于确定哪些工作是相关的。为了提出一种改进代码库的PR(Pull Request,合并代码请求),理解更大的背景与深入研究一个方面并充分熟悉所提议的变更集一样重要。

人们喜欢推荐的东西总是会超出你的阅读、理解、消化和学习范围……我在上面已经这样做过了——我推荐了3本书,2个无穷无尽的材料清单,还有一个周报。当你与他人交流时,你也会面临潜在的压力,因为你需要对大量的话题有足够的了解,以便在任何对话中都有所贡献。这对广度来说很好,但只有你才能创造出追求深度的道路。要提交一个PR,你需要开发特定的知识,让你提供改变。不要停留在“消化”阶段,专注将确保你继续“创造”的阶段。

如果你不是整天都在研究比特币,这一点就更重要了。这是一个非常复杂的项目。需要创造空间。即使是看起来很简单的任务也需要一段时间。

好了,人生忠告够多了了。现在开始说项目细节……

熟悉代码库

复制代码库,进行编译和测试。
通读项目开发人员文档:

1. Contributing to Bitcoin Core指南是入门的基本知识,包括pull request和审查过程如何工作。

2. 《开发者笔记》是很好的精读指南,在开启一个PR之前,重读这个笔记,以确保你符合当前的标准。

3. Productivity Notes的技巧在开发工作流程的不同时段非常有用。我强烈建议立即执行前四个步骤(安装ccache,执行./configure,使用make -j [num-cores]编译,并生成构建目标)。

阅读Jimmy Song和John Newbery写的入门文章。

参加每周的PR审查。审查PR对项目来说至关重要。更重要的是,这在最开始,是了解代码库和合并过程的有效方法。PR审查是在别人的帮助下熟悉特定变更集的一种方式。你从PR审查获得的价值是你愿意投入精力的直接产物。每周的参与有助于提高对技术架构和历史环境等模式的认识,独立开发需要更长的时间。无论你选择参与这样的活动,还是仅仅潜水,或花时间探索代码,你肯定会学到很多东西。提前准备可以让你利用这段时间来发文或树立你理解代码的信心。

找到你的第一个PR

当你开始适应代码库时,你可能觉得自己已经准备好提交PR了,但是不确定如何选择对项目有价值的贡献。到目前为止,这篇文章中提到的各种方法都很有可能帮助你找到一个有意义的内容。但如果你还在寻找,这里有一些其他的选择:

时刻关注good first issue和up for grabs。
搜索带有“TODO”的代码库,并进行解析,以查看是否有你熟悉且可用的代码库。我在测试中遇到过一些看起来对初学者很友好的。
选择代码库的一个部分(也就是贡献文档中的一个部分),并注意正在打开的相关PR。如果你跟进了PR内容,你肯定会注意到接下来要做的事情。同时,批判性地思考如何测试这些变化。打开PR来跟进处理和增加测试覆盖率将是最佳选择。你还可以访问pr-review-club history来熟悉某个部分。

开源贡献的本质意味着没有中心化的项目管理系统。因此,有些对项目有用的变更集不一定是对PR作者注意力和技能的最佳利用。因此,作为一名贡献者,在你的学习曲线上找出有用的贡献是你工作的一部分。我的第一个PR是通过up-for-grabs找到的。

我很惊讶地发现有这么多举手之劳可以做。在仔细查看Github项目之前,我从来没有想到会这样。

从伴随着Bitcoin Core的“街头形象”来看,很难想象做贡献是多么容易。留意不间断的(简单和复杂的)待办事项清单,确实让我们看到了比特币项目是多么年轻,以及对更多贡献者的紧迫需求。

利用互联网来进行进一步学习

当我开始学习C++语言的时候,我拿到了一些很棒的书,但是说实话,我仍然在努力阅读它们。

动手学习对我来说最有效,我专注于学习语言中最相关的部分,这样我就可以读懂Bitcoin Core代码库。

所以,我会写代码。当我遇到一个新的C++概念时,我会读文档并试图在一个示例程序中将这个函数拎出来看。我会保持tmux制表打开状态,方便调用c++ play。这些程序还可以作为我修改过的概念的文档。另一个很棒的工具是Compiler Explorer。我发现颜色编码对于比较执行相同函数的多种方法特别有帮助,可以看出这些差异是表面的、优化出来的,还是从根本上改变了所做的工作。

为了更深入地研究具体的C++概念,我一直很喜欢观看CppCon talks,尤其是“Back To Basics”这一系列。

这是一个好的开始,但有时我想和人说话。最初,我有时会对一些符号有疑问,但我不知道如何用谷歌来搜索。目前,我更想确认我对文档的理解是否正确。

我发现了一些很棒的在线社区,有陌生人愿意帮助我找到正确的方向。关于C++有一个cpplang slack,一个## c++ -general交流渠道,还有discord上的#include< c++ >社区。在网络上,陌生人给予的帮助令我十分惊讶。

两个注意事项:

1. 我鼓励寻求帮助,但要有礼貌,并且思虑周全。做尽职调查,首先尝试自己找到答案。礼貌地使用适合你的问题的沟通渠道。人们不欠你答案。提供任何帮助都是出于慷慨。

2. 选择聊天客户端:我发现irccloud是一个简单、美观的客户端,而且是免费的。还可以选择支付少量的费用永久保留用户名和日志。这样的客户端有很多选择,但是我建议你将你的决策能力集中在更重要的事情上,尽可能快地选择客户端。

我最喜欢的比特币资源在这篇文章中随处可见,但这里有一些我想要强调的代码:

P2P消息和RPC(远程过程调用)的开发者参考
Bitcoin stack exchange有专门针对协议开发的讨论,涉及各种问题和答案。这个网站在谷歌很难搜到,所以最好直接访问
Fabian Jahr编写了一个关于调试技术的完整文档[演讲] [要点]
我喜欢看James O’Beirne的架构概述[演讲] [幻灯片]

如果你正在努力学习一个技术概念,不确定要尝试什么,请联系我!我肯定不知道所有的答案,但我很高兴能集思广益为你找到解决方案。

更多了解比特币的途径

有很多很棒的方法可以增加你对比特币生态系统发展的了解。以下是一些热门的选择:

UTC时间每周四19:00在#bitcoin-core-dev会举行会议
#bitcoin-core-pr-reviews频道有时候会讨论进程和工具,关注这个频道会有所帮助
重新看看Chaincode Labs的比特币课程,那里有很多很棒的素材——演讲、论文、甚至是代码挑战
参加高质量的会议
观看之前会议的视频。我在上下班的路上看了Bitcoin Edge Dev++ [2017] [2018] 的视频,学到了很多
如果可以的话,参加Socratic seminar
阅读比特币维基,尤其是协议和隐私页面
Chaincode最近做了一个播客频道

熟悉比特币协议不是一件简单的事情,尤其是如果你有其他的事要做,比如一份全职工作或还是学生。我用间隔记忆法来记住新信息。我强烈推荐这个方式。它有助于催化持久记忆信息的能力,这样你就可以花更多的时间来获取新的概念或应用你所学到的知识。这样做还有其他好处,即可以随时进行概念学习,并可以将任何空闲时间都花在代码库的特定任务上。

密切关注Chaincode培训项目。我去年夏天有幸参加了这个项目,这改变了我的工作方式。但请记住,这是一个门槛很高的项目,你对Bitcoin Core的贡献程度越高会增加你被接受的几率(参加代码审查、审查PR、提交PR等等)。

说真的,快行动吧

为Bitcoin Core做贡献是很难的,但并非完全不可能。在开始这段旅程之前,我从来没有写过(甚至读过)任何C++代码。害怕是很自然的,但不要让这种情绪阻止你。

对自己要有耐心。我为Bitcoin Core做的贡献很多都需要花很多时间。有一次,我在集成测试中花了整整3天的时间,重复了用交易填充内存池的不同方法。我最初的几次尝试要求的测试时间长得很不合理,所以我不得不尝试不同的方法。不要陷入一种“这应该很容易”的假象。专注于你能学到的,并不断尝试。

刚开始的时候,“Bitcoin Core”和“核心贡献者”很容易让人觉得这是一个庞大而神秘的组织,不可能参与其中。我惊喜地发现人们是多么乐于助人和支持我。每个在项目中工作的人都受到极大的带宽限制,所以如果你做出了有意义的贡献,大家是会支持你的。

这是很重要的。不要一开始就纠正PR中的拼写错误。要有耐心,在你的学习上投入,观察这个项目,并确定你如何才能做出有意义的贡献。

无论你处于学习曲线的哪个位置,你都可以成为这个项目的资产。如果你愿意贡献你的精力,并且有能力批判性地思考和学习,你就是一笔财富。不要让傲慢或不安全感把你引入歧途。

一些异想天开的思考……

如果我们要描绘出各种各样的学习路径来为Bitcoin Core做贡献,它肯定不会像区块链那样有序和线性。追求你自己的旅程,享受路上的风景,玩得开心。

在开源领域的探索让我想起了越野背包旅行。

在背包旅行中,我首先在一张地形图上查看我想去的地方,然后画出我计划旅行的大致路线,尽量待在最平缓的地形上。由于比特币是新兴领域,可能在地图上还找不到。因此,在浏览比特币时,你首先必须用一些理解的片段拼凑出该地区的大致地图,然后制定出一种方法。我希望这篇文章能让这个过程变得简单一些。

徒步旅行的实际路线需要不断的迭代。每走一步,你都会获得新的信息,你可以利用这些信息来确定难度最小的路径,这样你就可以利用你的能量深入山区进行探险。你要注意每一步的细节,还要注意宏观路线。

这一过程与比特币领域的探索类似。当你学到更多,你会对未来的地形有不同的看法,必须不断选择正确的路线,以保持自己的合理前进。有时你会撞上悬崖,不得不回头尝试另一条路。寻找路线需要大量的精力和注意力。你必须是一个航海家和一个徒步旅行者。

我可以再深入谈谈我的经历,让这篇文章变得更长,但是,我将这样结尾:

祝你好运!希望在GitHub见到你的身影:)