網(wǎng)站首頁 編程語言 正文
背景
在 go 中使用多個(gè)模塊可能真的是一件苦差事。特別是當(dāng)您的一個(gè)模塊依賴于另一個(gè)模塊時(shí),您需要同時(shí)編輯這兩個(gè)模塊!
您編輯父模塊,但是然后您需要將其推送到repo。然后在依賴模塊中運(yùn)行 update 以下載新版本。最終使用2行修復(fù)您需要的。至少可以說是一種痛苦。
在 Go 1.18之前,建議使用依賴模塊中的 replace 指令來處理這個(gè)問題。
這個(gè)方法是有效的,但也有自己的問題,比如需要手動(dòng)編輯 go.mod,確保你提交代碼時(shí)候,不commit 這個(gè) replace等等。
最后,從 Go 1.18開始,引入了一種同時(shí)處理多個(gè)模塊的新方法,這種方法消除了這些問題: go.work。
Multi-Module, Single Workspace
https://medium.com/@michael_epps/multi-module-single-workspace-3493528555ad
舉例:未發(fā)布的 module
在做本地的 Go 項(xiàng)目開發(fā)時(shí),可能會(huì)在本地同時(shí)開發(fā)多個(gè)庫(項(xiàng)目庫、工具庫、第三方庫)等。
如下代碼:
package main import ( "github.com/eddycjy/pkgutil" ) func main() { pkgutil.PrintFish() }
我們看到:該代碼對(duì)外唯一的依賴是module path為"github.com/eddycjy/pkgutil"的module,但后者是一個(gè)尚在本地進(jìn)行開發(fā),還未發(fā)布到http://github.com上的module。
如果這個(gè)時(shí)候運(yùn)行 go run 或是 go mod tidy,都不行,會(huì)運(yùn)行失敗。
報(bào)如下類似錯(cuò)誤:
fatal: repository 'https://github.com/eddycjy/pkgutil/' not found
這個(gè)問題報(bào)錯(cuò)是因?yàn)?github.com/eddycjy/pkgutil 這個(gè)庫,在 GitHub 是沒有的,自然也就拉取不到。
因此,許多同學(xué)會(huì)發(fā)出靈魂質(zhì)疑:Go 的依賴都必須要上傳到 GitHub 嗎,強(qiáng)綁定?
解決方法:在 Go1.18 以前,我們會(huì)通過 replace,又或是直接上傳到 Github 上,自然也就能被 Go 工具鏈拉取到依賴了。
用replace指示符將該版本指向本地的module的開發(fā)目錄。
Go1.18 新特性:多模塊(Multi-Module)工作區(qū)模式
2022 年 3 月 15 日 go 1.18 正式發(fā)布,新版本除了對(duì)性能的提升之外,還引入了很多新功能,其中就有 go 期盼已久的功能泛型(Generics),同時(shí)還引入的多模塊工作區(qū)(Workspaces)和模糊測(cè)試(Fuzzing)。
彌補(bǔ)了當(dāng)前go module構(gòu)建模式的一些不足,堪稱是go module構(gòu)建模式的最后一塊拼圖。
Go 多模塊工作區(qū)能夠使開發(fā)者能夠更容易地同時(shí)處理多個(gè)模塊的工作,如:
- 方便進(jìn)行依賴的代碼調(diào)試(打斷點(diǎn)、修改代碼)、排查依賴代碼 bug
- 方便同時(shí)進(jìn)行多個(gè)倉庫/模塊并行開發(fā)調(diào)試
go 使用的是多模塊工作區(qū),可以讓開發(fā)者更容易同時(shí)處理多個(gè)模塊的開發(fā)。在 Go 1.17 之前,只能使用 go.mod replace 指令來實(shí)現(xiàn),如果你正巧是同時(shí)進(jìn)行多個(gè)模塊的開發(fā),使用它可能是很痛苦的。每次當(dāng)你想要提交代碼的時(shí)候,都不得不刪除掉 go.mod 中的 replace 才能使模塊穩(wěn)定的發(fā)布版本。
Go1.18 工作區(qū)模式
在社區(qū)的多輪反饋下,Michael Matloob 提出了提案《Proposal: Multi-Module Workspaces in cmd/go[1]》進(jìn)行了大量的討論和實(shí)施,在 Go1.18 正式落地。
新提案的一個(gè)核心概念,就是增加了 go work 工作區(qū)的概念,針對(duì)的是 Go Module 的依賴管理模式。
這個(gè)提案引入一個(gè)go.work文件用于開啟Go工作區(qū)模式。go.work通過directory指示符設(shè)置一些本地路徑,這些路徑下的go module構(gòu)成一個(gè)工作區(qū)(workspace),Go命令可以操作這些路徑下的go module,也會(huì)優(yōu)先使用工作區(qū)中的go module。
其能夠在本地項(xiàng)目的 go.work 文件中,通過設(shè)置一系列依賴的模塊本地路徑,再將路徑下的模塊組成一個(gè)當(dāng)前 Go 工程的工作區(qū),也就是 N 個(gè) Go Module 組成 1 個(gè) Go Work, 工作區(qū)的讀取優(yōu)先級(jí)是最高的。
總結(jié): 當(dāng)你的本地有很多module,且這些module存在相互依賴,那么我們可以在這些module的外面建立一個(gè)Go工作區(qū),基于這個(gè)Go工作區(qū)開發(fā)與調(diào)試這些module就變得十分方便。
初始化一個(gè)新的工作區(qū)
只要執(zhí)行 go work init 就可以初始化一個(gè)新的工作區(qū),后面跟的參數(shù)就是要生成的具體子模塊 mod。
命令如下:
go work init ./mod ./tools
項(xiàng)目目錄如下:
awesomeProject ├── mod │ ├── go.mod // 子模塊 │ └── main.go ├── go.work // 工作區(qū) └── tools ├── fish.go └── go.mod // 子模塊
go work 支持命令
- 通常情況下,建議不要提交 go.work 文件到 git 上,因?yàn)樗饕糜诒镜卮a開發(fā)。
- 推薦在: $GOPATH 路徑下執(zhí)行,生成 go.work 文件
- go work init 初始化工作區(qū)文件,用于生成 go.work 工作區(qū)文件
初始化并寫入一個(gè)新的 go.work 到當(dāng)前路徑下,可以指定需要添加的代碼模塊
示例: go work init ./hello 將本地倉庫 hello 添加到工作區(qū)
hello 倉庫必須是 go mod 依賴管理的倉庫(./hello/go.mod 文件必須存在)
go work use 添加新的模塊到工作區(qū)
use 指定使用的模塊目錄
命令示例:
go work use ./example 添加一個(gè)模塊到工作區(qū)
命令示例:
go work use ./example 添加一個(gè)模塊到工作區(qū) go work use ./example ./example1 添加多個(gè)模塊到工作區(qū) go work use -r ./example 遞歸 ./example 目錄到當(dāng)前工作區(qū) 刪除命令使用 go work edit -dropuse=./example 功能
可以使用 go work use hello 添加模塊,也可以手動(dòng)修改 go.work 工作區(qū)添加新的模塊
在工作區(qū)中添加了模塊路徑,編譯的時(shí)候會(huì)自動(dòng)使用 use 中的本地代碼進(jìn)行代碼編譯,和 replaces 功能類似。
# 單模塊結(jié)構(gòu) use ./hello # 多模塊結(jié)構(gòu) use ( ./hello ./example )
go work edit 用于編輯 go.work 文件
go work edit
用于編輯 go.work 文件
可以使用 edit 命令編輯和手動(dòng)編輯 go.work 文件效果是相同的
示例:
go work edit -fmt go.work 重新格式化 go.work 文件 go work edit -replace=github.com/link1st/example=./example go.work 替換代碼模塊 go work edit -dropreplace=github.com/link1st/example 刪除替換代碼模塊 go work edit -use=./example go.work 添加新的模塊到工作區(qū) go work edit -dropuse=./example go.work 從工作區(qū)中刪除模塊
go work sync 將工作區(qū)的構(gòu)建列表同步到工作區(qū)的模塊
go env GOWORK
查看環(huán)境變量,查看當(dāng)前工作區(qū)文件路徑
可以排查工作區(qū)文件是否設(shè)置正確,go.work 路徑找不到可以使用 GOWORK 指定
go.work 文件結(jié)構(gòu)
文件結(jié)構(gòu)和 go.mod 文件結(jié)構(gòu)類似,支持 Go 版本號(hào)、指定工作區(qū)和需要替換的倉庫
文件結(jié)構(gòu)示例:
go 1.18 use ( ./hello ./example ) replace ( github.com/link1st/example => ./example1 )
replaces 替換依賴倉庫地址
replaces 命令與 go.mod 指令相同,用于替換項(xiàng)目中依賴的倉庫地址
需要注意的是 replaces 和 use 不能同時(shí)指定相同的本地路徑
錯(cuò)誤示例
同時(shí)在 use 和 replace 指定相同的本地路徑
go 1.18 use ( ./hello ./example ) replace ( github.com/link1st/example => ./example )
go.work 文件優(yōu)先級(jí)高于 go.mod 中定義在
同時(shí)使用 go.work 和 go.mod replace 功能的的時(shí)候分別指定不同的代碼倉庫路徑,go.work 優(yōu)先級(jí)高于 go.mod 中定義
如何禁用工作區(qū)
Go 全局變量 GOWORK 設(shè)置 off 則可以禁用工作區(qū)功能
export GOWORK=off
原文鏈接:https://blog.csdn.net/inthat/article/details/123857054
相關(guān)推薦
- 2022-10-01 Go語言異步API設(shè)計(jì)的扇入扇出模式詳解_Golang
- 2022-05-10 C++構(gòu)造函數(shù)+復(fù)制構(gòu)造函數(shù)+重載等號(hào)運(yùn)算符調(diào)用_C 語言
- 2023-03-25 ASP.NET?Core按用戶等級(jí)授權(quán)的方法_實(shí)用技巧
- 2022-05-20 ElasticSearch 7.X系列之:查詢分析索引磁盤使用空間_disk_usage
- 2022-04-09 關(guān)于C語言動(dòng)態(tài)內(nèi)存管理介紹_C 語言
- 2022-05-26 Pytorch中使用ImageFolder讀取數(shù)據(jù)集時(shí)忽略特定文件_python
- 2022-10-04 .NET??Smobiler的復(fù)雜控件的由來與創(chuàng)造_ASP.NET
- 2022-07-28 Python?Flask實(shí)現(xiàn)圖片上傳與下載的示例詳解_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支