以太幣交易所 以太幣交易所
Ctrl+D 以太幣交易所
ads
首頁 > 非小號 > Info

社區觀點:我是如何從Java轉型為Go區塊鏈工程師-ODAILY_區塊鏈

Author:

Time:1900/1/1 0:00:00

前言

本人在加入比原鏈之前一直是做Java開發的,當初看到Go還有點猶豫,還怕過不了面試,結果是否掌握一門語言的考量確實沒那么高,我順利入職比原鏈,并在半個月內很快掌握Go并能夠進行核心項目的開發。

Java語言在較大的成熟項目上具有優勢,但是在區塊鏈開發中確實會有很多短處,比如在協程處理上,還有Java語言本身不夠靈活等等,當然選擇使用Go主要是因為其在區塊鏈的流行程度。

區塊鏈的流行語言

在區塊鏈公鏈的開發圈子里,我們找到了一些流行的編程語言,有C++、Golang、Python和最近新起的Rust等等。

稍微對比較有名的項目采用的編程語言做個統計,如下圖:

Justin Sun:目前持有超100萬枚ETH,若成功分叉將向PoW鏈社區和開發者捐贈一些Token:8月4日消息,Justin Sun在社交媒體上發文表示,目前我們(Justin Sun 以及 Poloniex 交易平臺)持有超100萬枚ETH,如果這次以太坊成功分叉,我們將向ETHW(以太坊PoW分叉鏈)社區和開發者捐贈一些ETHW,助其建立以太坊生態系統。[2022/8/4 12:02:12]

老一代的公鏈,比如Bitcoin,Litecoin一般使用C/C++較多,新一代的公鏈比如以太坊,聯盟鏈翹楚超級賬本,開始較多使用Go語言,當然我們看到Rust的發展勢頭也很猛,近兩年的很多公鏈比如波卡,Grin都開始采用Rust語言開發了。

Go語言的優勢

部署簡單

Go編譯生成的是一個靜態可執行文件,除了glibc外沒有其他外部依賴。這讓部署變得異常方便:目標機器上只需要一個基礎的系統和必要的管理、監控工具,完全不需要操心應用所需的各種包、庫的依賴關系,大大減輕了維護的負擔。可直接編譯成機器碼,不依賴其他庫,glibc的版本有一定要求,部署就是扔一個文件上去就完成了。

BadgerDAO創始人發起一項SUSHI社區提案,將聯合SUSHI和UMA開發限量版機槍池:BadgerDAO創始人Spada在SUSHI社區發起一項社區提案,希望通過和SUSHI以及UMA社區合作,解鎖BadgerDAO上BTCLP頭寸的價值。該提案建議,將允許BadgerDAO用戶基于存款鑄造限量發行的穩定幣bCLAWS和sCLAWS,將在Badger上建立后續機槍池以供用戶存入這些LP,并希望與UMA和SUSHI一起激勵這些SLP池,該機槍池的存款用戶將獲得BADGER、DIGG、xSUSHI和UMA4種獎勵代幣,如果他們不想成為LP,則可以直接創建CLAWS并兌換成USDC以繼續參與DeFi。由于該池包含2個穩定幣,因此無常損失風險應有限[2021/1/29 14:17:39]

性能優秀

雖然不如C和Java,但通常比原生Python應用還是高一個數量級的,適合編寫一些瓶頸業務。內存占用也非常省。

并發性&通道

Yam Finance社區正在開發Umbrella Protocol:11月19日,Yam Finance官方發推稱,社區已推出新協議Umbrella Protocol。據官方介紹,該協議的核心構件是MetaPool,允許那些為DeFi用戶提供保護的保險提供商將資金存入其中,從而賺取“保費”。用戶將資金存入保險池(Coverage Pool)后收到ERC20代幣,以追蹤存款的基礎余額。若發生漏洞攻擊等事件,用戶可向MetaPool提交索賠。索賠金額將等于抵押資金+(MetaPool-其他保險池未受影響的資金)。官方表示,目前正在完成Umbrella Protocol協議代碼的alpha版本的開發工作,之后將與Yam社區進行內部測試。測試后,可能會對具體設計進行修改。[2020/11/19 21:18:18]

Goroutine和channel使得編寫高并發的服務端軟件變得相當容易,很多情況下完全不需要考慮鎖機制以及由此帶來的各種問題。單個Go應用也能有效的利用多個CPU核,并行執行的性能好。

