PHP网站如何部署到Docker容器
时间:2026-02-25 11:44:36 329浏览 收藏
本文详细讲解了如何将PHP网站容器化部署到Docker中,涵盖从编写Dockerfile构建PHP-FPM环境、配置Nginx反向代理、到使用docker-compose统一编排Nginx、PHP和MySQL多服务的完整流程,强调环境隔离、快速部署与跨平台优势,并提供可直接复用的目录结构、配置示例及启动验证方法,同时兼顾生产优化建议(如关闭错误显示、启用OPcache、限制MySQL端口暴露等),让开发者轻松实现稳定、可维护的PHP应用容器化运行。

将PHP网站部署到Docker容器中,可以实现环境隔离、快速部署和跨平台运行。整个过程包括编写Dockerfile、配置Nginx或Apache、连接数据库(如MySQL)以及使用docker-compose管理多服务。下面详细介绍具体步骤。
准备项目文件结构
在开始之前,整理好你的PHP项目目录,例如:
- project/
- ├── src/(存放PHP代码,如index.php)
- ├── Dockerfile
- ├── nginx.conf(可选,自定义Nginx配置)
- └── docker-compose.yml
确保src/index.php能正常输出内容,比如:
<?php echo "Hello from Dockerized PHP!"; ?>
编写Dockerfile构建PHP环境
在项目根目录创建Dockerfile,用于构建PHP应用镜像:
FROM php:8.1-fpm <h1>安装常用扩展</h1><p>RUN docker-php-ext-install mysqli pdo pdo_mysql</p><h1>设置工作目录</h1><p>WORKDIR /var/www/html</p><h1>复制本地代码到容器</h1><p>COPY src/ .</p><h1>更改权限(防止运行时权限问题)</h1><p>RUN chown -R www-data:www-data /var/www/html </p>
这里使用php:8.1-fpm作为基础镜像,适合与Nginx配合使用。如果你用Apache,可以选择php:apache并直接启用Apache服务。
配置Nginx反向代理PHP-FPM
创建nginx.conf文件:
server {
listen 80;
root /var/www/html;
index index.php index.html;
<pre class="brush:php;toolbar:false"><code>server_name localhost;
location / {
try_files $uri $uri/ =404;
}
location ~ \.php$ {
fastcgi_pass php-container:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}</code>}
注意:fastcgi_pass指向的是PHP-FPM服务的容器名称(在docker-compose中定义为php-container)。
使用docker-compose编排服务
创建docker-compose.yml来统一管理Nginx、PHP和MySQL服务:
version: '3.8' <p>services: nginx: image: nginx:alpine ports:</p>
- "8080:80" volumes:
- ./src:/var/www/html
- ./nginx.conf:/etc/nginx/conf.d/default.conf depends_on:
- php-container
php-container: build: context: . volumes:
- ./src:/var/www/html depends_on:
- db
db: image: mysql:8.0 environment: MYSQL_ROOT_PASSWORD: rootpassword MYSQL_DATABASE: myapp MYSQL_USER: user MYSQL_PASSWORD: password ports:
- "3306:3306" volumes:
- db_data:/var/lib/mysql
volumes: db_data:
这个配置启动三个容器:
- Nginx监听8080端口,处理静态请求并转发PHP给fpm
- PHP-FPM运行PHP代码
- MySQL提供数据库支持,数据持久化通过命名卷
db_data保存
启动容器并验证运行
在项目根目录执行:
docker-compose up -d --build
等待镜像构建并启动后,访问http://localhost:8080,如果看到PHP输出内容,说明部署成功。
查看日志排查问题:
docker-compose logs nginx docker-compose logs php-container
进入PHP容器测试数据库连接或执行脚本:
docker exec -it <php-container-name> bash
优化与注意事项
- 生产环境建议:不要暴露MySQL端口,使用内部网络通信;关闭不必要的错误显示(display_errors=Off)
- 性能考虑:可添加OPcache扩展提升PHP性能
- HTTPS支持:可通过挂载SSL证书并在Nginx中配置SSL
- 代码更新:修改PHP文件后,由于挂载了volume,无需重建镜像即可生效(但Dockerfile变更需重新build)
基本上就这些。只要结构清晰,配置正确,PHP网站在Docker中运行非常稳定且易于维护。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
325 收藏
-
260 收藏
-
436 收藏
-
468 收藏
-
431 收藏
-
307 收藏
-
186 收藏
-
237 收藏
-
384 收藏
-
166 收藏
-
196 收藏
-
341 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习