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

使用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.4FROM 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数据库服务。

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=pgsqlDB_HOST=postgres_db # 必须与docker-compose.yml中数据库服务的名称一致DB_PORT=5432DB_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. 启动与

以上就是使用Docker容器化Laravel与PostgreSQL的完整教程的详细内容,更多请关注php中文网其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 05:37:47
下一篇 2025年12月13日 05:37:56

相关推荐

  • 如何用dom2img解决网页打印样式不显示的问题?

    用dom2img解决网页打印样式不显示的问题 想将网页以所见即打印的的效果呈现,需要采取一些措施,特别是在使用了bootstrap等大量采用外部css样式的框架时。 问题根源 在常规打印操作中,浏览器通常会忽略css样式等非必要的页面元素,导致打印出的结果与网页显示效果不一致。这是因为打印机制只识别…

    2025年12月24日
    800
  • 如何解决本地图片在使用 mask JS 库时出现的跨域错误?

    如何跨越localhost使用本地图片? 问题: 在本地使用mask js库时,引入本地图片会报跨域错误。 解决方案: 要解决此问题,需要使用本地服务器启动文件,以http或https协议访问图片,而不是使用file://协议。例如: python -m http.server 8000 然后,可以…

    2025年12月24日
    200
  • Bootstrap 中如何让文字浮于阴影之上?

    文字浮于阴影之上 文中提到的代码片段中 元素中的文字被阴影元素 所遮挡,如何让文字显示在阴影之上? bootstrap v3和v5在处理此类问题方面存在差异。 解决方法 在bootstrap v5中,给 元素添加以下css样式: .banner-content { position: relativ…

    2025年12月24日
    000
  • Bootstrap 5:如何将文字置于阴影之上?

    文字重叠阴影 在 bootstrap 5 中,将文字置于阴影之上时遇到了困难。在 bootstrap 3 中,此问题并不存在,但升级到 bootstrap 5 后却无法实现。 解决方案 为了解决这个问题,需要给 元素添加以下样式: .banner-content { position: relati…

    2025年12月24日
    400
  • Bootstrap 5 如何将文字置于阴影上方?

    如何在 bootstrap 5 中让文字位于阴影上方? 在将网站从 bootstrap 3 升级到 bootstrap 5 后,用户遇到一个问题:文字内容无法像以前那样置于阴影层之上。 解决方案: 为了将文字置于阴影层上方,需要给 banner-content 元素添加以下 css 样式: .ban…

    2025年12月24日
    100
  • 使用 Mask 导入本地图片时,如何解决跨域问题?

    跨域疑难:如何解决 mask 引入本地图片产生的跨域问题? 在使用 mask 导入本地图片时,你可能会遇到令人沮丧的跨域错误。为什么会出现跨域问题呢?让我们深入了解一下: mask 框架假设你以 http(s) 协议加载你的 html 文件,而当使用 file:// 协议打开本地文件时,就会产生跨域…

    2025年12月24日
    200
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    000
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • HTMLrev 上的免费 HTML 网站模板

    HTMLrev 是唯一的人工策划的库专门专注于免费 HTML 模板,适用于由来自世界各地慷慨的模板创建者制作的网站、登陆页面、投资组合、博客、电子商务和管理仪表板世界。 这个人就是我自己 Devluc,我已经工作了 1 年多来构建、改进和更新这个很棒的免费资源。我自己就是一名模板制作者,所以我知道如…

    2025年12月24日
    300
  • 如何使用 Laravel 框架轻松整合微信支付与支付宝支付?

    如何通过 laravel 框架整合微信支付与支付宝支付 在 laravel 开发中,为电商网站或应用程序整合支付网关至关重要。其中,微信支付和支付宝是中国最流行的支付平台。本文将介绍如何使用 laravel 框架封装这两大支付平台。 一个简单有效的方法是使用业内认可的 easywechat lara…

    2025年12月24日
    000
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • Laravel 框架中如何无缝集成微信支付和支付宝支付?

    laravel 框架中微信支付和支付宝支付的封装 如何将微信支付和支付宝支付无缝集成到 laravel 框架中? 建议解决方案 考虑使用 easywechat 的 laravel 版本。easywechat 是一个成熟、维护良好的库,由腾讯官方人员开发,专为处理微信相关功能而设计。其 laravel…

    2025年12月24日
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 使用Laravel框架如何整合微信支付和支付宝支付?

    使用 Laravel 框架整合微信支付和支付宝支付 在使用 Laravel 框架开发项目时,整合支付网关是常见的需求。对于微信支付和支付宝支付,推荐采用以下方法: 使用第三方库:EasyWeChat 的 Laravel 版本 建议直接使用现有的 EasyWeChat 的 Laravel 版本。该库由…

    2025年12月24日
    000
  • 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中?

    如何简洁集成微信和支付宝支付到 Laravel 问题: 如何将微信支付和支付宝支付无缝集成到 Laravel 框架中? 答案: 强烈推荐使用流行的 Laravel 包 EasyWeChat,它由腾讯开发者维护。多年来,它一直保持更新,提供了一个稳定可靠的解决方案。 集成步骤: 安装 Laravel …

    2025年12月24日
    100
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信