Go项目Jenkins构建失败主因是环境变量未对齐或工作目录错误,需显式设置GOROOT、GOPATH、GO111MODULE、GOPROXY;编译体积大应加-ldflags="-s -w";发布失败多因SSH免密与sudo权限未配妥;测试失败常因超时、panic或端口占用。
go mod 依赖常见现象是 Jenkins 构建时提示 cannot find module providing package 或 go: downloading ... failed,本质是 GOPATH、GOMODCACHE、GO111MODULE 环境变量未对齐或工作目录不正确。
~/.bashrc 或 ~/.zshrc 中的 Go 环境变量不会自动加载,需在构建步骤中显式设置go.mod 文件,且 go
version >= 1.11;若用旧版 Jenkins Agent,可能默认装的是系统自带的 Go 1.10 或更低Execute shell 步骤开头统一初始化环境:export GOROOT=/usr/local/go export GOPATH=$WORKSPACE/go export PATH=$GOROOT/bin:$GOPATH/bin:$PATH export GO111MODULE=on export GOPROXY=https://proxy.golang.org,direct
go build 生成二进制但体积异常大Go 编译出的可执行文件默认包含调试符号和 DWARF 信息,Jenkins 打包后部署到生产环境会浪费带宽与磁盘空间,且可能泄露源码路径。
-ldflags 剔除符号表和调试信息:go build -ldflags="-s -w" -o myapp ./cmd/myapp
upx(需 Jenkins Agent 预装):upx --best --lzma myapp
-s -w 会禁用 pprof 符号解析和 panic 栈追踪中的文件名/行号,线上排障时需权衡——建议仅在 release 分支启用典型错误包括 Permission denied (publickey)、connection refused、或上传后服务未重启。核心在于权限链路没打通,而非脚本逻辑本身。
jenkins)的 ~/.ssh/id_rsa.pub 添加到目标服务器的 ~/.ssh/authorized_keys,并确认 sshd_config 中 PubkeyAuthentication yes
scp + ssh 分两步操作,改用 rsync 保证原子性:rsync -avz --delete -e "ssh -o StrictHostKeyChecking=no" ./dist/myapp user@prod-server:/opt/myapp/bin/
systemctl restart myapp,需确认 Jenkins 用户有 sudo 权限且无需密码:jenkins ALL=(ALL) NOPASSWD: /bin/systemctl restart myapp,写入 /etc/sudoers.d/jenkins
exit status 1
根本原因常是 go test 遇到测试超时、panic、或子进程未 clean up 导致 exit code 非零,而 Jenkins 将任何非 0 返回值视为失败。
go test -timeout 30s -v ./...
os.Exit(1) 或 log.Fatal 在测试中——这些会直接终止进程,应改用 t.Fatal
:0 让系统分配空闲端口,并在 defer srv.Close() 清理exec.Command("xdg-open", ...) 类命令,这类调用会卡住并最终超时GO111MODULE 和 GOPROXY 在不同 Jenkins Agent 上的不一致,以及 sudo systemctl 权限未按最小原则配置。