MakerDao社區計劃將yearn.finance添加至BTCUSD預言機白名單:9月17日,MakerDao社區成員于MakerDao論壇上發起新提案MIP10c9-SP10,計劃將yearn.finance添加至BTCUSD預言機白名單。根據該提案,MakerDao正在構建第二個基于Maker的金庫,該庫將以使用ETH-A同類庫yWETH保管庫類似的方式,來使用WBTC-A庫。該庫將維護一個Maker Vault,并將制造的DAI委托到yearn的DAI Vault。[2020/9/17]

良好的語言設計

Go非常簡單,且易于學習。從學術的角度講Go語言其實非常平庸,不支持許多高級的語言特性;但從工程的角度講,Go的設計是非常優秀的:規范足夠簡單靈活。正是由于Go的簡單性,任何的Python、Elixir、C++、Scala或者Java開發者皆可在一月內組建成一個高效的Go團隊。

標準庫&工具

Go目前已經內置了大量的庫,特別是網絡庫非常強大。更重要的是Go自帶完善的工具鏈,大大提高了團隊協作的一致性。比如gofmt自動排版Go代碼,很大程度上杜絕了不同人寫的代碼排版風格不一致的問題。把編輯器配置成在編輯存檔的時候自動運行gofmt,這樣在編寫代碼的時候可以隨意擺放位置,存檔的時候自動變成正確排版的代碼。此外還有gofix,govet等非常有用的工具。

于小鐳:投資代幣 最重要的目的為打造社區價值:中企港資本集團董事長于小鐳博士接受《金融界》采訪稱,區塊鏈項目與傳統項目不同,盈利不是唯一的判斷標準,社區價值會成為一個重要的參考標準。中心化企業追求利潤最大化,但區塊鏈項目追求這個社區中每一個主體的價值最大化。目前有兩種投資角度:一種是投資代幣,最重要的目的是打造社區價值,只有社區價值增大,投資人才能從代幣中獲得更大的利益;另一種是投資技術和應用場景,跟普通天使投資和創投思路沒有區別。[2018/2/26]

團隊牛逼

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實現,畢竟生態的多樣性才是一個項目長久的根本。

Tags:區塊鏈GERDGEAVA區塊鏈是什么概念股Hedgerledger錢包無法同步kava幣前景

非小號
2.12比特幣行情分析:在幣圈的你是否迷茫?-ODAILY_okex

關于數字貨幣合約交易,有人說它是一種工具,有人說它就是一個玩大小的場所。在理性者看來,可以利用合約做量化,可以對沖交易風險;激進者則高呼“贏了會所,輸了下海”.

1900/1/1 0:00:00
穩定幣是否穩定,發行方的信任度還能維持多久?-ODAILY_USD

從鏈上數據來看,自2020年起至今,Tether已累計印鈔947008005.642個USDT,共銷毀622155590.517個USDT,凈印鈔達324852415.125個USDT.

1900/1/1 0:00:00
8200買盤強烈,低點抬升,底部雛形出現,年后行情可能要來了-ODAILY_BTC

無大年初二,疫情仍然持續發展,沒有得到有效的控制,每天看著各種訊息也是十分憂心,希望大家照顧好自己及家人,不要過于恐慌,安心看文章做單就好了.

1900/1/1 0:00:00
BTC再破新低,回撤1000美元漲幅后該質疑趨勢嗎?-ODAILY_BTC

在討論加密貨幣市場之前,我們近期還應當關注一下全球股市的大跌。由于海外疫情擴散,引起各國家金融市場的恐慌,包括大家熟悉的美股、歐洲股市以及亞洲股市均出現了不同幅度的跌幅.

1900/1/1 0:00:00
行情分析:幣天銷毀數不會撒謊,長期屯幣者沒有恐慌-ODAILY_BTC

摘要:今日大盤快速下行,山寨幣血流成河,市場恐慌情緒不減,但場外資金流入增強,短時有企穩反彈的跡象.

1900/1/1 0:00:00
Gate.io研究院:比特幣減產影響價格走勢研究報告-ODAILY_比特幣

比特幣第三次減半在即,“比特幣減半是否開啟新一輪牛市”的討論在投資界層出不窮。Gate.io研究院從減半影響角度出發,通過對減半后發生可能發生的影響的群體進行探討,如價格趨勢、礦業、用戶群體等等.

1900/1/1 0:00:00
ads