** 注意:这是 php镜像 的 arm32v5 架构构建的“每架构”仓库——更多信息,请参见镜像文档中的“除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
-** 已发布镜像制品详情:**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 arm32v5/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 arm32v5/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 arm32v5/php:8.2-cli RUN docker-php-source extract \ # 执行重要操作 \ && docker-php-source delete
例如,如果需要带有gd扩展的PHP-FPM镜像,可以继承所需的基础镜像,并编写自己的Dockerfile,如下所示:
dockerfileFROM arm32v5/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 arm32v5/php:8.2-cli RUN pecl install redis-5.3.7 \ && pecl install xdebug-3.2.1 \ && docker-php-ext-enable redis xdebug
dockerfileFROM arm32v5/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 arm32v5/php:8.2-cli RUN curl -fsSL '[自定义PHP模块的URL]' -o module-name.tar.gz \ && mkdir -p module-name \ && sha256sum -c "[shasum值] 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 arm32v5/php:8.2-cli RUN curl -fsSL '[自定义PHP模块的URL]' -o module-name.tar.gz \ && mkdir -p /tmp/module-name \ && sha256sum -c "[shasum值] 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 arm32v5/php:8.2-fpm-alpine # 使用默认生产配置 RUN mv "$PHP_INI_DIR/php.ini-production" "$PHP_INI_DIR/php.ini"
在许多生产环境中,还建议(构建并)启用PHP核心OPcache扩展以提高性能。有关更多详细信息,请参见 上游OPcache文档。
arm32v5/php镜像有多种风格,每种风格设计用于特定用例。
有些标签可能包含bookworm或trixie等名称。这些是 Debian 发行版的代号,表示镜像所基于的发行版。如果镜像需要安装除镜像自带软件包之外的任何其他软件包,可能需要明确指定其中一个代号,以最大程度减少Debian新版本发布时的中断。
arm32v5/php:<version>-cli此变体包含 PHP CLI(命令行接口) 工具及默认模块。如果需要Web服务器,这可能不是你要找的镜像。它设计为既可作为一次性容器(挂载源代码并启动容器以启动应用),也可作为构建其他镜像的基础。
它也是唯一包含(不推荐使用的)php-cgi二进制文件的变体,这对于某些工具(如 PPM)可能是必需的。
注意,arm32v5/php的所有变体都包含PHP CLI(/usr/local/bin/php)。
arm32v5/php:<version>-apache此镜像包含Debian的Apache httpd,结合PHP(作为mod_php),默认使用mpm_prefork。
dockerfileFROM arm32v5/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 arm32v5/php:7.2-apache
DocumentRoot(或其他Apache配置)某些应用可能希望更改Apache中的默认DocumentRoot(从/var/www/html)。以下演示了一种使用环境变量的方法(也可在容器运行时修改):
dockerfileFROM arm32v5/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配置选项。
arm32v5/php:<version>-fpm此变体包含 PHP的FastCGI进程管理器(FPM),这是PHP推荐的FastCGI实现。
要使用此镜像变体,需要某种反向代理(如NG

来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 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