yum安装PHP仅提供解释器和基础模块,需额外配置Web服务器(Nginx/Apache)+ PHP-FPM或mod_php,启用Remi等第三方仓库,安装php-fpm及常用扩展,启动并监听,再配置Web服务器反向代理,最后处理SELinux与权限问题。
Linux 系统用 yum 安装 PHP 并不能直接“一键跑起 Web 服务”,它只装核心解释器和基础模块;要真正运行 PHP 脚本(比如通过 Nginx 或 Apache 访问 index.php),必须额外配置 Web 服务器 + PHP-FPM 或 mod_php,否则 php -v 成功但浏览器打开全是源码或 502/404。
CentOS 7/RHEL 7 默认 yum 源里的 PHP 是 5.4,早已 EOL;CentOS 8+ 已废弃 yum(实际是 dnf),且默认不带 PHP 包。必须先启用第三方仓库:
yum install epel-release yum-utils,再启用 Remi 仓库:yum install https://rpms.remirepo.net/enterprise/remi-release-7.rpm
dnf,且需启用 powertools 和 remi-8.0(或对应版本)仓库,yum 命令会静默转为 dnf,但脚本里写 yum 可能误导yum repolist | grep remi —— 没输出说明仓库没启成功,后续所有 yum install php 都只会装系统旧版或报错单独执行 yum install php 只装 CLI 版本,无 php-fpm、无 MySQL 支持、无 GD/curl/json 等扩展,Web 场景下基本不可用。推荐一次性装齐:
yum install php php-cli php-fpm php-mysqlnd php-gd php-xml php-mbstring php-opcache php-json
php-fpm 是 Nginx 推荐的 PHP 进程管理器;Apache 用户可选 php + mod_ph
p,但 RHEL/CentOS 8+ 已移除 mod_php,强制走 FPMphp-mysqlnd 替代已废弃的 php-mysql,支持 MySQL 8.0+ 的认证插件php-pecl-redis(Remi 仓库提供),yum install php-pecl-redis
装完不启动、不配监听,Nginx 就连不上 PHP。关键三步:
systemctl start php-fpm,并设开机自启:systemctl enable php-fpm
ss -tlnp | grep :9000(默认监听 127.0.0.1:9000);若显示 php-fpm: 进程即正常/etc/php-fpm.d/www.conf 中的 listen = /run/php-fpm/www.sock(Unix socket 更安全)后,记得重启:systemctl restart php-fpm,否则 Nginx 配置 socket 路径会连接拒绝echo '' > /var/www/html/test.php && php /var/www/html/test.php —— 输出 OK 表示 CLI 正常;但不代表 Web 可访问yum 完全不管 Web 服务器配置。以 Nginx 为例,漏掉任一环节都会 502:
nginx 已安装并运行:yum install nginx && systemctl start nginx
/etc/nginx/conf.d/default.conf 的 server 块内添加 location:
location ~ \.php$ {
root /var/www/html;
fastcgi_pass 127.0.0.1:9000; # 或 unix:/run/php-fpm/www.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}nginx -t && systemctl reload nginx;若提示 “No such file or directory” 指向 socket,说明 php-fpm 没按配置监听该路径yum install httpd 后,PHP 模块不会自动加载,需确认 /etc/httpd/conf.modules.d/15-php.conf 存在且未被注释最常被跳过的其实是 SELinux 和文件权限:CentOS 默认开启 SELinux,/var/www/html 目录若没正确上下文(httpd_sys_content_t),或 php-fpm 进程无法读取脚本,就会 403 或 500。临时关闭验证可用性:setenforce 0,但生产环境必须用 chcon 或 semanage 修正,而不是关 SELinux。