
在现代web开发中,docker容器化技术已成为部署应用的主流方式。php-fpm作为php应用的进程管理器,通常运行在独立的容器中。而nginx作为高性能的web服务器和反向代理,可能选择运行在宿主机上,或者作为kubernetes集群中的ingress控制器。本文旨在提供一份全面的指南,详细说明如何在nginx运行于docker外部时,有效代理docker容器内部的php-fpm程序,确保请求能够正确路由和处理。
在Kubernetes集群中,Nginx Ingress Controller是实现外部流量路由到集群内部服务的常用组件。通过配置Ingress资源,我们可以指示Nginx Ingress将HTTP请求转发给PHP-FPM服务。
首先,我们需要一个运行PHP-FPM应用的Pod。这个Pod会暴露一个端口(通常是9000)供FastCGI通信。
apiVersion: v1
kind: Pod
metadata:
name: example-app
labels:
app: example-app
spec:
containers:
- name: example-app
image: example-app:1.0 # 替换为你的PHP-FPM镜像
ports:
- containerPort: 9000
name: fastcgi # 定义一个端口名称,方便Service引用在这个Pod定义中,example-app:1.0是你包含PHP-FPM程序的Docker镜像。containerPort: 9000指定了PHP-FPM监听的端口。
为了让Nginx Ingress能够稳定地访问到Pod,我们需要创建一个Service来抽象Pod的网络访问。
立即学习“PHP免费学习笔记(深入)”;
apiVersion: v1
kind: Service
metadata:
name: example-service
spec:
selector:
app: example-app # 匹配Pod的label
ports:
- port: 9000 # Service暴露的端口
targetPort: 9000 # Pod监听的端口
name: fastcgi # 引用Pod中定义的端口名称Service通过selector匹配具有app: example-app标签的Pod,并将9000端口的流量转发到这些Pod的9000端口。
Nginx Ingress Controller允许通过ConfigMap来配置FastCGI参数,例如SCRIPT_FILENAME。这有助于统一管理和维护。
apiVersion: v1 kind: ConfigMap metadata: name: example-cm data: SCRIPT_FILENAME: "/example/index.php" # 根据你的应用路径调整
此ConfigMap定义了一个名为SCRIPT_FILENAME的参数,其值是/example/index.php。在实际应用中,你可能需要根据你的PHP应用入口文件路径进行调整。
最后,我们创建Ingress资源来配置Nginx Ingress Controller,使其将特定域名的请求代理到PHP-FPM服务。
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
annotations:
kubernetes.io/ingress.class: "nginx" # 指定使用Nginx Ingress Controller
nginx.ingress.kubernetes.io/backend-protocol: "FCGI" # 告知Nginx后端是FastCGI协议
nginx.ingress.kubernetes.io/fastcgi-index: "index.php" # FastCGI的默认索引文件
nginx.ingress.kubernetes.io/fastcgi-params-configmap: "example-cm" # 引用ConfigMap
name: example-app
spec:
rules:
- host: app.example.com # 你的域名
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: example-service
port:
name: fastcgi # 引用Service中定义的端口名称关键注解解释:
通过以上配置,当访问app.example.com时,Nginx Ingress Controller会将请求代理到example-service,并以FastCGI协议与PHP-FPM容器进行通信。
如果Nginx运行在宿主机上,而非Kubernetes集群中,我们可以通过配置Nginx服务器块来直接代理Docker容器内的PHP-FPM。
为了让宿主机上的Nginx能够访问到Docker容器内的PHP-FPM,你需要确保PHP-FPM容器的端口已正确暴露并可从宿主机访问。最常见的方式是在运行Docker容器时将容器端口映射到宿主机的某个端口。
例如,运行PHP-FPM容器时:
docker run -d --name php-fpm-app -p 9000:9000 bitnami/php-fpm:latest # 示例镜像
这会将容器内部的9000端口映射到宿主机的9000端口。此时,宿主机上的Nginx可以通过127.0.0.1:9000或宿主机的IP地址:<宿主机端口>来访问PHP-FPM。
注意事项:
以下是一个Nginx服务器块的配置示例,用于代理PHP-FPM。
server {
listen 80; # Nginx监听的端口
server_name localhost; # 你的域名或IP
root /var/www/test; # Nginx的文档根目录,应与PHP-FPM容器内的应用路径匹配
error_log /var/log/nginx/localhost.error.log;
access_log /var/log/nginx/localhost.access.log;
location / {
# 尝试直接服务文件,如果不存在则回退到index.php
try_files $uri $uri/ /index.php$is_args$args;
}
location ~ ^/.+\.php(/|$) {
# FastCGI代理到PHP-FPM
# 这里的IP地址和端口需要替换为PHP-FPM容器可访问的地址和端口
# 如果端口映射到宿主机,通常是 127.0.0.1:9000
fastcgi_pass 127.0.0.1:9000; # 示例:192.168.59.103:9000 或 host.docker.internal:9000
fastcgi_split_path_info ^(.+\.php)(/.*)$; # 分割PHP脚本路径和额外路径信息
include fastcgi_params; # 包含Nginx默认的FastCGI参数
# 设置SCRIPT_FILENAME参数,告知PHP-FPM要执行的脚本路径
# $document_root 对应 Nginx 的 root 指令,与 PHP-FPM 容器内的应用根目录保持一致
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param HTTPS off; # 根据实际情况设置,如果Nginx接收HTTPS请求,这里应为 on
}
}配置详解:
无论选择哪种方式,成功代理Docker容器内的PHP-FPM程序都离不开以下几个关键点:
通过本文的指导,您应该能够根据自己的部署环境,灵活选择和配置Nginx来高效代理Docker容器内的PHP-FPM程序,从而构建健壮的Web服务架构。
以上就是Nginx在宿主机代理Docker容器内PHP-FPM程序的实践指南的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号