
本教程详细指导如何利用docker和docker compose容器化laravel应用程序与postgresql数据库。文章涵盖了优化的dockerfile配置,用于构建laravel应用镜像;以及一份完整的docker-compose.yml文件,用于编排laravel应用、postgresql数据库和网络。此外,教程还提供了laravel环境配置、容器启动与管理命令,并分享了重要的注意事项与最佳实践,旨在帮助开发者高效搭建和部署开发环境。
在现代Web开发中,Docker已成为部署和管理应用程序及其依赖的强大工具。通过容器化,我们可以确保开发、测试和生产环境的一致性,极大地简化了环境配置和团队协作。本教程将指导您如何使用Docker和Docker Compose将Laravel应用与PostgreSQL数据库进行容器化,构建一个高效、可移植的开发环境。
在开始之前,请确保您的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 配置文件
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 解释:
docker-compose.yml 文件用于定义和运行多容器Docker应用程序。我们将在这里定义Laravel应用服务和PostgreSQL数据库服务。
功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类
0
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 解释:
在您的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 部分完全匹配。
以上就是使用Docker容器化Laravel与PostgreSQL的完整教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号