宿主机Nginx代理Docker容器内php-fpm的配置指南

宿主机Nginx代理Docker容器内php-fpm的配置指南

本文旨在提供一份详尽的教程,指导您如何在宿主机上安装的Nginx反向代理Docker容器内部运行的php-fpm程序。核心内容涵盖了Nginx与Docker容器间的网络通信机制、FastCGI协议配置要点,以及如何确保文件路径在宿主机Nginx和Docker容器内php-fpm之间正确映射,从而实现高效稳定的PHP应用服务。

理解Nginx与Docker容器网络通信

nginx运行在宿主机上,而php-fpm运行在docker容器内部时,首要解决的问题是nginx如何找到并连接到php-fpm服务。docker通过其网络层为容器提供了隔离的环境。为了让宿主机上的nginx能够访问容器内的php-fpm,通常有两种主要方法:

端口映射 (Port Mapping):这是最常见且推荐的方式。Docker容器将内部的某个端口(例如php-fpm默认监听的9000端口)映射到宿主机的某个端口。这样,宿主机上的Nginx就可以通过localhost或宿主机的IP地址加上映射的端口来访问php-fpm。Docker桥接网络IP:在某些Linux环境中,宿主机可以直接通过Docker桥接网络的IP地址访问容器。例如,Docker默认的bridge网络通常会有一个网关IP(如172.17.0.1),容器在此网络中会有自己的IP。Nginx可以直接使用容器的IP地址进行连接。然而,容器的IP地址可能会动态变化,因此端口映射是更稳定的选择。

本教程将主要采用端口映射的方式进行配置,因为它更具通用性和稳定性。

Docker php-fpm容器准备

首先,确保您的php-fpm容器已正确运行,并监听了FastCGI协议的端口(通常是9000)。同时,为了让php-fpm能够访问到您的PHP应用代码,需要将宿主机上的应用代码目录挂载到容器内部。

以下是一个使用bitnami/php-fpm镜像的示例:

docker run -d   --name my-php-fpm   -p 9000:9000   -v /path/to/your/app:/app  # 将宿主机上的应用代码目录挂载到容器内的/app  bitnami/php-fpm:latest

说明:

立即学习“PHP免费学习笔记(深入)”;

-d: 后台运行容器。–name my-php-fpm: 为容器指定一个名称。-p 9000:9000: 将容器内部的9000端口映射到宿主机的9000端口。-v /path/to/your/app:/app: 这是一个关键步骤。它将宿主机上存放PHP应用代码的路径(例如/var/www/html/my-php-app)挂载到容器内部的/app目录。确保此路径与Nginx配置中的root指令相匹配。bitnami/php-fpm:latest: 使用Bitnami提供的php-fpm镜像。您可以根据自己的需求选择其他php-fpm镜像。

运行此命令后,php-fpm服务将在Docker容器内启动,并通过宿主机的9000端口对外提供服务。

Nginx配置核心:FastCGI代理

接下来,我们需要在宿主机上的Nginx中配置FastCGI代理,将PHP请求转发给Docker容器内的php-fpm。

