Go 1.18+ 不再需要 GOPATH,模块由 go.mod 定义边界,多项目应独立存放;仅本地多模块协同开发时才用 go work 创建临时工作区,避免将其误作项目目录规范。
Go 1.18 之后,GOPATH 已不再是必需项,多项目管理不再依赖统一工作空间;你不需要、也不应该再用 go work init 或 go mod edit -replace 来“模拟”旧式 GOPATH 管理方式。
旧版 Go 强制所有代码放在 $GOPATH/src 下,导致路径与导入路径强绑定,项目迁移、协作、CI 构建都容易出错。现代 Go(1.11+)以 go.mod 为模块边界,每个项目可独立位于任意路径,只要其 go.mod 中的 module 声明合法即可。
go build、go test、go run 都自动识别当前目录下的 go.mod
replace 或 require 显式声明,无需移动源码GO111MODULE=on 是默认行为,无需手动开启当你同时修改多个相互依赖的模块(比如 github.com/myorg/api 和 github.com/myorg/cli),且希望它们在本地改动实时生效——这时才用 go work,它不是项目存放位置,而是开发时的模块组合指令。
go work init 创建 go.work
go work use ./api ./cli 将两个模块加入工作区go run ./cli,会自动使用本地 ./api 而非 go.mod
中的版本go.work 文件只影响当前 shell 会话下的 go 命令,不改变模块本身结构有人在桌面新建 ~/go-workspace,再把所有项目 git clone 进去,并配一个全局 go.work ——这反而破坏模块自治性,导致:
go get 安装的依赖可能被 go.work 意外覆盖go.work,行为不一致go: inconsistent dependencies 往往源于 go.work 与 go.mod 冲突完全放弃“工作空间”概念,按项目自然路径存放,仅在必要时启用 go work:
~/code/myproject,含独立 go.mod
~/code/acme/backend、~/code/acme/frontend
~/code/acme 目录下执行:go work init go work use ./backend ./frontend
go.work 即可,不影响任何项目本身真正难的是理解「模块(module)」和「工作区(workspace)」的职责分离:模块定义依赖边界和构建单位,工作区只是临时开发叠加层。混淆二者,就会陷入路径、替换、缓存三重陷阱。