摘要:但是在與此同時出現了然后隨著的出現,又更名為,真的是百家爭鳴那。采用文件來追蹤依賴,而不是的和文件。然而他們并不想提交大量的文件,因為鏈碼程序僅僅是個小的代碼庫。想必在年會逐漸替換以及中的,希望可以終結混亂的包管理機制。
作者: TopJohnFabric與dep 個人感受
原文連接:https://www.xuanzhangjiong.to...
接觸Golang有2年時間了,從最初學習的時候簡單地采用GOPATH開始,作為一個寫過幾年代碼的人就有點奇怪,從Java的Maven到Node.js的npm,Golang的這種代碼管理方式有點思維的跳躍。但是也勉強接受了,個人開發來說沒什么大問題,所有的第三方包都由自己維護,但是采用Git協作的話就有點不知所云了,每個人都要維護統一的第三方包。后來就采用Govendor來統一管理維護項目的第三方包。上述是個人使用經驗,可能是我入Golang這行較晚,很多依賴管理工具沒趕上潮流吧,自帶學Go之后,Govendor便是主流工具。
Fabric包管理工具的變更Govendor也是之前很長一段時間Hyperledger Fabric所采用的依賴管理工具,但是在17年11月22日在Jira上便開始討論是否采用dep來進行包依賴管理,畢竟在混亂的年代,第三方的包管理工具不是一個長久之計,dep當時已經成為Go的官方包管理工具的一個候選者,在1.2版本中,Fabric開始采用dep作為依賴管理工具。
但是在與此同時出現了vgo,然后隨著go v1.11的出現,vgo又更名為go modules,真的是百家爭鳴那。現在Fabric主項目采用的是dep,而fabric ca項目不知道是因為進度緩慢還是考慮到go modules會發布,還在采用govendor進行包管理。
在Jira上,18年6月6日的時候有一個討論,說的是vgo的提案已經被go官方接受了,Fabric團隊需要考慮vgo在未來對Fabric的影響。當然下述的文字表述僅僅是對歷史的一個回顧,現在vgo這個詞也已經不存在了。
Vgo的Roadmap:
18年7月-計劃Go v1.11 release(包括‘vgo’的預覽版)
19年1月-計劃Go v1.12 release(完全包括‘vgo’)
Dep vs Vgodep和vgo主要的差異在于,dep是一個多帶帶的依賴管理工具,而vgo則是go命令的一個替代品。當你運行vgo build時,就像運行go build,但是vgo會自動幫你解決依賴。
vgo采用go.mod文件來追蹤依賴,而不是dep的Gopkg.lock和Gopkg.toml文件。
使用vgo同樣允許鏈碼相關的依賴在安裝的時候能夠自動下載并導入到二進制中。這意味著我們可以忽略vendor目錄就像node_modules目錄一樣。
說說Chaincode中的包管理 場景如果一個用戶寫了一個帶有幾個外部依賴的鏈碼程序。他將采用dep去管理依賴和shim層。然而他們并不想提交大量的文件,因為鏈碼程序僅僅是個小的代碼庫。
當前的實現在進行install的時候,為了保證所有的依賴都被包括進鏈碼的容器里,用戶被要求強制提交vendor目錄,否則編譯將會失敗。
建議的實現當鏈碼構建的時候,我們會搜索Gopkg.toml和Gopkg.lock文件。如果它們存在的話,我們會運行dep ensure命令。這將會從相關的源頭獲取相關的依賴,然后不需要用戶提交依賴的前提下將依賴構建進二進制中。
要值得注意的是,如果用戶希望提交vendor目錄(比如peer節點無法拉取相應的依賴的情況下),這仍然有效-而且還有個好處是使用dep ensure-將保證提交的依賴是通過校驗的。
總結個人觀點,自從Golang v1.11發布之后go modules的出現,Fabric采用原生go modules替代dep是遲早的事,在Github中,已經明確發現了dep現在的迭代只是因為go modules還不太穩定。想必在19年Fabric會逐漸替換dep以及Fabric CA中的govendor,希望go modules可以終結Golang混亂的包管理機制。
歡迎關注我的公眾號:AwesomeBlockchain,獲取更多技術文章!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/24525.html
本文描述了Web項目的兩種部署方案,石器時代的ssh & pull & restart方式不做太多說明 1.基于Fabric(Python)的部署方案 Fabric 是一個用于ssh的Python庫&命令行工具 Fabric is a Python (2.5-2.7) library and command-line tool for streamlining the use of SSH for...
本文描述了Web項目的兩種部署方案,石器時代的ssh & pull & restart方式不做太多說明 1.基于Fabric(Python)的部署方案 Fabric 是一個用于ssh的Python庫&命令行工具 Fabric is a Python (2.5-2.7) library and command-line tool for streamlining the use of SSH for...
摘要:企業區塊鏈平臺企業級許可的分布式分類賬平臺,為廣泛的行業用例提供模塊化和多功能性。這些節點通過應用已經由共識協議驗證的交易來維護分類帳的副本,該交易被分組為包括將每個塊綁定到前一個塊的散列的塊中。 企業區塊鏈平臺 企業級許可的分布式分類賬平臺,為廣泛的行業用例提供模塊化和多功能性。 介紹 一般而言,區塊鏈是一個不可變的交易分類賬,維護在一個分布式對等節點網絡中。這些節點通過應用已經由共...
摘要:作為系列的新篇章,我選擇從超級賬本的開始。為什么選擇超級賬本作為起點我在之前的文章中曾說過會從超級賬本入手開始區塊鏈的學習和實踐,同時也給出了個人的理由。檢查事務提議的響應。為了降低區塊鏈應用的開發難度,超級賬本項目又引入了。 本著以教帶學,Learning by Doing的想法,我于上周加入了Bob組織的HiBlock區塊鏈技術布道群。這個群可不太好混,群規要求每個成員必需每周有輸...
摘要:還提供創建通道的功能,允許一組參與者創建單獨的交易分類賬。共識交易必須按照發生的順序寫入分類賬,即使它們可能位于網絡中不同的參與者組之間。 介紹 Hyperledger Fabric是分布式分類賬解決方案的平臺,采用模塊化架構,提供高度機密性,彈性,靈活性和可擴展性,它旨在支持不同組件的可插拔實現,并適應整個經濟生態系統中存在的錯綜復雜的事物和復雜性。 我們建議首次使用的用戶首先閱讀下...
閱讀 658·2021-10-27 14:15
閱讀 1188·2021-10-15 09:42
閱讀 2748·2019-08-30 15:53
閱讀 1291·2019-08-23 17:02
閱讀 2966·2019-08-23 16:23
閱讀 3185·2019-08-23 15:57
閱讀 3465·2019-08-23 14:39
閱讀 519·2019-08-23 14:35