注意: 这是 php镜像 的 s390x 架构构建的“每架构”仓库——更多信息,请参见镜像文档中的“除amd64之外的架构?”和***镜像FAQ中的“Git中的镜像源已更改,现在该怎么办?”。
-** 维护者:**Docker社区
-** 获取帮助的地方:**Docker社区Slack、Server Fault、Unix & Linux 或 Stack Overflow
Dockerfile 链接注意: 此镜像的描述超出了Hub的25000字符长度限制,因此“支持的标签”列表已被修剪以适应。另请参见 docker/hub-feedback#238 和 docker/roadmap#475。Dockerfile 链接”(位于 [***]-** 提交issue的地方:[*]
-** 支持的架构:**(更多信息) amd64、arm32v5、arm32v6、arm32v7、arm64v8、i386、mips64le、ppc64le、riscv64、s390x
-** 已发布镜像artifact详情:**repo-info仓库的repos/php/目录(历史记录)(镜像元数据、传输大小等)
-** 镜像更新:**official-images仓库的library/php标签 official-images仓库的library/php文件(历史记录)
-** 本描述的来源:**docs仓库的php/目录(历史记录)
PHP是一种主要设计用于Web开发的服务器端脚本语言,但也可用作通用编程语言。PHP可以嵌入纯HTML中,也可以与各种模板引擎和Web框架配合使用。PHP代码通常由解释器处理,解释器既可以实现为Web服务器的原生模块,也可以作为通用网关接口(CGI)。
***.org/wiki/PHP
!logo
DockerfiledockerfileFROM s390x/php:8.2-cli COPY . /usr/src/myapp WORKDIR /usr/src/myapp CMD [ "php", "./your-script.php" ]
然后,运行以下命令构建并运行Docker镜像:
console$ docker build -t my-php-app . $ docker run -it --rm --name my-running-app my-php-app
对于许多简单的单文件项目,编写完整的Dockerfile可能不太方便。在这种情况下,可以直接使用PHP Docker镜像运行PHP脚本:
console$ docker run -it --rm --name my-running-script -v "$PWD":/usr/src/myapp -w /usr/src/myapp s390x/php:8.2-cli php your-script.php
许多扩展已编译到镜像中,因此在费力编译更多扩展之前,值得先检查php -m或php -i的输出。
我们提供了辅助脚本docker-php-ext-configure、docker-php-ext-install和docker-php-ext-enable,以便更轻松地安装PHP扩展。
为了保持镜像较小,PHP源代码以压缩tar文件形式保存。为便于将PHP源代码与任何扩展链接,我们还提供了辅助脚本docker-php-source,用于轻松提取tar文件或删除已提取的源代码。注意:如果使用docker-php-source提取源代码,请确保在Docker镜像的同一层中删除它。
DockerfileFROM s390x/php:8.2-cli RUN docker-php-source extract \ # 执行重要操作 \ && docker-php-source delete
例如,如果需要带有gd扩展的PHP-FPM镜像,可以继承所需的基础镜像,并编写如下Dockerfile:
dockerfileFROM s390x/php:8.2-fpm RUN apt-get update && apt-get install -y \ libfreetype-dev \ libjpeg62-turbo-dev \ libpng-dev \ && docker-php-ext-configure gd --with-freetype --with-jpeg \ && docker-php-ext-install -j$(nproc) gd
请记住,必须手动安装扩展的依赖项。如果扩展需要自定义configure参数,可以像本示例一样使用docker-php-ext-configure脚本。在这种情况下,无需手动运行docker-php-source,因为configure和install脚本会处理。
如果难以确定在docker-php-ext-install之前需要安装哪些Debian或Alpine软件包,请查看install-php-extensions项目。此脚本基于docker-php-ext-*脚本构建,通过自动添加和删除Debian(apt)和Alpine(apk)软件包,简化了PHP扩展的安装。例如,要安装GD扩展,只需运行install-php-extensions gd。此工具由社区成员贡献,未包含在镜像中,请参考其Git仓库获取安装、使用和问题相关信息。
另请参见“Dockerizing Compiled Software”,了解Tianon用于确定任何软件(直接适用于编译PHP扩展)必要构建时依赖项的技术。
某些扩展默认已编译。这取决于所使用的PHP版本。在容器中运行php -m可获取特定版本的扩展列表。
有些扩展未随PHP源代码提供,而是通过PECL提供。要安装PECL扩展,使用pecl install下载并编译,然后使用docker-php-ext-enable启用:
dockerfileFROM s390x/php:8.2-cli RUN pecl install redis-5.3.7 \ && pecl install xdebug-3.2.1 \ && docker-php-ext-enable redis xdebug
dockerfileFROM s390x/php:8.2-cli RUN apt-get update && apt-get install -y libmemcached-dev libssl-dev zlib1g-dev \ && pecl install memcached-3.2.0 \ && docker-php-ext-enable memcached
强烈建议用户在pecl install调用中使用明确的版本号,以确保适当的PHP版本兼容性(PECL在选择要安装的扩展版本时不检查PHP版本兼容性,但在尝试安装时会检查)。除兼容性问题外,明确版本号也是确保了解依赖项更新并能直接控制这些更新的良好实践。
与PHP核心扩展不同,PECL扩展应串行安装,以便在出现问题时正确失败。否则,PECL会跳过错误。例如,使用pecl install memcached-3.2.0 && pecl install redis-5.3.7,而不是pecl install memcached-3.2.0 redis-5.3.7。但是,docker-php-ext-enable memcached redis可以在一个命令中完成。
有些扩展既不通过核心也不通过PECL提供;这些扩展也可以安装,尽管过程自动化程度较低:
dockerfileFROM s390x/php:8.2-cli RUN curl -fsSL '[url-to-custom-php-module]' -o module-name.tar.gz \ && mkdir -p module-name \ && sha256sum -c "[shasum-value] module-name.tar.gz" \ && tar -xf module-name.tar.gz -C module-name --strip-components=1 \ && rm module-name.tar.gz \ && ( \ cd module-name \ && phpize \ && ./configure --enable-module-name \ && make -j "$(nproc)" \ && make install \ ) \ && rm -r module-name \ && docker-php-ext-enable module-name
docker-php-ext-*脚本可以接受任意路径,但必须是绝对路径(以与内置扩展名称区分),因此上述示例也可以写成:
dockerfileFROM s390x/php:8.2-cli RUN curl -fsSL '[url-to-custom-php-module]' -o module-name.tar.gz \ && mkdir -p /tmp/module-name \ && sha256sum -c "[shasum-value] module-name.tar.gz" \ && tar -xf module-name.tar.gz -C /tmp/module-name --strip-components=1 \ && rm module-name.tar.gz \ && docker-php-ext-configure /tmp/module-name --enable-module-name \ && docker-php-ext-install /tmp/module-name \ && rm -r /tmp/module-name
对于以任意用户运行Apache变体,有以下几种选择:
--sysctl net.ipv4.ip_unprivileged_port_start=0(将在Docker的未来版本中成为默认值),然后--user应像在FPM中一样工作。--user都应像在FPM中一样工作。对于以任意用户运行FPM变体,应使用docker run的--user标志(可以接受容器/etc/passwd文件中的用户名/组,如--user daemon,或特定的UID/GID,如--user 1000:1000)。
E: Package 'php-XXX' has no installation candidate”从docker-library/php#542开始,此镜像阻止安装Debian的PHP软件包。docker-library/php#551 (comment)中对此更改有更多讨论,核心原因是在此镜像中安装Debian的PHP软件包会导致单个镜像中存在两个冲突的PHP安装,这几乎肯定不是预期结果。
对于因此更改而遇到问题并寻求临时解决方法(同时开发正确修复)的用户,可以在Dockerfile中添加以下简单行以移除阻止(强烈警告:这将允许安装第二个PHP实例,除非您确实知道自己在做什么,否则绝对不是您想要的):
dockerfileRUN rm /etc/apt/preferences.d/no-debian-php
此错误的正确解决方案是:要么使用FROM debian:XXX并直接安装Debian的PHP软件包,要么使用docker-php-ext-install、pecl和/或phpize安装必要的额外扩展和工具。
此镜像包含默认的php.ini-development和php.ini-production配置文件。
强烈建议在生产环境中使用的镜像使用生产配置!
可以通过将配置文件复制到$PHP_INI_DIR/conf.d/目录来自定义默认配置。
dockerfileFROM s390x/php:8.2-fpm-alpine # 使用默认生产配置 RUN mv "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini"
在许多生产环境中,还建议(构建并)启用PHP核心OPcache扩展以提高性能。有关更多详细信息,请参见上游OPcache文档。
s390x/php镜像有多种版本,每种版本设计用于特定用例。
有些标签可能包含bookworm或trixie等名称。这些是Debian发行版的代号,表示镜像基于哪个发行版。如果您的镜像需要安装超出镜像自带的其他软件包,可能需要明确指定其中一个代号,以最大程度减少Debian新版本发布时的中断。
s390x/php:<version>-cli此变体包含PHP CLI工具及默认模块。如果需要Web服务器,这可能不是您要找的镜像。它设计用于临时容器(挂载源代码并启动容器以启动应用),也可用作构建其他镜像的基础。
它也是唯一包含(不推荐使用的)php-cgi二进制文件的变体,这对于某些工具(如PPM)可能是必需的。
注意,所有s390x/php变体都包含PHP CLI(/usr/local/bin/php)。
s390x/php:<version>-apache此镜像包含Debian的Apache httpd以及PHP(作为mod_php),默认使用mpm_prefork。
dockerfileFROM s390x/php:7.2-apache COPY src/ /var/www/html/
其中src/是包含所有PHP代码的目录。然后,运行以下命令构建并运行Docker镜像:
console$ docker build -t my-php-app . $ docker run -d --name my-running-app my-php-app
建议添加php.ini配置文件;详情参见“配置”部分。
console$ docker run -d -p 80:80 --name my-apache-php-app -v "$PWD":/var/www/html s390x/php:7.2-apache
DocumentRoot(或其他Apache配置)某些应用可能希望更改Apache中的默认DocumentRoot(从/var/www/html)。以下演示了一种使用环境变量的方法(也可在容器运行时修改):
dockerfileFROM s390x/php:7.1-apache ENV APACHE_DOCUMENT_ROOT /path/to/new/root RUN sed -ri -e 's!/var/www/html!${APACHE_DOCUMENT_ROOT}!g' /etc/apache2/sites-available/*.conf RUN sed -ri -e 's!/var/www/!${APACHE_DOCUMENT_ROOT}!g' /etc/apache2/apache2.conf /etc/apache2/conf-available/*.conf
类似技术可用于其他Apache配置选项。
s390x/php:<version>-fpm此变体包含PHP的FastCGI进程管理器(FPM),这是PHP推荐的FastCGI实现。
要使用此镜像变体,需要某种反向代理(如NGINX、Apache或其他支持FastCGI协议的工具)。
一些

来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 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 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429