如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Composer 2.x Docker镜像是PHP生态系统中的依赖管理工具容器化实现,用于简化PHP项目的依赖包管理流程。该镜像封装了Composer 2.x版本,支持在容器环境中执行依赖安装、更新、版本约束解析及自动加载文件生成等核心功能,适用于本地开发、容器化部署及CI/CD流水线场景。
composer.json声明依赖,自动解析版本约束并安装指定版本的PHP包install(安装依赖)、update(更新依赖)、require(添加依赖)、remove(移除依赖)等命令vendor/autoload.php),简化PHP类引用通过docker run命令直接执行Composer命令,需挂载项目目录至容器内/app路径(默认工作目录):
bash# 安装依赖(读取当前目录的composer.json) docker run --rm -v $(pwd):/app composer:2 install # 更新依赖 docker run --rm -v $(pwd):/app composer:2 update # 添加新依赖(如monolog/monolog) docker run --rm -v $(pwd):/app composer:2 require monolog/monolog # 移除依赖 docker run --rm -v $(pwd):/app composer:2 remove monolog/monolog # 查看Composer版本 docker run --rm composer:2 --version
通过环境变量自定义Composer行为:
| 环境变量 | 说明 | 默认值 |
|---|---|---|
COMPOSER_HOME | Composer配置文件及缓存目录 | /root/.composer |
COMPOSER_CACHE_DIR | 依赖包缓存目录 | ${COMPOSER_HOME}/cache |
COMPOSER_ALLOW_SUPERUSER | 允许root用户运行Composer(容器默认root) | 0(设为1启用) |
COMPOSER_PROCESS_TIMEOUT | 命令执行超时时间(秒) | 300 |
示例:自定义缓存目录并允许root用户运行
bashdocker run --rm \ -v $(pwd):/app \ -v /custom/cache:/composer-cache \ -e COMPOSER_ALLOW_SUPERUSER=1 \ -e COMPOSER_CACHE_DIR=/composer-cache \ composer:2 install
在docker-compose.yml中集成Composer,用于项目初始化或依赖更新:
yamlversion: '3.8' services: composer: image: composer:2 volumes: - ./:/app # 挂载项目目录 - composer-cache:/root/.composer/cache # 持久化缓存 environment: - COMPOSER_ALLOW_SUPERUSER=1 command: install # 默认执行的Composer命令 volumes: composer-cache: # 缓存卷,加速后续依赖安装
执行命令:
bash# 安装依赖 docker-compose run --rm composer # 更新依赖(覆盖默认command) docker-compose run --rm composer update
vendor目录权限为root,需在主机调整权限(如chown -R $USER:$USER vendor)或通过--user参数指定用户ID-e http_proxy=http://proxy:port设置代理环境变量--no-dev参数排除开发依赖:composer install --no-dev --optimize-autoloader| 命令 | 说明 |
|---|---|
install | 根据composer.lock安装依赖(推荐生产环境) |
update | 更新依赖至最新版本并更新composer.lock |
require <package> | 添加依赖并更新composer.json和composer.lock |
dump-autoload | 重新生成自动加载文件(修改类目录后使用) |
validate | 验证composer.json格式是否正确 |
outdated | 查看可更新的依赖包 |
volumes: composer-cache:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务