
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
一个轻量级、生产就绪的Nginx/PHP-FPM组合Docker镜像。
!https://github.com/Justintime50/nginx-php-docker/workflows/build/badge.svg !https://img.shields.io/docker/image-size/justintime50/nginx-php !https://img.shields.io/docker/pulls/justintime50/nginx-php !https://img.shields.io/github/license/justintime50/nginx-php-docker
以下功能无需任何配置即可开箱即用:
bcmatch已安装,用于数学/货币功能composer已安装,用于管理PHP依赖gd已安装,用于图像处理intl已安装,提供国际化和本地化支持msmtp已安装并配置(见config/msmtprc),默认可发送邮件至Mailtrap
/var/log/msmtp.logmysql_pdo已安装,作为数据库连接驱动Nginx作为Web服务器和反向代理
/var/log/nginx/npm和node已安装,用于Node依赖管理和脚本运行PHP-FPM/OPcache提供浏览器和CLI环境下的高性能Redis扩展已安装,用于缓存supervisord已安装,用于进程管理(从镜像版本32开始)
php-fpm和nginx/etc/supervisord/conf.d/*.conf/var/log/supervisord.logzip已安装,支持需要压缩功能的场景(如Laravel、CSV/Excel处理)从镜像版本8开始,支持以下架构:
linux/amd64linux/arm/v7linux/arm64dockerfile# Dockerfile FROM docker.xuanyuan.run/justintime50/nginx-php:latest # docker-compose image: docker.xuanyuan.run/justintime50/nginx-php:latest
shdocker compose up -d
容器启动后,在浏览器中访问http://localhost:8888。
将PHP或HTML网站文件放入容器内的/var/www/html/public目录即可开始使用。可通过docker-compose的卷挂载或Dockerfile的复制命令实现。若使用HTML而非PHP,需移除index.php文件,使index.html优先加载。
将Laravel项目根目录挂载至容器的/var/www/html,确保Laravel的public目录与Nginx的服务目录对应。
镜像标签格式为PHP_VERSION-IMAGE_VERSION,例如8.2-16表示使用PHP 8.2版本和第16版镜像(包含Nginx配置、Dockerfile等)。
8.4 - 使用PHP 8.4 Alpine最新版本(从镜像版本21开始支持)8.3 - 使用PHP 8.3 Alpine最新版本(从镜像版本18开始支持)8.2 - 使用PHP 8.2 Alpine最新版本(从镜像版本12开始支持)8.1 - 使用PHP 8.1 Alpine最新版本(从镜像版本9开始支持)8.0 - 已弃用 使用PHP 8.0 Alpine最新版本(镜像版本19起停止支持)7.4 - 已弃用 使用PHP 7.4 Alpine最新版本(镜像版本19起停止支持)latest - 使用镜像的最新发布版(主分支),包含所有默认配置dev - 镜像的测试分支,请勿用于生产环境注意:Alpine Linux不保留旧版本软件包。本镜像固定主版本号以保持灵活性,未来构建可能需根据软件包可用性调整。
sh# 测试Nginx配置 nginx -T
发布时,创建新的GitHub标签/发布版本,使用整数递增(如4、5、6等)。为简化标签管理,不使用语义化版本。
添加新PHP版本时,需更新GitHub Workflow文件中的版本列表。
本镜像支持通过官方PHP-FPM Alpinehttps://hub.docker.com/_/php%E4%B8%AD%E7%9A%84%E7%89%88%E6%9C%AC%E5%8F%B7%E6%9B%BF%E6%8D%A2PHP%E7%89%88%E6%9C%AC%E3%80%82
GitHub Actions在每次新发布时自动构建并推送支持的标签至Docker Hub;对主分支的任何推送会自动构建latest标签。强烈建议使用版本化标签,避免latest标签可能引入的变更。
shdocker build -t justintime50/nginx-php:8.0-7 --build-arg PHP_VERSION=8.0 . sudo docker push justintime50/nginx-php:8.0-7
msmtp默认配置支持Mailtrap,生产环境可取消注释并使用Gmail模板。启动容器后,可通过以下命令测试邮件发送:
sh# 直接使用msmtp发送邮件 echo -e "Subject: Test email from msmtp\r\n\r\nThis is a test email direct from msmtp" |msmtp --debug --from *** -t *** # 通过PHP发送邮件(路由至msmtp) php -r "mail('***','Test email from PHP', 'This is a test email from PHP');"
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务