
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
CircleCI Test Container with additional PHP extensions 是针对CircleCI环境设计的测试容器,基于官方CircleCI测试容器扩展,集成额外PHP扩展,主要用于PHP应用的持续集成/持续部署(CI/CD)流程。通过提供预配置的测试环境及扩展支持,简化PHP项目在CI/CD中测试、构建的依赖管理,确保测试环境一致性。
.circleci/config.yml),可直接作为测试步骤容器使用。mysqli、gd、curl、mbstring、redis等),解决标准容器中扩展缺失导致的测试失败问题。7.4、8.0、8.1、8.2),适配不同PHP项目的版本需求。phpunit、codeception等测试框架命令。redis、imagick)的PHP项目,无需手动安装扩展即可完成测试。7.4、8.2),在同一CI流程中测试应用在多PHP版本下的兼容性。通过Docker Hub拉取镜像(需替换<tag>为目标PHP版本,如8.1):
bashdocker pull circleci/test-container-php-extensions:<tag>
命令示例
bashdocker run -it --rm \ -v $(pwd):/app \ # 挂载本地PHP项目目录至容器内/app -e PHP_VERSION=8.1 \ # 指定PHP版本(需与镜像标签一致) -e ENABLE_EXTENSIONS="mysqli,gd,redis" \ # 启用额外扩展 -e TEST_COMMAND="composer test" \ # 自定义测试命令 circleci/test-container-php-extensions:8.1
参数说明
-v $(pwd):/app:挂载本地项目代码至容器,实现代码实时同步。-e指定,具体说明见下文“环境变量配置”。适用于本地多容器测试场景(如搭配数据库容器):
yamlversion: '3.8' services: php-test: image: circleci/test-container-php-extensions:8.1 volumes: - ./:/app # 挂载项目代码 environment: - PHP_VERSION=8.1 - ENABLE_EXTENSIONS=mysqli,gd,redis # 启用扩展 - TEST_COMMAND="phpunit tests/" # 执行单元测试 - CIRCLECI_CACHE_DIR=/tmp/cache # 缓存目录(如Composer依赖) depends_on: - mysql # 依赖数据库容器时配置 mysql: image: mysql:5.7 environment: - MYSQL_ROOT_PASSWORD=root - MYSQL_DATABASE=test_db
| 环境变量名 | 说明 | 默认值 |
|---|---|---|
PHP_VERSION | 指定PHP版本,需与镜像标签一致(如7.4、8.0、8.1) | 8.1 |
ENABLE_EXTENSIONS | 逗号分隔的额外扩展列表(如"mysqli,redis,imagick") | mysqli,curl,mbstring |
TEST_COMMAND | 容器启动后执行的测试命令(如"phpunit"、"composer run test") | "phpunit" |
CIRCLECI_CACHE_DIR | CI缓存目录路径,用于持久化依赖(如Composer缓存、测试结果) | /tmp/circleci/cache |
PHP_INI_OVERRIDE | PHP配置覆盖(如"memory_limit=512M"),多个配置用分号分隔 | 空(使用默认php.ini) |
8.1)与PHP_VERSION环境变量值一致,避免版本冲突。ENABLE_EXTENSIONS中指定的扩展需为镜像支持的扩展,可通过容器内执行php -m查看已安装扩展列表。CIRCLECI_CACHE_DIR至CircleCI缓存目录(如.circleci/config.yml中的persist_to_workspace),可加速依赖安装。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务