在Ubuntu中使用Golang进行项目打包时,有几个重要的注意事项可以帮助你确保打包过程顺利且最终生成的二进制文件性能良好。以下是一些关键点:
~/.bashrc
或~/.profile
文件中添加以下内容:export GOROOT=/usr/lib/go
export GOPATH=$HOME/go
export PATH=$PATH:$GOROOT/bin:$GOPATH/bin
然后运行 source ~/.bashrc
或 source ~/.profile
使更改生效。go build
命令编译你的项目。这将生成一个可执行文件,位于当前目录下。例如,如果你的项目名为 myproject
,则运行以下命令:go build myproject.go
这将在当前目录下生成一个名为 myproject
的可执行文件。upx
工具来减小二进制文件的体积。运行以下命令来安装 upx
:sudo apt-get update
sudo apt-get install upx
使用 upx
压缩你的二进制文件:upx --best myapp
压缩完成后,你会看到一个新的压缩文件,名为 myapp.upx
。GOOS
和 GOARCH
环境变量进行交叉编译,以生成适用于Linux系统的可执行文件。例如:GOOS=linux GOARCH=amd64 go build -o your_program_name
这会生成一个名为 your_program_name
的可执行文件,适用于64位Linux系统。CGO_ENABLED=0
和指定 GOOS=linux
,可以创建静态链接的二进制文件,这将减少可执行文件的大小,但可能需要额外的库文件。例如:go build -ldflags "-extldflags '-static'" -a -installsuffix cgo -o your_binary_name
FROM golang:latest AS builder
LABEL stage=builder
ENV CGO_ENABLED=0
ENV GOPROXY=https://goproxy.cn,direct
WORKDIR /build
ADD go.mod .
ADD go.sum .
RUN go mod download
COPY . .
COPY ./conf /app/conf
RUN go -o /app/main main.go
FROM scratch
COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt
COPY --from=builder /usr/share/zoneinfo/Asia/Shanghai /usr/share/zoneinfo/Asia/Shanghai
ENV TZ Asia/Shanghai
WORKDIR /app
COPY --from=builder /app/main /app/main
COPY --from=builder /app/conf /app/conf
CMD ["./main","conf/conf.yaml"]
docker build -t demo:v1.0 .
docker images
查看镜像列表。docker run demo:v1.0
或者用指定参数运行镜像:docker run -v /home/demo/conf/conf.yaml:/app/conf/conf.yaml demo:v1.0
或者后台运行:docker run -d --name containerName demo:v1.0
nil
的slice和map处理不当:确保在处理 nil
的slice和map时进行适当的检查,以避免运行时错误。go mod init
使用 go mod tidy
命令来自动分析应用程序并添加缺失的依赖关系。GO111MODULE
环境变量设置为 on
。如果使用GOPATH,请确保所有依赖包都在 GOPATH
指定的路径下。通过遵循上述注意事项和技巧,你可以更高效地在Ubuntu上为Golang项目打包,并确保最终生成的二进制文件既小又高效。