区块见闻 区块见闻
Ctrl+D收藏区块见闻
首页 > ICP > 正文

BRI:社区观点:我是如何从Java转型为Go区块链工程师-ODAILY_Bridge Mutual

作者:

时间:

前言

本人在加入比原链之前一直是做Java开发的,当初看到Go还有点犹豫,还怕过不了面试,结果是否掌握一门语言的考量确实没那么高,我顺利入职比原链,并在半个月内很快掌握Go并能够进行核心项目的开发。

Java语言在较大的成熟项目上具有优势,但是在区块链开发中确实会有很多短处,比如在协程处理上,还有Java语言本身不够灵活等等,当然选择使用Go主要是因为其在区块链的流行程度。

区块链的流行语言

在区块链公链的开发圈子里,我们找到了一些流行的编程语言,有C++、Golang、Python和最近新起的Rust等等。

稍微对比较有名的项目采用的编程语言做个统计,如下图:

EOS网络基金会敦促EOS社区拒绝Block.one的2200万美元和解协议:8月9日消息,EOS网络基金会敦促EOS社区拒绝Block.one和解协议,其认为与Block.one的拟议和解不符合EOS网络和整个EOS社区的最佳利益。该和解方案未能充分补偿社区成员因Block.one的虚假陈述和不良行为而遭受的损失,禁止了集体成员在未来寻求公平、公正的索赔解决方案的权利。

Block.one在ICO销售中从社区筹集了40亿美元,Block.one曾承诺向EOS网络和社区投资10亿美元,但没有兑现承诺。根据和解协议的条款,加入和解协议的社区成员今后将不得对Block.one及其创始人提出任何索赔要求,Block.one将支付2200万美元。选择退出的截止日期为2023年8月29日,若社区成员未能在此日期前退出,可能会被自动纳入集体诉讼。[2023/8/9 21:34:08]

老一代的公链,比如Bitcoin,Litecoin一般使用C/C++较多,新一代的公链比如以太坊,联盟链翘楚超级账本,开始较多使用Go语言,当然我们看到Rust的发展势头也很猛,近两年的很多公链比如波卡,Grin都开始采用Rust语言开发了。

社区代币平台Roll集成机构级安全公司Fireblocks:社区代币平台Roll集成机构级安全公司Fireblocks,以进行密钥保护。Roll此前因热钱包安全事故损失570万美元,集成Fireblocks是其私钥基础设施进行改造的一部分。Roll联合创始人SidKalla表示,Fireblocks的多方计算(MPC)钱包基础设施将使Roll安全地签署交易,而无需将私钥存储在一个地方,还有助于防止私钥被盗和凭据泄露。此外还将通过Fireblocks为Roll创作者和用户提供高达3000万美元的网络安全保险。(Coindesk)[2021/6/24 0:03:59]

Go语言的优势

部署简单

Go编译生成的是一个静态可执行文件,除了glibc外没有其他外部依赖。这让部署变得异常方便:目标机器上只需要一个基础的系统和必要的管理、监控工具,完全不需要操心应用所需的各种包、库的依赖关系,大大减轻了维护的负担。可直接编译成机器码,不依赖其他库,glibc的版本有一定要求,部署就是扔一个文件上去就完成了。

动态 | SENbit联合ETE社区Jack Liao向各大医院捐助口罩、面罩等物资:据官方消息,连日来新型冠状病肺炎疫情牵动着全国人民的心,SENbit基金会宣布联合ETE以太币社区建设者Jack Liao首批捐助10000只防护口罩、10000个防护面罩等物资。

10000只防护口罩定向捐赠金寨县县委组织部,用于发放给社区民众进行疫情防控。

10000个防护面罩定向捐赠给相关重点医院,具体名单如下:武汉协和医院3000个;孝感中心医院1000个;黄冈中医院1000个;四川省人民医院1500个;四川省中医院1500个;西南财经大学医院1000个等。[2020/2/2]

性能优秀

虽然不如C和Java,但通常比原生Python应用还是高一个数量级的,适合编写一些瓶颈业务。内存占用也非常省。

并发性&通道

Goroutine和channel使得编写高并发的服务端软件变得相当容易,很多情况下完全不需要考虑锁机制以及由此带来的各种问题。单个Go应用也能有效的利用多个CPU核,并行执行的性能好。

动态 | V神24小时内被3位加密社区名人“抨击”:在24小时内,V神在推特遭到3个加密名人的抨击,他自己也发推调侃自己遭到“侮辱”并称这次可能是创纪录的。第一个人是Ayre Group创始人、BSV支持者Calvin Ayre,他评论了V神关于经济模式是如何不合理的推文,“Vitalik对经济学或区块链一无所知。”第二个人是BitTorrent创始人Bram Cohen,针对V神关于加密货币技术状况的文章,Cohen指出,分片并不是解决可扩展性问题的唯一选择。第三个人是加密播客主持人Peter McCormak,他称以太坊为“雾件宣传废话(vapourware nonsense)”,并间接称V神为子。(CoinGape)[2019/11/26]

