0

0

使用Docker容器化Laravel与PostgreSQL:完整实践指南

聖光之護

聖光之護

发布时间:2025-12-09 16:38:38

|

989人浏览过

|

来源于php中文网

原创

使用Docker容器化Laravel与PostgreSQL:完整实践指南

本教程旨在提供一个使用docker容器化laravel应用与postgresql数据库的完整指南。我们将详细介绍如何配置dockerfile以构建php-fpm服务,集成composer和node.js,并创建docker-compose.yml文件来编排laravel应用容器和postgresql数据库容器。通过本指南,读者将学习如何构建、运行并管理一个基于docker的laravel开发环境,确保环境一致性和部署便捷性。

引言

在现代软件开发中,容器化技术已成为构建、部署和管理应用程序的基石。Docker通过提供轻量级、可移植且自包含的运行环境,极大地简化了开发工作流。本教程将指导您如何使用Docker和Docker Compose,将一个Laravel应用程序与PostgreSQL数据库进行容器化,从而实现一个高效、一致且易于维护的开发环境。

前提条件

在开始之前,请确保您的系统已安装以下软件:

  • Docker Desktop: 包含Docker Engine和Docker Compose。
  • 一个现有的Laravel项目(或创建一个新项目)。

项目结构

为了保持清晰和组织性,建议您的项目根目录包含以下文件和目录:

your-laravel-project/
├── .env                 # Laravel 环境变量文件
├── Dockerfile           # Laravel 应用的 Docker 构建文件
├── docker-compose.yml   # Docker Compose 编排文件
├── app/
├── bootstrap/
├── config/
├── database/
├── public/
├── resources/
├── routes/
├── storage/
├── tests/
├── vendor/
└── ... (其他Laravel文件)

1. 定义Laravel应用服务(Dockerfile)

Dockerfile用于构建包含Laravel应用及其所有依赖的Docker镜像。我们将基于PHP-FPM官方镜像,并安装必要的系统依赖、PHP扩展、Composer和Node.js。

在项目根目录下创建名为Dockerfile的文件,并添加以下内容:

Beautiful.ai
Beautiful.ai

AI在线创建幻灯片

下载
# 使用官方PHP-FPM运行时作为父镜像
FROM php:7.4-fpm

# 设置工作目录
WORKDIR /app

# 安装系统依赖:Git、Curl、图像处理库、PostgreSQL客户端、压缩工具等
# 注意:Python3及其科学计算库(pandas, scikit-learn, numpy)在此处安装,
# 如果您的Laravel应用不涉及数据科学,可以移除相关行以减小镜像体积。
RUN apt-get update && apt-get install -y \
    git \
    curl \
    libpng-dev \
    libonig-dev \
    libxml2-dev \
    libzip-dev \
    zip \
    unzip \
    vim \
    postgresql-client \
    libpq-dev \
    python3 \
    python3-pip && \
    ln -s /usr/bin/python3 /usr/bin/python

# 安装Python包(可选,如果不需要数据科学工具可移除)
RUN pip3 install --no-cache-dir pandas scikit-learn numpy

# 安装PHP扩展:PostgreSQL PDO、多字节字符串、Exif、进程控制、高精度计算、GD库、Zip
RUN docker-php-ext-install pdo_pgsql mbstring exif pcntl bcmath gd zip
# 启用已安装的GD和Zip扩展
RUN docker-php-ext-enable gd zip

# 安装Node.js和npm(Laravel Mix等前端工具可能需要)
# 这里安装Node.js 16.x版本
RUN curl -fsSL https://deb.nodesource.com/setup_16.x | bash - \
    && apt-get install -y nodejs

# 安装Composer
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer

# 将应用程序文件复制到容器中
COPY . .

# 安装Laravel依赖
# 移除旧的vendor目录和composer.lock以确保全新安装
# 使用 composer install --no-dev --optimize-autoloader 优化生产环境的依赖安装
RUN rm -rf vendor composer.lock && composer update && composer install --no-dev --optimize-autoloader

# 设置Laravel目录的权限
# www-data 是 PHP-FPM 进程通常使用的用户和组
RUN chmod -R 775 storage bootstrap/cache && \
    chown -R www-data:www-data /app

# 安装Node.js依赖(如果使用Laravel Mix)
RUN npm install

# 暴露PHP-FPM默认端口9000
EXPOSE 9000

# 启动PHP-FPM服务
CMD ["php-fpm"]

