0

0

如何在Docker Compose中部署多容器PHP应用的详细步骤?

雪夜

雪夜

发布时间:2025-11-02 21:18:02

|

473人浏览过

|

来源于php中文网

原创

首先创建项目目录结构,包括app、nginx、mysql等子目录,并编写docker-compose.yml文件定义web、php、db和redis四个服务。接着在php目录下编写Dockerfile,基于php:8.2-fpm安装必要扩展并复制代码至容器。然后配置nginx.conf,设置server块监听80端口并将.php请求转发至php:9000。在docker-compose.yml中为db服务使用mysql:8.0镜像,设置环境变量并挂载本地数据目录实现持久化。添加redis服务使用redis:7-alpine镜像,可选挂载dump.rdb实现数据保存。定义自定义网络app-network供所有服务通信,并使用命名卷管理mysql和redis的数据。最后执行docker compose up -d启动服务,通过docker compose ps检查状态,访问localhost验证应用运行正常。

如何在docker compose中部署多容器php应用的详细步骤?

如果您正在构建一个基于PHP的多容器应用,并希望通过Docker Compose实现服务编排与快速部署,您需要配置多个相互协作的容器,如Web服务器、数据库和缓存服务。以下是完成该任务的具体步骤:

本文运行环境:MacBook Pro,macOS Sonoma

一、准备项目目录结构

合理的目录结构有助于分离关注点并提升可维护性。将应用程序代码、配置文件和服务定义分开放置。

1、在本地创建项目根目录,例如 my-php-app

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

2、在根目录下建立 app 子目录用于存放PHP源码。

3、创建 nginx 目录存放Nginx配置文件,mysql 目录用于MySQL数据持久化。

4、在根目录创建 docker-compose.yml 文件以定义服务。

二、编写Docker Compose配置文件

Docker Compose使用YAML文件来定义多个容器服务及其依赖关系。通过此文件可以声明网络、卷和端口映射。

1、打开文本编辑器,创建 docker-compose.yml 文件。

2、定义四个服务:web(Nginx)、php(PHP-FPM)、db(MySQL)和 redis(缓存)。

3、为每个服务设置镜像名称、容器名称、端口暴露、卷挂载及启动顺序依赖。

4、确保所有服务连接到同一个自定义网络,以便内部通信。

三、配置PHP-FPM容器

PHP应用逻辑由PHP-FPM处理,需定制Docker镜像以安装必要扩展并复制代码。

1、在项目根目录创建 php/Dockerfile

2、基于 php:8.2-fpm 镜像进行构建,安装常用扩展如pdo_mysql、gd、zip等。

3、使用COPY指令将本地 app/ 目录内容复制到容器内的 /var/www/html

4、设置工作目录为 /var/www/html,并更改文件权限以避免运行错误。

四、配置Nginx服务器

Nginx作为反向代理接收HTTP请求,并将PHP请求转发给PHP-FPM容器处理。

1、在 nginx 目录中创建 nginx.conf 配置文件。

2、定义server块监听80端口,指定root目录为 /var/www/html

3、配置location块将所有.php文件请求代理到 http://php:9000

听脑AI
听脑AI

听脑AI语音,一款专注于音视频内容的工作学习助手,为用户提供便捷的音视频内容记录、整理与分析功能。

下载

4、在docker-compose.yml中将本地nginx.conf挂载到容器的/etc/nginx/nginx.conf位置。

五、设置MySQL数据库服务

MySQL容器用于存储应用数据,需预设数据库名、用户和密码,并支持数据持久化。

1、在docker-compose.yml中为db服务选择官方 mysql:8.0 镜像。

2、通过environment字段设置 MYSQL_ROOT_PASSWORDMYSQL_DATABASE 等变量。

3、将本地 ./mysql/data 挂载到容器的 /var/lib/mysql 实现数据持久化。

4、暴露容器3306端口到主机以便外部工具访问。

六、集成Redis缓存服务

Redis可用于会话存储或应用级缓存,提高响应速度并减轻数据库负载。

1、在docker-compose.yml中添加名为redis的服务,使用 redis:7-alpine 镜像。

2、无需额外配置即可运行,但建议启用持久化RDB快照功能。

3、在PHP代码中通过host为 redis、端口为6379连接实例。

4、可选地,在redis服务中挂载本地dump.rdb文件路径以实现数据保存。

七、定义共享网络与卷

确保各容器可通过自定义桥接网络相互通信,并使用命名卷管理持久化数据。

1、在docker-compose.yml的networks部分声明名为 app-network 的内部网络。

2、将所有服务加入该网络,设置driver为bridge模式。

3、在volumes部分定义 mysql_dataredis_data 命名卷。

4、在对应服务中引用这些卷,替代部分本地路径绑定以增强可移植性。

八、启动并验证多容器应用

完成所有配置后,使用Docker Compose命令启动整个栈并检查运行状态。

1、在终端进入项目根目录,执行 docker compose up -d 构建并后台运行所有服务。

2、使用 docker compose ps 查看各容器是否处于running状态。

3、访问 http://localhost 测试Nginx是否成功返回PHP页面。

4、进入PHP容器执行 php artisan tinker 或类似命令测试数据库和Redis连通性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

668

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

247

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

256

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

532

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

601

2023.08.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

9

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号