0

0

使用Docker容器化Laravel与PostgreSQL的完整教程

心靈之曲

心靈之曲

发布时间:2025-12-12 13:39:25

|

178人浏览过

|

来源于php中文网

原创

使用Docker容器化Laravel与PostgreSQL的完整教程

本教程详细指导如何利用docker和docker compose容器化laravel应用程序与postgresql数据库。文章涵盖了优化的dockerfile配置,用于构建laravel应用镜像;以及一份完整的docker-compose.yml文件,用于编排laravel应用、postgresql数据库和网络。此外,教程还提供了laravel环境配置、容器启动与管理命令,并分享了重要的注意事项与最佳实践,旨在帮助开发者高效搭建和部署开发环境。

1. 引言

在现代Web开发中,Docker已成为部署和管理应用程序及其依赖的强大工具。通过容器化,我们可以确保开发、测试和生产环境的一致性,极大地简化了环境配置和团队协作。本教程将指导您如何使用Docker和Docker Compose将Laravel应用与PostgreSQL数据库进行容器化,构建一个高效、可移植的开发环境。

2. 项目结构概述

在开始之前,请确保您的Laravel项目已经准备就绪。我们将创建两个核心文件:Dockerfile 用于构建Laravel应用程序的Docker镜像,以及 docker-compose.yml 用于定义和运行Laravel应用与PostgreSQL数据库服务。这些文件通常放置在Laravel项目的根目录下。

.
├── app/
├── bootstrap/
├── config/
├── database/
├── public/
├── resources/
├── routes/
├── storage/
├── tests/
├── vendor/
├── .env
├── composer.json
├── composer.lock
├── artisan
├── Dockerfile              <-- Laravel 应用的 Dockerfile
└── docker-compose.yml      <-- Docker Compose 配置文件

3. Dockerfile 配置 (Laravel 应用容器)

Dockerfile 用于定义如何构建您的Laravel应用程序镜像。以下是一个针对Laravel 7.x/8.x (PHP 7.4) 和PostgreSQL优化的Dockerfile示例。

# 使用官方PHP-FPM镜像作为基础,版本为7.4
FROM php:7.4-fpm

# 设置容器内的工作目录
WORKDIR /app

