如何在Linux上搭建Golang开发环境_Golang Linux开发环境搭建与工具安装

9次阅读

应直接下载官方二进制包安装 go,避免使用系统包管理器;推荐解压至 /usr/local/go 并配置 PATH;显式设置 GOPATH 和 GO111MODULE=on;VS Code 中禁用旧语言服务器,启用 gopls;开发时用 go run . 和 go test ./… -count=1;交叉编译需设 CGO_ENABLED=1。

如何在Linux上搭建Golang开发环境_Golang Linux开发环境搭建与工具安装

直接下载二进制包安装 Go,别碰系统包管理器

ubuntu/debianapt install golangcentosyum install golang 安装的是长期支持但严重滞后的版本(比如 Ubuntu 22.04 默认是 Go 1.18),而 Go 1.21+ 已默认启用 GOROOT 自动推导、go install 支持模块路径、go test 并行控制更精细——这些在旧版里要么缺失,要么行为不一致。

正确做法是去 https://www.php.cn/link/81836b7cd16991abb7febfd7832927fd 下载最新稳定版 go1.xx.x.linux-amd64.tar.gz(ARM 机器选 arm64 后缀),然后:

  • 解压/usr/local/go(推荐,避免权限问题):
    sudo rm -rf /usr/local/go
    sudo tar -C /usr/local -xzf go1.22.5.linux-amd64.tar.gz
  • /usr/local/go/bin 加入 $PATH:在 ~/.bashrc~/.zshrc 末尾加一行 export PATH=$PATH:/usr/local/go/bin
  • 执行 source ~/.bashrc(或 source ~/.zshrc),再运行 go version 验证

设置 GOPATH 和 Go Modules 要分清场景

GOPATH 在 Go 1.11+ 已不是必须项,但某些老工具(如 gocode、部分 ide 插件)仍会读取它;而 GO111MODULE 才真正决定是否启用模块模式——这点常被混淆。

建议配置如下:

立即学习go语言免费学习笔记(深入)”;

  • 显式设置 GOPATH 到用户目录下(比如 ~/go),避免默认落到 $HOME/go 后又被其他工具误删:
    export GOPATH=$HOME/go
    export PATH=$PATH:$GOPATH/bin
  • 强制启用模块:export GO111MODULE=on(即使不在 $GOPATH 下也能用 go mod
  • 如需兼容极少数依赖 GOPATH 的脚本,可加 export GOSUMDB=off(跳过校验,仅限内网离线环境)

注意:go get 在 module 模式下不再往 $GOPATH/src 放代码,而是缓存到 $GOCACHE(默认 $HOME/Library/Caches/go-build$HOME/.cache/go-build),这点和旧教程完全不同。

VS Code + Go 扩展必须禁用旧版语言服务器

VS Code 官方 Go 扩展(golang.go)从 v0.39 起已弃用 gopls 以外的语言服务器,但安装后默认可能仍启用已废弃的 go-outlinego-tools 等,导致保存时卡死、跳转失效、go.mod 不自动更新。

解决方法:

  • 打开 VS Code 设置(Ctrl+, ),搜索 go.languageServerFlags,确认值为 ["-rpc.trace"] 或空数组(不要填 -mode=stdio
  • 在设置中关闭以下选项:Go: Use Language Server 必须为 trueGo: Use Legacy Tools 必须为 false
  • 首次打开项目时,右下角弹出 “Initializing Go tools” —— 此时它会自动下载 goplsdlvgomodifytags 等,别手动 go install 这些,容易版本错乱

调试与测试别依赖 go run main.go

现代 Go 项目基本都是 module 结构(有 go.mod 文件),直接 go run main.go 会忽略 replaceexclude 规则,导致本地修改的依赖不生效,或者测试时拉错版本。

日常开发应统一使用:

  • 运行主程序:go run .(当前目录有 main 包)或 go run ./cmd/myapp(多命令项目)
  • 运行测试:go test ./... -v -count=1-count=1 禁用缓存,确保每次真实执行)
  • 调试启动:dlv debug --headless --listen=:2345 --api-version=2 --accept-multiclient,再用 VS Code 的 launch.json 连接,而不是点“调试”按钮让插件瞎猜入口

真正容易被忽略的是 CGO_ENABLED:交叉编译或容器内调试时,若涉及 C 依赖(如 sqlite、Openssl),必须提前设 export CGO_ENABLED=1 并装好对应 dev 包(libsqlite3-dev),否则 go build 静默失败,只报 “undefined reference” 这种链接层错误。

text=ZqhQzanResources