在区块链公链的开发圈子里,我们找到了一些流行的编程语言,有C++、Golang、Python和最近新起的Rust等等。
我们稍微对比较有名的项目采用的编程语言做个统计,如下图:
老一代的公链,比如Bitcoin,Litcoin一般使用C/C++较多,新一代的公链比如以太坊,联盟链翘楚超级账本,开始较多使用Go语言,当然我们看到Rust的发展势头也很猛,近两年的很多公链比如波卡,Grin都开始采用Rust语言开发了。
Go语言的优势
部署简单
Go编译生成的是一个静态可执行文件,除了glibc外没有其他外部依赖。这让部署变得异常方便:目标机器上只需要一个基础的系统和必要的管理、监控工具,完全不需要操心应用所需的各种包、库的依赖关系,大大减轻了维护的负担。可直接编译成机器码,不依赖其他库,glibc的版本有一定要求,部署就是扔一个文件上去就完成了。
Morgan Creek Digital Assets联合创始人:离我们更接近的是10万美元的比特币:2月19日消息,加密货币对冲基金Morgan Creek Digital Assets联合创始人兼合伙人安东尼-庞普里亚诺(Anthony Pompliano)在推特上表示,相比0美元,离我们更近的是10万美元的比特币。[2021/2/19 17:28:42]
性能优秀
虽然不如C和Java,但通常比原生Python应用还是高一个数量级的,适合编写一些瓶颈业务。内存占用也非常省。
并发性&通道
Goroutine和channel使得编写高并发的服务端软件变得相当容易,很多情况下完全不需要考虑锁机制以及由此带来的各种问题。单个Go应用也能有效的利用多个CPU核,并行执行的性能好。
良好的语言设计
Go非常简单,且易于学习。从学术的角度讲Go语言其实非常平庸,不支持许多高级的语言特性;但从工程的角度讲,Go的设计是非常优秀的:规范足够简单灵活。正是由于Go的简单性,任何的Python、Elixir、C++、Scala或者Java开发者皆可在一月内组建成一个高效的Go团队。
观点:我们在DeFi市场投资方面还处于起步阶段:加密货币投资者Andrew Kang深入研究了DeFi市场的状况后得出结论:目前市场正处于首次抛售和熊市陷阱之间,即我们在DeFi市场投资方面还处于起步阶段。Kang首先研究了技术面,指出有50%的回调,抹去了DeFi指数永续期货一个月的价格走势。Messari DeFi资产指数证实了这一点,报告称所有与DeFi相关的代币目前总市值为52亿美元。在顶峰时期,这个数字曾超过120亿美元。
Kang还指出,许多“退化的农民(degens)”仍完全被部署在流动性池中,零售交易员尚未进入。
Kang同时补充道,该领域的创新正以“飞快的速度”前进,这一点可以从主要的DeFi协议如Uniswap、Yearn Finance、Aave和Synthetix纷纷部署Layer 2扩展解决方案中得到证明。(CoinGape)[2020/9/24]
标准库&工具
Go目前已经内置了大量的库,特别是网络库非常强大。更重要的是Go自带完善的工具链,大大提高了团队协作的一致性。比如gofmt自动排版Go代码,很大程度上杜绝了不同人写的代码排版风格不一致的问题。把编辑器配置成在编辑存档的时候自动运行gofmt,这样在编写代码的时候可以随意摆放位置,存档的时候自动变成正确排版的代码。此外还有gofix,govet等非常有用的工具。
声音 | Ripple CEO:我们需要有适当的监督和法规到位,以保护消费者:Ripple CEO Brad Garlinghouse在推特上分享对Libra、监管机构和新数字经济未来的看法。他表示: 1. 我对本周针对Libra举行的国会听证会上的(大部分)深思熟虑的对话感到振奋。委员会成员支持美国的区块链和支付创新,但鉴于其信任问题的历史,他们怀疑Facebook是否是合适的管家。 2. 这场辩论是健康的,对于这个行业的持续成熟是必要的。我们需要提出和回答棘手的问题,确保我们的系统经过战斗测试,并有适当的监督和法规到位,以保护消费者。 3. 用国会议PatrickMcHenry的话来说:“无论Facebook是否参与,变革都在这里。数字货币存在。区块链技术是真实存在的。“ 4. “那么问题就变成了——美国的政策制定者将如何应对这个创新世界的挑战和机遇?”[2019/7/18]
团队牛逼
Go语言后面的支持者是Google,语言足够在各种场景下得到检验,同时创始人还是C语言之父,对后续的发展和创新可期。
Go成功的项目
Go语言在云时代得到了比较广泛的应用,特别是Docker和K8s这样的杀手级产品的出现让Go语言在工程界占有一席之地除此之外Go语言还有非常多的成功运行中的软件:
Cobra回应吴忌寒:我们不应该被迫列出攻击比特币的服务:针对Bitcoin.org移除BitPay和Coinbase的消息,吴忌寒问比特币官方论坛Bitcoin.org持有人Cobra:“你对最近的审查行动负责吗?”Cobra回应称:“我们为什么要给这些邪恶的公司免费推广?你在BITMIN的网站上推广Blockstream吗?这不是审查制度,而是自由,能够决定哪些服务可以推广。我们不应该被迫列出攻击比特币的服务。”[2018/6/9]
nsq:bitly开源的消息队列系统,性能非常高,目前他们每天处理数十亿条的消息
packer:用来生成不同平台的镜像文件,例如VM、vbox、AWS等,作者是vagrant的作者
skynet:分布式调度框架Doozer:分布式同步工具,类似ZooKeeper
Heka:mazila开源的日志处理系统
cbfs:couchbase开源的分布式文件系统
tsuru:开源的PAAS平台,和SAE实现的功能一模一样
groupcache:memcahe作者写的用于Google下载系统的缓存系统
世界最大ATM运营商Cardtronics:加密货币对我们的业务构成威胁:世界最大ATM运营商Cardtronics在10-K年度报告中表示,虚拟货币是该公司面临的众多威胁之一。报告表示消费者行为分析显示,更好的支付方式发生了重大变化。现在,更多的客户选择电子支付方式,而不是传统的实物纸币。该公司认为,比特币等虚拟货币可能是导致普通民众对现金需求减少的原因,所有这些因素加起来会对ATM交易量产生负面影响。[2018/3/3]
god:类似redis的缓存系统,但是支持分布式和扩展性
gor:网络流量抓包和重放工具
生态卡位和隐性标准
除了打铁还需自身硬之外,还有些机遇和运势,让区块链选择的了Go语言。我们来看区块链2.0以来最成功的公链和联盟链代表,以太坊和超级账本Fabric,无一例外都选择使用Go作为开发语言,这两大超级区块链的影响力可不是一般项目可以比拟的,不仅在生态中占据了大的坑位,事实上还隐性的制定了区块链的标准,不论是公链中的智能合约,还是联盟链的技术,都绕不开以太坊和Fabric,那么对于一家想要做区块链技术选型的公司来说,最快捷的实现是什么?自然是直接照搬这两个项目的创新,再捷径一点就是直接拿开源代码改,那么自然Go语言就成为后来者的首选,换种语言重新实现一遍难度也不小,而且如果选择一些创新但不是非常成熟的语言还会缺失一些特定库的支持从而导致项目无法开展。
很多人对以太坊的影响力毋庸置疑,但实际上Fabric在企业区块链部署上的影响力更不容小觑:
图表来源《2019年全球企业区块链基准研究报告》
HyperledgerFabric是已部署的企业区块链网络中使用最多的协议框架,超级账本Hyperledger是集成商和软件开发平台最常支持的协议框架,比例达到了53%。而在所有的区块链技术书籍里面,有关超级账本的书籍是卖的最为火爆这个事实也是侧面印证了超级账本Hyperledger的影响力。
比原链在Go语言中的实践
我们在选型编程语言的过程中,考量了C,C++,Java,但C/C++大项目维护难度大,而Java又略显笨重,此时Go语言已经在区块链项目上大放异彩,也逐渐形成技术和人才的一个头部效应,那么顺应潮流进行技术选型自然也会减少初始比原链项目遇到的阻力,当然在逐渐开发过程中,我们也感受到了选用Go语言带来的便利和优势。
Go在区块链上的一个Case
从技术上来说,区块链节点是需要多模块异步协同工作的,所以Go语言并发性和通道就显得非常有优势,我们看下面交易验证的例子:
funcValidateTxs(txs*bc.Tx,block*bc.Block)*ValidateTxResult{
txSize:=len(txs)
//initthegoroutinevalidateworker
varwgsync.WaitGroup
workCh:=make(chan*validateTxWork,txSize)
resultCh:=make(chan*ValidateTxResult,txSize)
closeCh:=make(chanstruct{})
fori:=0;i<=validateWorkerNum&&i<txSize;i++{
wg.Add(1)
govalidateTxWorker(workCh,resultCh,closeCh,&wg)
}
?
//senttheworks
fori,tx:=rangetxs{
workCh<-&validateTxWork{i:i,tx:tx,block:block}
}
?
//collectvalidateresults
results:=make(*ValidateTxResult,txSize)
fori:=0;i<txSize;i++{
result:=<-resultCh
results=result
}
?
close(closeCh)
wg.Wait()
close(workCh)
close(resultCh)
returnresults
}
我们使用Routine+Ch+WaitGroup在30行代码之内,就可以构建一个并发的验证交易的功能,在高配置的服务器的情况下,可以跑出10万以上的TPS。
轻松变成Go语言大师
从人才上来说,比原链核心开发团队的部分成员之前也没有做过Go语言开发,但都能够很快上手,基本在半个月内能够参与核心代码的开发和维护了,这就是语言简单对团队构建带来的好处。
统一的协作
从协作上来说,通过gofmt自动排版Go代码,能够让核心团队成员甚至社区开发者提交的代码风格的差异性降到最小,提升项目的整体质量和可维护性。
小结
Go语言本身的特质和优势为其做好了铺垫,而以太坊和超级账本两个超级区块链项目的加持也让Go语言成为了很多区块链项目的首选,比原链选用Go语言也充分体会到了其开发区块链底层的优势,但是无需落入语言之争的陷阱,讲求实用主义才是做工程应有之义,比原链核心项目是用Go语言完成,但是周边的很多子项目也有用Java,Python或者JavaScript实现,毕竟生态的多样性才是一个项目长久的根本。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。