代码解释:

  • FROM php:7.4-fpm: 选择PHP 7.4 FPM作为基础镜像,它包含了运行PHP应用程序所需的环境。
  • WORKDIR /app: 将容器内的工作目录设置为/app。所有后续命令都将在此目录下执行。
  • RUN apt-get update && apt-get install -y ...: 安装必要的系统软件包,包括Git、Curl、图像处理库、PostgreSQL客户端库(postgresql-client, libpq-dev)等。
  • RUN docker-php-ext-install ...: 安装并启用Laravel常用的PHP扩展,如pdo_pgsql(用于PostgreSQL连接)、mbstring、gd(图像处理)和zip。
  • RUN curl -fsSL ... | bash - && apt-get install -y nodejs: 安装Node.js和npm,这对于使用Laravel Mix编译前端资源非常重要。
  • RUN curl -sS ... | php -- ...: 安装Composer,用于管理PHP依赖。
  • COPY . .: 将宿主机当前目录(即Laravel项目根目录)下的所有文件复制到容器的/app目录。
  • RUN rm -rf vendor composer.lock && composer update && composer install --no-dev --optimize-autoloader: 清理旧的依赖,然后通过composer update更新composer.lock文件,最后执行composer install安装项目依赖。--no-dev用于跳过开发环境依赖,--optimize-autoloader用于优化自动加载。
  • RUN chmod -R 775 storage bootstrap/cache && chown -R www-data:www-data /app: 设置storage和bootstrap/cache目录的写入权限,并更改整个/app目录的所有者为www-data用户,确保PHP-FPM进程有足够的权限。
  • RUN npm install: 安装Node.js项目依赖。
  • EXPOSE 9000: 声明容器将监听9000端口,这是PHP-FPM的默认端口。
  • CMD ["php-fpm"]: 定义容器启动时执行的默认命令,即启动PHP-FPM服务。

2. 编排服务(docker-compose.yml)

docker-compose.yml文件用于定义和运行多容器Docker应用程序。我们将定义两个服务:一个用于Laravel应用(laravel-app),另一个用于PostgreSQL数据库(postgres-db)。

在项目根目录下创建名为docker-compose.yml的文件,并添加以下内容:

version: '3.8' # 推荐使用较新的Compose文件格式版本

services:
  # Laravel 应用服务
  laravel-app:
    container_name: laravel-app-container # 指定容器名称
    build:
      context: . # Dockerfile 所在的上下文路径
      dockerfile: Dockerfile # 指定 Dockerfile 文件名
    command: 'php artisan serve --host=0.0.0.0 --port=8000' # 启动Laravel开发服务器
    restart: unless-stopped # 容器异常退出时自动重启
    volumes:
      - .:/app # 将宿主机当前目录挂载到容器的 /app 目录,实现代码同步
    ports:
      - "8000:8000" # 将宿主机的 8000 端口映射到容器的 8000 端口
    depends_on:
      - postgres-db # 声明此服务依赖于 postgres-db 服务
    networks:
      - app-network # 将此服务连接到 app-network 网络

  # PostgreSQL 数据库服务
  postgres-db:
    container_name: postgres-db-container # 指定容器名称
    image: postgres:13 # 使用官方 PostgreSQL 13 镜像
    restart: unless-stopped # 容器异常退出时自动重启
    environment: # 设置 PostgreSQL 环境变量
      POSTGRES_DB: laravel_db # 数据库名称
      POSTGRES_USER: laravel_user # 数据库用户
      POSTGRES_PASSWORD: secret # 数据库密码
      # POSTGRES_HOST_AUTH_METHOD: "trust" # 生产环境不推荐,仅用于开发简化认证
    volumes:
      - postgres_data:/var/lib/postgresql/data # 挂载数据卷,实现数据持久化
    ports:
      - "5432:5432" # 将宿主机的 5432 端口映射到容器的 5432 端口
    networks:
      - app-network # 将此服务连接到 app-network 网络

# 定义网络,使服务之间可以互相通信
networks:
  app-network:
    driver: bridge # 使用桥接网络驱动

# 定义数据卷,用于 PostgreSQL 数据的持久化存储
volumes:
  postgres_data:
    driver: local # 使用本地驱动

代码解释:

  • version: '3.8': 指定Docker Compose文件格式版本。
  • services: 定义了两个服务。
    • laravel-app:
      • build: 指示Docker Compose根据当前目录下的Dockerfile构建镜像。
      • command: 'php artisan serve --host=0.0.0.0 --port=8000': 覆盖Dockerfile中的CMD,直接使用Laravel自带的开发服务器启动应用。这在开发环境中非常方便。
      • volumes: - .:/app: 将宿主机项目根目录挂载到容器的/app目录。这意味着您在宿主机上修改代码,容器内会立即同步,无需重新构建镜像。
      • ports: - "8000:8000": 将宿主机的8000端口映射到容器的8000端口,您可以通过http://localhost:8000访问Laravel应用。
      • depends_on: - postgres-db: 声明laravel-app服务依赖于postgres-db服务,Docker Compose会确保postgres-db先启动。
      • networks: - app-network: 将laravel-app服务连接到名为app-network的自定义网络。
    • postgres-db:
      • image: postgres:13: 使用官方的PostgreSQL 13镜像。
      • environment: 设置PostgreSQL的环境变量,包括数据库名、用户名和密码。这些信息将用于Laravel应用的数据库连接。
      • volumes: - postgres_data:/var/lib/postgresql/data: 使用一个命名卷postgres_data来持久化PostgreSQL的数据。这样即使容器被删除,数据也不会丢失。
      • ports: - "5432:5432": 将宿主机的5432端口映射到容器的5432端口,允许您从宿主机连接到数据库。
      • networks: - app-network: 将postgres-db服务连接到app-network网络。
  • networks: 定义了一个名为app-network的桥接网络,允许laravel-app和postgres-db服务通过服务名互相通信。
  • volumes: 定义了一个命名卷postgres_data,用于PostgreSQL的数据持久化。

3. 配置Laravel环境变量(.env)

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

339

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

293

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

771

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

384

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

140

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

79

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

343

2026.03.04

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

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

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