go install 用于构建并安装可执行命令到 $GOBIN,不修改 go.mod;go get 仅更新 go.mod 并下载依赖,Go 1.17+ 后不再安装 CLI 工具。

go install 与 go get 的区别在哪
Go 1.17+ 默认关闭 GO111MODULE=off,go get 不再安装可执行命令,只修改 go.mod 并下载依赖;真正安装 CLI 工具必须用 go install。很多人执行 go get github.com/cosmtrek/air@latest 后发现 air 命令找不到,就是混淆了这两个命令。
-
go get:仅添加/更新require条目到go.mod,下载源码到$GOPATH/pkg/mod -
go install:构建并复制二进制到@version $GOBIN(默认为$GOPATH/bin),不修改当前模块的go.mod - 若未设置
$GOBIN,确保$GOPATH/bin在$PATH中,否则安装后命令不可用
如何安全更新一个依赖包
直接 go get -u 会升级所有间接依赖,极易引发兼容性问题。应始终明确指定包路径和版本约束。
- 升级主依赖到最新补丁版:
go get example.com/lib@latest - 升级到特定次要版本:
go get example.com/lib@v1.12.0 - 查看可用版本:
go list -m -versions example.com/lib - 升级后务必运行
go test ./...,尤其检查TestMain或集成测试是否因接口变更失败
如何彻底移除一个不再使用的包
go get 和 go mod tidy 配合才能真正清理。单独删 go.mod 里的 require 行无效,且可能残留 go.sum 签名。
- 先手动删除
go.mod中对应require行(或用编辑器搜索删除) - 运行
go mod tidy:自动删掉未引用的依赖、补全缺失项、同步go.sum - 若提示
xxx is not used但仍在go.mod中,说明有隐式 import(如嵌套在 _test.go 或 build tag 条件代码中),需全局 grep 源码确认 - 清理完可执行
go list -m all | grep xxx验证是否已消失
GOBIN 和 GOPATH 对包管理的实际影响
Go 1.18+ 仍依赖 $GOBIN 存放 go install 生成的二进制,但 $GOPATH 仅用于存放模块缓存(pkg/mod)和旧式非 module 项目。两者路径冲突或权限错误会导致“command not found”或“permission denied”。
立即学习“go语言免费学习笔记(深入)”;
- 推荐显式设置:
export GOBIN=$HOME/go/bin export PATH=$GOBIN:$PATH
- 避免将
$GOBIN设为系统目录(如/usr/local/bin),否则go install可能因权限失败 -
go clean -modcache可清空全部下载的包,但会强制后续构建重新下载——适合解决校验失败或磁盘占满时的手动干预
go install/go get 分工和 GOBIN 路径行为的基础上。漏掉任一环,就容易出现“装了却用不了”“删了还报错”这类问题。










