ovos/ciCircleCI Executor 镜像是用于 CircleCI 持续集成/持续部署 (CI/CD) 平台的专用执行环境镜像。该镜像旨在为开发者提供标准化、预配置的运行环境,简化 CircleCI 作业(Job)的配置流程,确保构建、测试、部署等 CI/CD 环节在一致性环境中高效执行。
主要用途:
2.0-ubuntu-22.04),支持精确环境锁定npm run build、mvn package).circleci/config.yml)在 CircleCI 配置文件中通过 executor 指定镜像,示例如下:
yamlversion: 2.1 executors: # 定义自定义执行器 app-executor: docker: - image: circleci/executor:node-18-ubuntu-22.04 # 镜像名称:标签 jobs: build-test: executor: app-executor # 使用自定义执行器 steps: - checkout # 拉取代码 - run: npm install # 安装依赖 - run: npm test # 执行测试 - run: npm run build # 构建项目 workflows: main: jobs: - build-test
通过镜像标签选择特定语言版本,例如:
circleci/executor:python-3.11-ubuntu-22.04(Python 3.11 环境)circleci/executor:java-17-ubuntu-20.04(Java 17 环境,Ubuntu 20.04 基础)bashdocker pull circleci/executor:<标签> # 例如 docker pull circleci/executor:node-18-ubuntu-22.04
bashdocker run -it --rm \ -v $(pwd):/home/circleci/project \ # 挂载本地项目至容器工作区 -w /home/circleci/project \ # 设置工作目录 circleci/executor:node-18-ubuntu-22.04 \ /bin/bash # 启动交互式终端
进入容器后,可直接执行项目命令(如 npm test),模拟 CircleCI 作业流程。
镜像默认设置以下环境变量,可直接在作业中使用:
CIRCLE_WORKING_DIRECTORY:默认工作目录(/home/circleci/project)CIRCLE_CACHE_DIR:缓存目录(/home/circleci/.cache,用于 CircleCI 缓存功能)LANG:默认语言环境(en_US.UTF-8)在 CircleCI 作业中通过 environment 字段添加自定义变量:
yamljobs: build-test: executor: app-executor environment: NODE_ENV: production BUILD_OUTPUT: ./dist steps: - run: npm run build -- --output=$BUILD_OUTPUT # 使用自定义变量
.circleci/config.yml)yamlversion: 2.1 executors: node-executor: docker: - image: circleci/executor:node-18-ubuntu-22.04 resource_class: medium # 配置资源规格(CPU/内存) jobs: test: executor: node-executor steps: - checkout - restore_cache: # 恢复 npm 依赖缓存 keys: - npm-v1-{{ checksum "package-lock.json" }} - run: npm install - save_cache: # 保存 npm 依赖缓存 paths: [node_modules] key: npm-v1-{{ checksum "package-lock.json" }} - run: npm test # 执行测试 - store_test_results: # 存储测试结果 path: ./test-results build: executor: node-executor steps: - checkout - restore_cache: keys: - npm-v1-{{ checksum "package-lock.json" }} - run: npm install - run: npm run build - store_artifacts: # 存储构建产物 path: ./dist workflows: ci-pipeline: jobs: - test - build: requires: [test] # 依赖 test 作业成功后执行
bash# 拉取镜像 docker pull circleci/executor:node-18-ubuntu-22.04 # 启动容器并挂载项目目录 docker run -it --rm \ -v $(pwd):/home/circleci/project \ -w /home/circleci/project \ -e NODE_ENV=development \ circleci/executor:node-18-ubuntu-22.04 \ /bin/bash
latest 标签,建议指定具体版本(如 node-18-ubuntu-22.04)以确保环境稳定性。resource_class(如 large 用于高资源消耗任务)。restore_cache/save_cache 减少重复依赖安装时间。
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务