在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項目打包,并確保最終生成的二進制文件既小又高效。