# 安装系统依赖:
# git, curl: 常用的版本控制和网络工具
# libpng-dev, libonig-dev, libxml2-dev, libzip-dev, zip, unzip: PHP扩展所需的库
# postgresql-client, libpq-dev: PostgreSQL客户端工具和PHP PostgreSQL扩展所需的开发库
# python3, python3-pip: 如果您的项目需要Python脚本或数据科学工具 (可选)
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 && \
    rm -rf /var/lib/apt/lists/* && \
    ln -s /usr/bin/python3 /usr/bin/python

# 安装可选的Python包 (如果需要,可根据项目需求调整)
# RUN pip3 install --no-cache-dir pandas scikit-learn numpy

# 安装并启用PHP扩展:
# pdo_pgsql: PostgreSQL数据库驱动
# mbstring: 多字节字符串支持
# exif: 处理图像元数据
# pcntl: 进程控制 (通常用于队列)
# bcmath: 任意精度数学
# gd: 图像处理库 (需要libpng-dev)
# zip: Zip文件处理 (需要libzip-dev)
RUN docker-php-ext-install -j$(nproc) pdo_pgsql mbstring exif pcntl bcmath gd zip && \
    docker-php-ext-enable gd zip

# 安装Node.js和npm (如果您的Laravel项目使用Laravel Mix或其他前端构建工具,则需要)
# 这里安装的是Node.js 16.x版本
RUN curl -fsSL https://deb.nodesource.com/setup_16.x | bash - \
    && apt-get install -y nodejs && \
    rm -rf /var/lib/apt/lists/*

# 安装Composer (PHP依赖管理器)
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer

# 将本地项目文件复制到容器的工作目录
COPY . .

# 安装Laravel项目依赖
# 先删除旧的vendor目录和composer.lock以确保清洁安装
# 使用 --no-dev 和 --optimize-autoloader 进行生产环境优化安装
RUN rm -rf vendor composer.lock && \
    composer install --no-dev --optimize-autoloader

# 设置Laravel存储和缓存目录的权限,确保Web服务器可以写入
RUN chmod -R 775 storage bootstrap/cache && \
    chown -R www-data:www-data /app

# 如果项目使用Laravel Mix,安装Node.js依赖并编译前端资源 (可选)
# RUN npm install && npm run prod

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

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

Dockerfile 解释:

  • FROM php:7.4-fpm: 选择PHP 7.4 FPM作为基础镜像。FPM (FastCGI Process Manager) 是生产环境中运行PHP应用的推荐方式,它与Nginx等Web服务器配合使用。
  • WORKDIR /app: 设置容器内的工作目录,所有后续命令都将在此目录下执行。
  • RUN apt-get update && apt-get install -y ...: 更新包列表并安装必要的系统依赖。这包括PostgreSQL客户端工具 (postgresql-client) 和PHP扩展所需的开发库 (libpq-dev, libpng-dev 等)。
  • RUN docker-php-ext-install ...: 安装并启用PHP扩展,如 pdo_pgsql (PostgreSQL数据库驱动)、gd (图像处理) 等,这些是Laravel应用可能需要的。
  • RUN curl ... | bash - && apt-get install -y nodejs: 安装Node.js和npm,如果您的Laravel项目需要前端构建(例如使用Laravel Mix)。
  • RUN curl ... | php -- ... composer: 安装Composer,用于管理PHP依赖。
  • COPY . .: 将当前目录(您的Laravel项目)下的所有文件复制到容器的 /app 目录。
  • RUN composer install --no-dev --optimize-autoloader: 安装Laravel项目的PHP依赖。--no-dev 排除开发依赖,--optimize-autoloader 优化Composer自动加载器,这对于生产环境非常有用。
  • RUN chmod -R 775 storage bootstrap/cache && chown -R www-data:www-data /app: 设置Laravel的 storage 和 bootstrap/cache 目录的权限,确保Web服务器用户 (www-data) 可以写入。
  • EXPOSE 9000: 声明容器将监听9000端口,这是PHP-FPM的默认端口。
  • CMD ["php-fpm"]: 定义容器启动时执行的命令,即启动PHP-FPM服务。

4. Docker Compose 配置 (服务编排)

docker-compose.yml 文件用于定义和运行多容器Docker应用程序。我们将在这里定义Laravel应用服务和PostgreSQL数据库服务。

站长俱乐部购物系统
站长俱乐部购物系统

功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类

下载
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目录,实现代码热重载
      - /app/vendor # 匿名卷,防止宿主机的vendor目录覆盖容器内的依赖
      - /app/node_modules # 匿名卷,防止宿主机的node_modules目录覆盖容器内的依赖
    ports:
      - "80:8000" # 将宿主机的80端口映射到容器的8000端口
    environment: # 环境变量,用于Laravel连接数据库
      DB_CONNECTION: pgsql
      DB_HOST: postgres_db # 数据库服务名称作为主机名
      DB_PORT: 5432
      DB_DATABASE: your_laravel_db # 替换为您的数据库名称
      DB_USERNAME: your_user # 替换为您的数据库用户名
      DB_PASSWORD: your_password # 替换为您的数据库密码
    depends_on:
      - postgres_db # 确保postgres_db服务在laravel_app之前启动
    networks:
      - app_network # 连接到自定义网络

  # PostgreSQL 数据库服务
  postgres_db:
    container_name: postgres-db-container
    image: postgres:13 # 使用PostgreSQL 13官方镜像
    restart: unless-stopped
    environment: # 数据库环境变量
      POSTGRES_DB: your_laravel_db # 替换为您的数据库名称
      POSTGRES_USER: your_user # 替换为您的数据库用户名
      POSTGRES_PASSWORD: your_password # 替换为您的数据库密码
    volumes:
      - postgres_data:/var/lib/postgresql/data # 数据持久化卷
    ports:
      - "5432:5432" # 将宿主机的5432端口映射到容器的5432端口 (可选,用于外部访问)
    networks:
      - app_network # 连接到自定义网络

# 定义数据卷,用于PostgreSQL数据持久化
volumes:
  postgres_data:

# 定义自定义网络,使服务之间可以相互通信
networks:
  app_network:
    driver: bridge # 默认的桥接网络

docker-compose.yml 解释:

  • version: '3.8': 指定Compose文件格式版本。
  • services: 定义应用程序包含的服务。
    • laravel_app:
      • build: 指示Docker Compose 使用当前目录下的 Dockerfile 构建镜像。
      • command: 覆盖 Dockerfile 中的 CMD,直接运行Laravel的开发服务器。
      • restart: unless-stopped: 容器在非手动停止的情况下会自动重启。
      • volumes:
        • .:/app: 将宿主机的当前目录挂载到容器的 /app 目录。这意味着您在本地修改代码,容器内会立即反映,无需重建镜像。
        • /app/vendor 和 /app/node_modules: 这些是匿名卷,用于防止宿主机上的 vendor 和 node_modules 目录覆盖容器内已安装的依赖。当您在容器内运行 composer install 或 npm install 时,这些依赖会安装到这些匿名卷中,而不是直接映射到宿主机。
      • ports: - "80:8000": 将宿主机的 80 端口映射到容器的 8000 端口,您可以通过 http://localhost 访问Laravel应用。
      • environment: 设置环境变量,Laravel会使用这些变量连接到PostgreSQL数据库。DB_HOST 设置为 postgres_db,这是数据库服务的名称,Docker Compose 会自动解析。
      • depends_on: - postgres_db: 确保 postgres_db 服务在 laravel_app 之前启动。
      • networks: - app_network: 将服务连接到名为 app_network 的自定义网络。
    • postgres_db:
      • image: postgres:13: 使用PostgreSQL 13的官方Docker镜像。
      • environment: 设置PostgreSQL数据库的名称、用户名和密码。请务必替换为您的实际值。
      • volumes: - postgres_data:/var/lib/postgresql/data: 使用命名卷 postgres_data 来持久化PostgreSQL的数据。这样即使容器被删除,数据也不会丢失。
      • ports: - "5432:5432": 将宿主机的 5432 端口映射到容器的 5432 端口。这允许您从宿主机上的其他工具(如pgAdmin)直接连接到数据库。
      • networks: - app_network: 连接到自定义网络。
  • volumes: 定义命名卷 postgres_data,用于PostgreSQL的数据持久化。
  • networks: 定义一个名为 app_network 的自定义桥接网络,所有服务都将连接到这个网络,从而能够通过服务名称相互通信。

5. Laravel 环境配置 (.env)

在您的Laravel项目根目录下的 .env 文件中,您需要配置数据库连接信息,使其能够连接到Docker Compose中运行的PostgreSQL服务。

DB_CONNECTION=pgsql
DB_HOST=postgres_db # 必须与docker-compose.yml中数据库服务的名称一致
DB_PORT=5432
DB_DATABASE=your_laravel_db # 必须与docker-compose.yml中POSTGRES_DB一致
DB_USERNAME=your_user # 必须与docker-compose.yml中POSTGRES_USER一致
DB_PASSWORD=your_password # 必须与docker-compose.yml中POSTGRES_PASSWORD一致

重要提示: 请确保 .env 文件中的数据库配置与 docker-compose.yml 中 postgres_db 服务的 environment 部分完全匹配。

6. 启动与

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2691

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1663

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1525

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

954

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1420

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1509

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

3

2026.01.20

热门下载

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

精品课程

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

共137课时 | 8.9万人学习

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

共6课时 | 8.6万人学习

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

共13课时 | 0.9万人学习

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

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