良好的语言设计

Go非常简单,且易于学习。从学术的角度讲Go语言其实非常平庸,不支持许多高级的语言特性;但从工程的角度讲,Go的设计是非常优秀的:规范足够简单灵活。正是由于Go的简单性,任何的Python、Elixir、C++、Scala或者Java开发者皆可在一月内组建成一个高效的Go团队。

动态 | NEO开发者社区CoZ发布neo-python的v0.8.2版本:据Neonewstoday消息,NEO开发者社区CoZ(City of Zion) 最近发布了neo-python的 v0.8.2 版本,这是一个基于Python的节点和用于NEO区块链的SDK。该项目旨在成为NEO项目的完整港口。[2018/11/3]

标准库&工具

Go目前已经内置了大量的库,特别是网络库非常强大。更重要的是Go自带完善的工具链,大大提高了团队协作的一致性。比如gofmt自动排版Go代码,很大程度上杜绝了不同人写的代码排版风格不一致的问题。把编辑器配置成在编辑存档的时候自动运行gofmt,这样在编写代码的时候可以随意摆放位置,存档的时候自动变成正确排版的代码。此外还有gofix,govet等非常有用的工具。

团队牛逼

Go语言后面的支持者是Google,语言足够在各种场景下得到检验,同时创始人还是C语言之父,对后续的发展和创新可期。

Go成功的项目

Go语言在云时代得到了比较广泛的应用,特别是Docker和K8s这样的杀手级产品的出现让Go语言在工程界占有一席之地。

除此之外,Go语言还有非常多的成功运行中的软件:

nsq:bitly开源的消息队列系统,性能非常高,目前他们每天处理数十亿条的消息;

packer:用来生成不同平台的镜像文件,例如VM、vbox、AWS等,作者是vagrant的作者;

skynet:分布式调度框架;

Doozer:分布式同步工具,类似ZooKeeper;

Heka:mazila开源的日志处理系统;

cbfs:couchbase开源的分布式文件系统;

tsuru:开源的PAAS平台,和SAE实现的功能一模一样;

groupcache:memcahe作者写的用于Google下载系统的缓存系统;

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语言并发性和通道就显得非常有优势,我们看下面交易验证的例子:

我们使用Routine+Ch+WaitGroup在30行代码之内,就可以构建一个并发的验证交易的功能,在高配置的服务器的情况下,可以跑出10万以上的TPS。

轻松变成Go语言大师

我当初进入比原之前也没有做过Go语言开发,但都能够很快上手,基本在半个月内能够参与核心代码的开发和维护了,这就是语言简单对团队构建带来的好处。

统一的协作

从协作上来说,通过gofmt自动排版Go代码,能够让核心团队成员甚至社区开发者提交的代码风格的差异性降到最小,提升项目的整体质量和可维护性。

总结

Go语言本身的特质和优势为其做好了铺垫,而以太坊和超级账本两个超级区块链项目的加持也让Go语言成为了很多区块链项目的首选。

比原链选用Go语言也充分体会到了其开发区块链底层的优势,但是无需落入语言之争的陷阱,讲求实用主义才是做工程应有之义,比原链核心项目是用Go语言完成,但是周边的很多子项目也有用Java,Python或者JavaScript实现,毕竟生态的多样性才是一个项目长久的根本。

标签:区块链BRIUSTUTI区块链的几个大局有哪些Bridge Mutualcrust币挖矿教程UTI币

ICP热门资讯
BRO:从MOV稳定币的设计哲学看基于四种因子的宏观调控-ODAILY_Super Squid Grow

1月15日比原链发布了《MOV稳定金融体系白皮书》,首创了三级清算体系并引入风险债券的清算方式、全天候风险度量体以及基于马尔科夫链的风险评级模型.

ROW:科普:真随机数和伪随机数-ODAILY_BRO

比特币用户很喜欢讨论“非对称加密”、“椭圆曲线”、“量子计算机”这类高深莫测的话题,然后再以一种非常莫名其妙的方式把币弄丢,比如说:“随机”.

区块链:Power of Blockchain「产业区块链榜单」发布-ODAILY_YFIX价格

根据国家网信办发布的「区块链信息服务备案管理系统」备案情况,截止目前已备案企业414家,备案项目达506项。其中金融、政务、溯源、司法场景占比最高.

SSE:比特币拿4年,收益高达56倍-ODAILY_比特币怎么转换门罗币

我在文章中一直提倡普通投资者定投比特币,并且给出的定投价格是8000美元内可以放心定投,如果能够承担风险在10000美元内也可以定投.

GRAP:BSV带领多头卷土重来-ODAILY_Cryptographic Ultra Money

1.今日市场概况 今日市场总市值为1774亿美元,相比昨日增加15%。交易量为1719亿美元,相比昨日增加30%.

区块链:CasperLabs:筑梦者的区块链-ODAILY_WAS

2020年3月11日晚,密码极客邀请到了硅谷明星项目CasperLabs的CTOMedhaParlikar女士做客密码极客大咖直播间,揭开了CasperLabs的神秘面纱.