专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏

s390x/php Docker 镜像 - 轩辕镜像

php
s390x/php
PHP是一种主要设计用于Web开发的脚本语言,同时也可作为通用编程语言使用,可嵌入HTML或与多种模板引擎及Web框架配合使用。
1 收藏0 次下载actives390x镜像
🚀专业版镜像服务,面向生产环境设计
中文简介版本下载
🚀专业版镜像服务,面向生产环境设计

注意: 这是 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?

PHP是一种主要设计用于Web开发的服务器端脚本语言,但也可用作通用编程语言。PHP可以嵌入纯HTML中,也可以与各种模板引擎和Web框架配合使用。PHP代码通常由解释器处理,解释器既可以实现为Web服务器的原生模块,也可以作为通用网关接口(CGI)。

***.org/wiki/PHP

!logo

如何使用此镜像

在PHP项目中创建 Dockerfile
dockerfile
FROM 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
运行单个PHP脚本

对于许多简单的单文件项目,编写完整的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扩展

许多扩展已编译到镜像中,因此在费力编译更多扩展之前,值得先检查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镜像的同一层中删除它。

Dockerfile
FROM s390x/php:8.2-cli
RUN docker-php-source extract \
	# 执行重要操作 \
	&& docker-php-source delete
PHP核心扩展

例如,如果需要带有gd扩展的PHP-FPM镜像,可以继承所需的基础镜像,并编写如下Dockerfile:

dockerfile
FROM 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可获取特定版本的扩展列表。

PECL扩展

有些扩展未随PHP源代码提供,而是通过PECL提供。要安装PECL扩展,使用pecl install下载并编译,然后使用docker-php-ext-enable启用:

dockerfile
FROM s390x/php:8.2-cli
RUN pecl install redis-5.3.7 \
	&& pecl install xdebug-3.2.1 \
	&& docker-php-ext-enable redis xdebug
dockerfile
FROM 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提供;这些扩展也可以安装,尽管过程自动化程度较低:

dockerfile
FROM 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-*脚本可以接受任意路径,但必须是绝对路径(以与内置扩展名称区分),因此上述示例也可以写成:

dockerfile
FROM 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变体,有以下几种选择:

  • 如果内核版本为4.11或更高,可以添加--sysctl net.ipv4.ip_unprivileged_port_start=0(将在Docker的未来版本中成为默认值),然后--user应像在FPM中一样工作。
  • 如果将Apache配置调整为使用“非特权”端口(默认情况下大于1024),则无论内核版本如何,--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实例,除非您确实知道自己在做什么,否则绝对不是您想要的):

dockerfile
RUN 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/目录来自定义默认配置。

示例
dockerfile
FROM 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。

使用Dockerfile的Apache
dockerfile
FROM 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配置文件;详情参见“配置”部分。

不使用Dockerfile的Apache
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)。以下演示了一种使用环境变量的方法(也可在容器运行时修改):

dockerfile
FROM 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协议的工具)。

一些

查看更多 php 相关镜像 →
php logo
php
by library
官方
PHP脚本语言虽最初为Web开发设计,却兼具通用目的用途,作为一种广泛应用的服务器端脚本语言,它能高效处理动态网页生成、数据库交互等Web开发核心任务,同时也可用于编写命令行脚本、开发桌面应用及进行系统管理等非Web领域,凭借其简洁语法与跨平台特性,成为众多开发者在不同场景下的实用工具。
78251B+ pulls
上次更新:5 天前
cimg/php logo
cimg/php
by CircleCI
认证
CircleCI PHP便捷镜像,专为PHP项目在CircleCI平台上的持续集成流程设计,提供预配置环境以简化集成部署。
610M+ pulls
上次更新:25 天前
devwithlando/php logo
devwithlando/php
by Lando Alliance
Lando是一款受专业开发者信赖的本地开发和DevOps工具,可帮助用户摆脱低效开发工具的束缚,节省时间与精力,专注于实际工作。
161M+ pulls
上次更新:1 个月前
serversideup/php logo
serversideup/php
by Server Side Up
适合生产环境的PHP Docker镜像,针对Laravel和WordPress进行了优化。
551M+ pulls
上次更新:18 天前
paketobuildpacks/php logo
paketobuildpacks/php
by Linux Foundation
暂无描述
5M+ pulls
上次更新:11 个月前
shinsenter/php logo
shinsenter/php
by SHIN Company
简化的PHP Docker镜像,便于轻松定制和扩展设置。
32500K+ pulls
上次更新:7 天前

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

oldzhang的头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
s390x/php
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
提交工单
免费获取在线技术支持请 提交工单,官方QQ群:13763429 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
免费获取在线技术支持请提交工单,官方QQ群: 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.
轩辕镜像 官方专业版 Logo
轩辕镜像轩辕镜像官方专业版
首页个人中心搜索镜像
交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 13763429