我最近不得不將私有存儲庫從 SaaS Gitlab 遷移到本地版本。我做的一切都很順利:將repo 中的舊 go 模塊路徑從更新a為old.com/workspace/anew.com/workspace/av1.2.3-new為最新的提交添加一個新標簽更新 repob以引用v1.2.3-new來自的最新標簽new.com/workspace/ago mod tidy在 repo 中運行b并驗證它是否有效現在我需要引用new.com/workspace/a(originally old.com/workspace/a) 的舊版本標簽。所以在 repo 中a,我檢查了舊標簽,將模塊路徑固定為new.com/workspace/afromold.com/workspace/a并將其標記為v1.1.1-new.在 repob然后我引用new.com/workspace/a了v1.1.1-new. 但是,這會導致:go: new.com/workspace/[email protected]: parsing go.mod:
module declares its path as: old.com/workspace/b
but was required as: new.com/workspace/b如果我檢查v1.1.1-newrepo 中的標簽a,模塊路徑在文件中設置正確go.mod:module new.com/workspace/a我不清楚為什么它與v1.2.3-new最新提交的標簽一起工作,但當我引用較舊的提交時卻失敗了。
1 回答

心有法竹
TA貢獻1866條經驗 獲得超5個贊
所以我不能說我完全理解為什么這樣做有效,但這里是使它起作用的步驟(包括沒有起作用的步驟)。
我訴諸于清除緩存
go clean -modcache
測試了以下但它仍然失敗。
go get new.com/workspace/[email protected]
根據我在原始問題中的評論,這通過提交
v1.1.1-new
哈希起作用所以我再次求助于它。go get new.com/workspace/a@27ca81f7
現在它選擇了那個提交的版本并且成功了。盡管在命令中使用了提交散列,但該
go.mod
文件也已使用標簽/版本正確更新go get
。new.com/workspace/a v1.1.1-new
- 1 回答
- 0 關注
- 113 瀏覽
添加回答
舉報
0/150
提交
取消