server {    listen 80;    server_name your_domain.com; # 替换为您的域名或IP地址    root /path/to/your/app;      # 替换为宿主机上PHP应用代码的根目录    # 错误日志和访问日志路径    error_log /var/log/nginx/your_domain.error.log;    access_log /var/log/nginx/your_domain.access.log;    index index.php index.html index.htm; # 默认索引文件    location / {        # 尝试直接提供文件,如果不存在则回退到index.php        try_files $uri $uri/ /index.php?$query_string;    }    location ~ .php(/|$) {        # FastCGI代理到php-fpm服务        fastcgi_pass 127.0.0.1:9000; # 或 localhost:9000,取决于您的系统配置        # 如果宿主机与容器在同一网络且没有端口映射,可能需要使用Docker桥接IP,例如:        # fastcgi_pass 172.17.0.1:9000;         fastcgi_split_path_info ^(.+.php)(/.*)$;        include fastcgi_params; # 包含FastCGI标准参数        # 确保SCRIPT_FILENAME正确指向PHP脚本在容器内的路径        # $document_root 对应 Nginx 的 root 指令,即宿主机上的 /path/to/your/app        # 容器内通过卷挂载,此路径在容器内也存在,如 /app        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;        fastcgi_param HTTPS off; # 根据您的HTTPS配置调整    }    # 可选:禁止访问某些敏感文件    location ~ /.ht {        deny all;    }}

关键配置项解析

server_name: 设置Nginx监听的域名或IP地址。root /path/to/your/app;: 至关重要。此指令指定了Nginx查找静态文件和PHP脚本的根目录。这个路径必须是宿主机上PHP应用代码的实际存放路径,并且这个路径必须与Docker容器启动时通过-v参数挂载到容器内部的路径相对应。例如,如果容器内部是/app,则宿主机上的root也应指向/path/to/your/app。index index.php index.html index.htm;: 定义了默认的索引文件。location /: 负责处理非PHP文件的请求,并使用try_files指令实现URL重写,将所有请求路由到index.php,这对于现代PHP框架(如Laravel, Symfony)非常常见。location ~ .php(/|$): 这是一个正则表达式匹配块,用于处理所有以.php结尾的请求。fastcgi_pass 127.0.0.1:9000;: 这是Nginx连接php-fpm的关键。如果您的Docker容器将9000端口映射到宿主机的9000端口,那么127.0.0.1:9000或localhost:9000是正确的地址。在某些Linux环境中,如果您没有进行端口映射,而是直接通过Docker桥接网络IP访问,您可能需要查找Docker宿主机的桥接网卡IP(例如ifconfig docker0或ip a show docker0)或容器的实际IP地址。但如前所述,端口映射更为稳定。*`fastcgi_split_path_info ^(.+.php)(/.)$;`**: 这个指令用于正确解析PHP脚本的路径信息,将脚本路径和附加路径信息分开。include fastcgi_params;: 引入Nginx自带的FastCGI参数文件,其中包含了许多必要的FastCGI变量。fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;: 这是另一个关键参数。它告诉php-fpm要执行的PHP脚本的完整路径。$document_root在Nginx中解析为root指令设置的路径(即宿主机上的/path/to/your/app),而$fastcgi_script_name是请求的PHP文件名。由于您已经通过卷挂载将宿主机的/path/to/your/app映射到容器内的/app,因此php-fpm在容器内可以通过/app/your_script.php找到并执行脚本。确保Nginx的root路径和Docker容器内部挂载的路径能够正确对应,这是避免“File not found”错误的关键。

部署与测试

启动php-fpm容器: 按照上述docker run命令启动您的php-fpm容器。

配置Nginx: 将上述Nginx配置保存到您的Nginx配置文件中(例如/etc/nginx/conf.d/your_app.conf)。

检查Nginx配置: 运行sudo nginx -t检查Nginx配置是否有语法错误。

重载Nginx: 如果配置无误,运行sudo systemctl reload nginx或sudo service nginx reload重载Nginx服务。

创建测试文件: 在宿主机上您的应用代码根目录(例如/path/to/your/app)中创建一个index.php文件,内容如下:


访问测试: 在浏览器中访问http://your_domain.com(或您配置的IP地址),如果一切配置正确,您应该能看到phpinfo页面。

注意事项

文件路径一致性: Nginx的root指令指向的宿主机路径,必须通过卷挂载(-v)的方式,与php-fpm容器内部访问PHP脚本的路径保持一致。这是最常见的配置错误来源。网络连通性: 确保宿主机上的Nginx能够通过fastcgi_pass指定的地址和端口连接到Docker容器内的php-fpm。防火墙规则(如firewalld或ufw)可能会阻止这种连接,请检查并放行相关端口。权限问题: 确保Nginx进程和php-fpm进程对应用代码目录及其文件拥有足够的读写权限。日志监控: 定期检查Nginx的error_log和php-fpm的日志,以便及时发现和解决问题。生产环境考虑: 在生产环境中,建议使用Docker Compose来管理多个容器(如Nginx、php-fpm、数据库等),并利用Docker内部网络进行服务发现,这样可以避免直接使用宿主机IP或localhost,使配置更具可移植性。

总结

通过本教程,您应该已经掌握了在宿主机Nginx中代理Docker容器内php-fpm的核心方法。关键在于正确配置Nginx的FastCGI代理指令,并确保宿主机Nginx与Docker容器php-fpm之间的网络连通性以及文件路径的映射一致性。遵循这些步骤,您将能够高效地利用Docker容器的隔离性来运行php-fpm,同时保持Nginx在宿主机上的灵活性。

以上就是宿主机Nginx代理Docker容器内php-fpm的配置指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1273492.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 15:44:10
下一篇 2025年12月10日 15:44:27

相关推荐

  • 比特币BTC今日价格行情 比特币24小时实时汇率K线历史走势图

    比特币(BTC),作为加密货币世界的开创者和无可争议的王者,早已不仅仅是一种数字资产,更是一种席卷全球的金融现象。它以其去中心化、总量恒定的特性,被誉为“数字黄金”,吸引了无数追求前沿技术和资产增值的投资者。 为了方便您快速进入数字货币的世界,本文将为您提供官方App的直接下载通道。您只需点击文中提…

    2025年12月10日
    000
  • 如何进入币安官方平台 币安交易所官网登录链接

    币安是全球领先的数字资产交易平台,支持现货、合约、理财等服务。为了保障账户与资金安全,新手用户应通过官方登录链接或 app 快速直达平台。 官网登录链接: 客户端下载地址: 1. 如何确认登录链接安全可靠 请确保访问地址以https://www.binance.com或币安官方备用域名开头,并确认浏…

    2025年12月10日
    000
  • bitget网页版怎么登录?bitget官网地址链接及App下载入口

    bybit是知名的数字资产交易平台之一,提供现货、合约、杠杆、理财等多项功能。为了保障账户与资金安全,建议通过官方渠道下载并注册账户。 官网链接:www.bybit.com 客户端下载地址: 1. 如何确认访问的是 Bybit 官方平台 建议通过Bybit官方社媒(如推特、微信公众号)或官网公告获取…

    2025年12月10日
    000
  • 什么是DAI稳定币?它如何维持价格稳定?与其他稳定币的差异在哪里?

    DAI是一种独特的去中心化稳定币,其价值与美元保持1:1锚定。它不依赖于中心化机构的储备,而是通过一个公开透明的链上资产抵押系统来维持其稳定性,这使其在众多稳定币中脱颖而出。DAI提供了一种更加原生于数字世界的解决方案。对于看重去中心化原则和链上可验证性的用户而言,DAI无疑是稳定币领域中一个值得关…

    2025年12月10日
    000
  • 火币交易所官网入口 火币唯一官方网址

    火币交易所(huobi global)于2023年完成品牌升级,正式更名为htx交易所。此次变更是其战略调整的一部分,但核心服务仍延续火币原有的交易体系。用户需注意,所有官方链接均已更新为htx域名。 2. 官网入口确认方式 唯一官方网址: 警惕仿冒网站,务必手动输入网址或通过官方社交媒体验证的链接…

    2025年12月10日
    000
  • 币安app官方版下载 Binance官网入口地址

    币安(Binance)是全球领先的加密货币交易平台,为用户提供安全、便捷的数字资产交易服务。 币安提供官方移动应用,可通过官网下载: iOS版本: Android版本: 访问注意事项 验证网站真实性:访问前务必确认网址拼写正确,警惕钓鱼网站。官方网址应为”binance.com&#822…

    2025年12月10日
    000
  • 币安交易所app苹果手机版下载

    币安(binance)是全球领先的加密货币交易平台,为用户提供安全、便捷的数字资产交易服务。以下是关于币安官网入口的详细介绍: 官方网站地址 币安的官方网站地址为: 移动端入口 币安提供官方移动应用,可通过官网下载: iOS版本: Android版本: 新用户注册 官网首页右上角有”注册…

    2025年12月10日
    000
  • 火币(HTX)官网正确地址

    火币(htx)是全球领先的加密货币交易平台,为用户提供安全、便捷的数字资产交易服务。以下是关于火币官网入口的详细介绍: 官方网站地址 火币的官方网站地址为: 访问注意事项 验证网站真实性:访问前务必确认网址拼写正确,警惕钓鱼网站。官方网址应为”binance.com”而非类似…

    2025年12月10日
    000
  • 币安binance官网最新版APP下载链接 币安交易所APP官方正版

    币安(Binance)是全球领先的数字资产交易平台,为用户提供安全、稳定、便捷的加密货币交易服务。平台支持数百种数字货币的交易,并拥有强大的技术支持和严格的资金安全管理体系。 本文将为您提供币安官网最新版的app下载与安装教程,点击文内提供的官方下载链接,即可轻松获取正版币安app,开启您的数字资产…

    2025年12月10日
    000
  • 币安交易所官方最新版本APP入口 binance最新版官网下载地址

    币安(Binance)是全球知名的数字资产交易平台,为用户提供广泛的加密货币交易服务、安全的资产管理以及丰富的金融产品。其App设计简洁,操作流畅,是众多数字货币爱好者的首选交易工具。 本文将为您提供币安官方最新版app的下载与安装教程,点击本文中提供的下载入口即可直接获取官方安装包,确保您的下载渠…

    2025年12月10日
    000
  • SOL币行情实时查询app 索拉纳最新价格k线走势图在线看

    Solana,中文名为索拉纳,是一个以其高性能和快速交易而闻名的公链平台,其原生代币为SOL。由于其独特的架构和高吞吐量,SOL币在全球数字货币市场中备受关注,吸引了众多开发者和投资者的目光。 当前sol币实时价格:根据最新数据,sol价格约为$197.42(价格可能因市场波动而变化,具体以app内…

    2025年12月10日
    000
  • 火币交易所官方app最新版本入口 火币网huobi官网app

    火币(Huobi)是全球知名的数字资产服务平台,为用户提供安全、可靠的交易体验。火币App集成了行情查看、交易、资产管理等多种功能,方便用户随时随地进行操作。 本文将为您提供火币交易所官方app最新版本的下载入口,点击本文提供的安全下载链接即可开始下载安装。 火币App官方下载流程 1、首先,请点击…

    2025年12月10日
    000
  • 火币交易所最新版app官方链接 火币官网app安卓版下载

    火币(Huobi)是全球知名的数字资产服务平台,为用户提供广泛的数字货币交易服务。其官方App以其安全稳定、交易品类丰富和操作便捷的特点,受到了众多用户的青睐。 为了方便用户获取最新、最安全的客户端,本文将提供火币交易所最新版app的官方下载链接,您只需点击本文中的链接,即可轻松下载官方正版app,…

    2025年12月10日
    000
  • 以太坊实时行情app追踪 最新ETH价格走势图表一键查看

    1、以太坊是全球第二大加密货币,也是支持DApps和智能合约的开源区块链平台;2、通过官方app可安全查看ETH等千种币实时价格、K线图并交易;3、下载需点击文内专属链接,安装前允许未知来源,完成后按提示操作;4、首次使用须授权、同意协议并安全备份助记词或私钥,切勿截图或在线存储,方可开始行情追踪与…

    2025年12月10日
    000
  • SOL币最新实时行情走势图app 索拉纳币24小时价格k线在线查询

    索拉纳(Solana)是一个备受关注的高性能公链项目,以其高速度和低交易成本而闻名,其原生代币为SOL。它旨在为去中心化应用(DApps)和加密货币提供一个可扩展、安全且去中心化的平台。 当前sol币实时价格:根据最新数据,sol价格约为$197.42(价格可能因市场波动而变化,具体以app内显示为…

    2025年12月10日
    000
  • 以太坊价格app动态追踪 ETH实时行情图表在线监控

    以太坊(ethereum),这个名字在数字资产领域如雷贯耳。但它远不止是一种加密货币,更是一个革命性的全球开源平台,以其独特的智能合约功能,催生了去中心化金融(defi)、非同质化代币(nft)以及无数创新应用的诞生。以太坊如同一个数字世界的操作系统,为未来的互联网形态奠定了基础。想要精准捕捉这个庞…

    2025年12月10日
    000
  • 数字货币的骗局案列

    选择加密货币交易所需优先考虑安全性、流动性、费用结构、支持币种、用户体验、客户服务及合规性;2. 常见骗局包括庞氏骗局、金字塔骗局、杀猪盘、钓鱼网站、假冒ICO、空投骗局、勒索软件、虚假存储和客服诈骗;3. 防范措施为核实信息来源、警惕高回报承诺、保护私钥助记词、启用MFA、核对网址、拒绝转账授权请…

    2025年12月10日 好文分享
    000
  • 必安交易平台App的官方途径是什么 从官网注册安装必安App的具体操作流程

    必安交易平台是一款广受欢迎的数字资产服务平台,为用户提供多样化的交易选择和专业的市场数据。它凭借稳定的系统和友好的用户界面,吸引了众多数字资产爱好者。本文将为您提供必安官方app的下载与安装指导,点击本文提供的官方下载链接即可安全、快速地获取应用程序,开启您的数字资产之旅。 下载与安装 1、获取官方…

    2025年12月10日
    000
  • 火币APP全指南2025 火币安卓/iOS版功能详解与实操

    火币(huobi)是一款全球知名的数字资产综合服务平台,为广大用户提供覆盖广泛的数字资产交易、投资和管理等一站式服务。它凭借丰富的交易对、安全稳定的系统架构和专业的客户支持,在全球范围内赢得了众多用户的信赖和青睐。为了帮助您顺利开启数字资产之旅,本文将为您提供一份详尽的下载安装指南,并为您准备了官方…

    2025年12月10日
    000
  • HTX(火必网)官网打不开怎么办_访问障碍处理

    HTX(火必网)官网打不开怎么办_访问障碍处理 一、常见访问障碍类型 部分用户在尝试访问 htx(原火必网)官网时,可能会遇到网页加载失败、域名跳转异常、提示连接超时或403/404错误等情况。造成这些问题的原因主要包括: 网络运营商或地区对相关网站的访问限制本地DNS解析异常浏览器缓存或插件冲突输…

    好文分享 2025年12月10日
    000

发表回复

登录后才能评论
关注微信