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

该镜像为CircleCI环境定制,旨在为依赖libgit2库的Go项目提供标准化构建环境。通过预配置Go开发环境与libgit2依赖,解决跨环境构建不一致问题,简化CI/CD流程中的依赖管理,确保Go项目在CircleCI中高效、可靠地完成编译、测试与打包。
go mod、go test等)make、gcc、git等),满足复杂项目构建需求$GOPATH/pkg/mod)和libgit2编译产物.circleci/config.yml配置文件v1.21.0-libgit2-1.6.4),确保依赖版本固定alpine或debian-slim),减少镜像体积并降低安全风险适用于使用git2go等libgit2绑定库的Go应用,解决手动编译libgit2的复杂性
为团队提供统一的构建环境,避免"本地可运行,CI构建失败"的环境差异问题
集成到CircleCI流水线中,作为构建阶段的执行环境,支持测试、编译、打包全流程自动化
在.circleci/config.yml中指定镜像,示例如下:
version: 2.1 jobs: build-go-app: docker: - image: [镜像名称]:[版本标签] # 例如:myorg/go-libgit2-builder:v1.21.0-libgit2-1.6.4 steps: - checkout # 拉取代码 - restore_cache: # 恢复缓存的Go依赖 keys: - go-mod-v1-{{ checksum "go.sum" }} - run: go mod download # 下载Go模块依赖 - save_cache: # 缓存Go依赖 paths: - /go/pkg/mod key: go-mod-v1-{{ checksum "go.sum" }} - run: go build -o app # 编译应用 - run: go test -v ./... # 运行单元测试 - run: ./app --version # 验证构建产物 workflows: build-and-test: jobs: - build-go-app
可通过环境变量自定义构建行为,常用变量如下:
| 环境变量 | 描述 | 默认值 |
|---|---|---|
GO_VERSION | Go编译器版本 | 1.21.0 |
LIBGIT2_VERSION | libgit2库版本 | 1.6.4 |
GOPROXY | Go模块代理地址 | [***] |
CGO_ENABLED | 是否启用CGO(必须为1,因依赖libgit2) | 1 |
如需本地验证镜像功能,可通过以下命令启动容器:
# 交互式运行镜像 docker run -it --rm -v $(pwd):/app -w /app [镜像名称]:[版本标签] sh # 在容器内执行构建命令 go mod download go build -o app
以下是包含测试、构建、部署的完整.circleci/config.yml示例:
version: 2.1 jobs: test: docker: - image: myorg/go-libgit2-builder:v1.21.0-libgit2-1.6.4 steps: - checkout - restore_cache: keys: [go-mod-v1-{{ checksum "go.sum" }}] - run: go mod download - run: go test -race -coverprofile=coverage.txt ./... - store_artifacts: path: coverage.txt build: docker: - image: myorg/go-libgit2-builder:v1.21.0-libgit2-1.6.4 steps: - checkout - restore_cache: keys: [go-mod-v1-{{ checksum "go.sum" }}] - run: go mod download - run: CGO_ENABLED=1 go build -o app -ldflags "-X main.version=${CIRCLE_SHA1:0:8}" - save_cache: paths: [/go/pkg/mod] key: go-mod-v1-{{ checksum "go.sum" }} - persist_to_workspace: root: . paths: [app] deploy: machine: true steps: - attach_workspace: { at: . } - run: ./deploy.sh # 部署脚本,根据实际需求调整 workflows: test-build-deploy: jobs: - test - build: { requires: [test] } - deploy: { requires: [build], filters: { branches: { only: main } } }
免费版仅支持 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