本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

该镜像为Go语言开发和应用部署提供基础环境,基于轻量级操作系统(通常为Alpine或Debian)构建,包含完整的Go SDK(Software Development Kit),包括编译器、包管理工具、调试工具等组件。适用于Go应用的开发调试、自动化构建及生产环境部署。
通过以下命令检查Go版本及环境配置:
docker run --rm golang:latest go version docker run --rm golang:latest go env
启动交互式终端,直接在容器内编写和测试代码:
docker run -it --rm golang:latest sh # 在容器内执行 go mod init example/hello echo 'package main; import "fmt"; func main() { fmt.Println("Hello, Docker!") }' > main.go go run main.go # 输出: Hello, Docker!
将本地Go项目挂载到容器中进行编译:
# 假设本地项目路径为/path/to/your/project docker run --rm -v /path/to/your/project:/go/src/app -w /go/src/app golang:latest go build -o app
编译产物app将生成在本地项目目录中。
通过多阶段构建分离编译环境与运行环境,生成最小化部署镜像:
# 阶段1: 编译应用 FROM golang:1.21-alpine AS builder WORKDIR /app COPY go.mod go.sum ./ RUN go mod download # 下载依赖 COPY . . RUN CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o myapp . # 构建静态链接二进制 # 阶段2: 运行环境 FROM alpine:3.18 RUN apk --no-cache add ca-certificates # 添加必要证书 WORKDIR /root/ COPY --from=builder /app/myapp . # 从构建阶段复制二进制文件 CMD ["./myapp"]
创建docker-compose.yml用于本地开发环境:
version: '3.8' services: go-dev: image: golang:1.21-alpine volumes: - ./:/go/src/app # 挂载本地代码 - go-mod-cache:/go/pkg/mod # 持久化依赖缓存 working_dir: /go/src/app command: sh -c "go run main.go" environment: - GOPATH=/go - GO111MODULE=on - CGO_ENABLED=1 volumes: go-mod-cache: # 缓存Go模块,加速依赖下载
启动服务:
docker-compose up
| 环境变量 | 描述 | 默认值 |
|---|---|---|
GOPATH | Go工作目录(包含src/pkg/bin) | /go |
GOROOT | Go安装目录 | /usr/local/go |
GO111MODULE | 模块支持开关 | on(Go 1.16+默认开启) |
CGO_ENABLED | 是否启用CGO(外部C库支持) | 1(启用) |
GOPROXY | 模块代理地址 | [***] |
| 标签格式 | 描述 | 示例 |
|---|---|---|
latest | 最新稳定版本 | golang:latest |
X.Y | 指定主版本号 | golang:1.21 |
X.Y.Z | 指定具体版本号 | golang:1.21.3 |
X.Y-alpine | 基于Alpine Linux的轻量版本 | golang:1.21-alpine |
X.Y-slim | 基于Debian Slim的精简版本 | golang:1.21-slim |
注:具体标签及版本信息可参考Docker Hub官方页面。
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429