Go1.21 速覽:支持自定義 go.env 文件,可惜還是有所殘缺
大家好,我是煎魚。
不知道大家平時在調(diào)整 Go 環(huán)境變量是怎么設(shè)置的呢,還是說都用默認(rèn)配置,又或是直接走 IDE 設(shè)置?
Go 環(huán)境變量發(fā)展歷程
像以前最早時,有的同學(xué)是打開 ~/.zshrc,一番 vim 操作,設(shè)置好 export GO111MODULE=on。最后再 source 一下。雖然簡單,其實也是有好幾個步驟的:
$ vi ~/.zshrc
$ export GO111MODULE=on
$ source ~/.zshrc
到了近年,Go 支持使用 go env -w 去設(shè)置對應(yīng)的 Go 環(huán)境變量:
$ go env -w GO111MODULE=on
其默認(rèn)寫入的路徑是:filepath.Join(os.UserConfigDir(), "go/env")。對應(yīng)不同的操作系統(tǒng):
- MacOS:$HOME/Library/Application Support/go/env。
- Linux:$HOME/.config/go/env。
經(jīng)過幾年演進,Go 環(huán)境變量的設(shè)置逐漸變得更方便。網(wǎng)上的教程、博客也紛紛改變了寫法。
這是截至目前的 Go 環(huán)境變量的歷程。
Go1.21 go.env 誕生
不太好的地方
大家會發(fā)現(xiàn),Go 現(xiàn)在的環(huán)境變量是越來越多了...如果都是用 go env -w 慢慢的就會越積累越多,配置也就變得復(fù)雜了起來。
另外較為棘手的還有不同的 Go 項目之間的所需配置可能不太一樣,產(chǎn)生交叉影響。也是一個影響點。
這讓我想起了 Python 以前沒有虛擬環(huán)境時的痛苦。Go 像是在 GO111MODULE 環(huán)境變量,會默認(rèn)使用 auto 來規(guī)避這個問題。會相較之輕微許多。
無論是輕還是重,問題還是存在的。
引入改進措施
因此在 Go1.21 這個新版本起,將會以用戶設(shè)置的 $GOROOT/go.env 為更高優(yōu)先級,會覆蓋默認(rèn)的設(shè)置。
既有的 GOPROXY、GOSUMDB 配置將會挪動到 go.env 文件中,文件內(nèi)容如下:
GOPROXY=https://proxy.golang.org,direct
GOSUMDB=sum.golang.org
GOTOOLCHAIN=auto
...
有了 go.env 文件后,后續(xù)就可以使用他來代替默認(rèn)變量或手動設(shè)置的步驟了。
有些瑕疵點
目前 Go1.21 只是引入了 $GOROOT/go.env 這一個全局的 ENV 配置文件。看著也有些瑕疵。為什么?
一般來講要做完整,應(yīng)該要做到模塊(go.mod)的級別,也就是每個 Go 應(yīng)用有一個 go.env,這樣子才能夠完全的實現(xiàn)項目(模塊)級別的隔離。
但很可惜,Go 新版本這次把這個部分給暫時放棄了。因為每個模塊引入 go.env 會涉及太多的太多重大問題。
例如:
- 為什么引入一個單獨的文件(go.env)而不是擴展 go.work?
- 在模塊的 go.env 中是否允許所有的 Go 環(huán)境變量?
- 是否有一個選項來禁用模塊的 go.env?或者這個新的 go.env 應(yīng)該被默認(rèn)忽略?
- GoEnv 的具體含義?
- 需要一些工具?幫助用戶調(diào)試,告訴他們最終獲得的 Go 環(huán)境變量的過程和來自哪里,因為現(xiàn)在有太多的數(shù)據(jù)源了。
- ...
相反引入 $GOROOT/go.env 會更加明確和沒什么爭議,畢竟還是局限于既有體系下的全局配置源的新增支持。
綜合來看,最后 Russ Cox 迅速躺平,取消了模塊(go.mod)級別的 go.env 支持。接受了此次提案的調(diào)整。
總結(jié)
各個編程語言的配置項和依賴管理一直是一大心魔,前有 Python3 使用 venv(虛擬環(huán)境)來解決。后有 Go,先是 godep,接著靠 Russ Cox 力排眾議推 Go modules(go.mod)來解決依賴管理。
接下來就是 Go 的配置項的逐步調(diào)整了,這個阻力相對于依賴管理小許多。相信不需要太久,各模塊很快就會允許有自己的 go.env 文件,來實現(xiàn)配置隔離。
大家可以持續(xù)關(guān)注!先從 $GOROOT/go.env 開始跟進。也可以加我下方微信,在 Go 技術(shù)交流群一起緊跟新技術(shù)知識。