我是如何从Java转型为Go区块链工程师
前言
本人在加入比原链之前一直是做Java开发的,当初看到Go还有点犹豫,还怕过不了面试,结果是否掌握一门语言的考量确实没那么高,我顺利入职比原链,并在半个月内很快掌握Go并能够进行核心项目的开发。
Java语言在较大的成熟项目上具有优势,但是在区块链开发中确实会有很多短处,比如在协程处理上,还有Java语言本身不够灵活等等,当然选择使用Go主要是因为其在区块链的流行程度。
区块链的流行语言
在区块链公链的开发圈子里,我们找到了一些流行的编程语言,有C++、Golang、Python和最近新起的Rust等等。
稍微对比较有名的项目采用的编程语言做个统计,如下图:
老一代的公链,比如Bitcoin,Litecoin一般使用C/C++较多(我们看看那个时间,当时Go还没起来呢),新一代的公链比如以太坊,联盟链翘楚超级账本,开始较多使用Go语言,当然我们看到Rust的发展势头也很猛,近两年的很多公链比如波卡,Grin都开始采用Rust语言开发了。
Go语言的优势
部署简单
Go 编译生成的是一个静态可执行文件,除了 glibc 外没有其他外部依赖。这让部署变得异常方便:目标机器上只需要一个基础的系统和必要的管理、监控工具,完全不需要操心应用所需的各种包、库的依赖关系,大大减轻了维护的负担。可直接编译成机器码,不依赖其他库,glibc的版本有一定要求,部署就是扔一个文件上去就完成了。
性能优秀
虽然不如 C 和 Java,但通常比原生 Python 应用还是高一个数量级的,适合编写一些瓶颈业务。内存占用也非常省。
并发性&通道
Goroutine 和 channel 使得编写高并发的服务端软件变得相当容易,很多情况下完全不需要考虑锁机制以及由此带来的各种问题。单个 Go 应用也能有效的利用多个 CPU 核,并行执行的性能好。
良好的语言设计
Go 非常简单,且易于学习。从学术的角度讲 Go 语言其实非常平庸,不支持许多高级的语言特性;但从工程的角度讲,Go 的设计是非常优秀的:规范足够简单灵活。正是由于 Go 的简单性,任何的 Python、Elixir、C++、Scala 或者 Java 开发者皆可在一月内组建成一个高效的 Go 团队。
标准库&工具
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在企业区块链部署上的影响力更不容小觑:
Hyperledger Fabric是已部署的企业区块链网络中使用最多的协议框架,超级账本Hyperledger(其中Fabric作为旗舰协议)是集成商和软件开发平台最常支持的协议框架,比例达到了53%。
而在所有的区块链技术书籍里面,有关超级账本的书籍是卖的最为火爆这个事实也是侧面印证了超级账本Hyperledger的影响力。
比原链在Go语言中的实践
在选型编程语言的过程中,考量了C,C++, Java,但C/C++大项目维护难度大,而Java又略显笨重,此时Go语言已经在区块链项目上大放异彩,也逐渐形成技术和人才的一个头部效应,那么顺应潮流进行技术选型自然也会减少初始比原链项目遇到的阻力,当然在逐渐开发过程中,我们也感受到了选用Go语言带来的便利和优势。
Go在区块链上的一个Case
从技术上来说,区块链节点是需要多模块异步协同工作的,所以Go语言并发性和通道就显得非常有优势,我们看下面交易验证的例子:
我们使用Routine+Ch+WaitGroup在30行代码之内,就可以构建一个并发的验证交易的功能,在高配置的服务器的情况下,可以跑出10万以上的TPS。
轻松变成Go语言大师
我当初进入比原之前也没有做过Go语言开发,但都能够很快上手,基本在半个月内能够参与核心代码的开发和维护了(对于从C/C++/Java有经验的开发者尤其快速),这就是语言简单对团队构建带来的好处。
统一的协作
从协作上来说,通过gofmt 自动排版 Go 代码,能够让核心团队成员甚至社区开发者提交的代码风格的差异性降到最小,提升项目的整体质量和可维护性。
总结
Go语言本身的特质和优势为其做好了铺垫,而以太坊和超级账本两个超级区块链项目的加持也让Go语言成为了很多区块链项目的首选。
比原链选用Go语言也充分体会到了其开发区块链底层的优势,但是无需落入语言之争的陷阱,讲求实用主义才是做工程应有之义,比原链核心项目是用Go语言完成,但是周边的很多子项目也有用Java,Python或者JavaScript实现,毕竟生态的多样性才是一个项目长久的根本。
你可能感兴趣的文章
-
给区块链大佬泼盆冷水:先吃螃蟹者,不一定是英雄,也可能是烈士
-
给区块链大佬泼盆冷水:先吃螃蟹者,不一定是英雄,也可能是烈士
朱啸虎冷眼旁观区块链昨天朱啸虎与陈伟星(快的打车创始人)的互怼,想必大家都有目共睹了,有人觉得朱啸虎理性,有人觉得陈伟星更有前瞻性。不过区块链的火热,也引发了许...
2024-10-18
详解印度区块链,你不可错过的二三事
-
详解印度区块链,你不可错过的二三事
区块链在印度发展可谓一波三折,但数字货币的快速升值也引起了印度媒体的关注,主流媒体对加密货币进行了密集报道,大多数文章对比特币和加密币持支持的态度,会给出“投资...
2024-10-17
一文看 懂国内区块链产业,到底哪块最赚钱?
-
一文看 懂国内区块链产业,到底哪块最赚钱?
区块链火了。无论它是徐小平、陈伟星等人眼中的“风口”,还是巴菲特、朱啸虎等人口中的“泡沫”、“骗局”。当你为没加入“3点钟”社群而深深焦虑的时候,不如平心静气地...
2024-10-17
重磅第三届区块链全球峰会全程演讲视频,正式公开
-
重磅第三届区块链全球峰会全程演讲视频,正式公开
前沿的技术,前卫的观点,展示真实区块链世界为期三天的峰会,来自全球炙手可热的区块链先锋人物,带着他们对区块链行业的实践和洞察,为一千多名观众呈现了60多场精彩绝...
2024-10-17
字节、腾讯悄悄杀入,“区块链韭菜”真来了?
-
字节、腾讯悄悄杀入,“区块链韭菜”真来了?
今年7月中旬,一个 “区块链韭菜”项目再次被热议。这是在山东潍坊刚刚落地的被称为“区块链+韭菜”的合规、合法的项目。政府等相关部门人士都来站台。创业邦获悉,这个...
2024-10-17
区块链政务,让办事更轻松
-
区块链政务,让办事更轻松
“全国住房公积金”小程序页面。图片来源于网络“区块链+政务”会碰撞出什么样的火花?福建省福州市马尾新港社区利用区块链技术解决政务信息化痛点,推出“区块链+社区证...
2024-10-17
区块链大神陈纯给我上了课:发币是传销,区块链要实名制和备案制
-
区块链大神陈纯给我上了课:发币是传销,区块链要实名制和备案制
一个礼拜之前,除了行业内的人,陈纯是谁无人知晓。但现在,院士陈纯已经封“神”——专门去北京上课,可不是一般人,并且研究的还是神秘的“区块链”。从北京回来没多久陈...
2024-10-17
深圳启动区块链立法研究,助力元宇宙产业发展
-
深圳启动区块链立法研究,助力元宇宙产业发展
日前,深圳市信息服务业区块链协会在深圳大中华国际交易广场组织召开了区块链立法研讨会,开启元宇宙信任机制的立法研究。这是深圳继发布国内首批元宇宙标准之后,助力元宇...
2024-10-17
瑞波币66%涨幅收窄六成;淘宝技术部招聘区块链专家;小牛队将全面接受加密货币支付
-
瑞波币66%涨幅收窄六成;淘宝技术部招聘区块链专家;小牛队将全面接受加密货币支付
监管阴影再现 数字货币回落 瑞波币66%涨幅收窄六成传出欧洲方面的监管消息后,全线反弹的数字货币震荡,整体涨幅收窄。截至北京时间19日6点20分,追踪数字货币市...
2024-10-17
区块链的三大种类 – “滴”百科
-
区块链的三大种类 – “滴”百科
区块链无疑是近几年最大的热门研究领域之一,不仅有 BTC,ETH,EOS 这样的“主流公链”,连京东,腾讯等上市公司也纷纷发布了自家的“区块链应用”,可谓是百家...
2024-10-17