Docker Compose一键部署LNMP环境全攻略


首先,我们得确定LNMP环境的各个组件。LNMP通常包括Nginx作为Web服务器,MySQL作为数据库,PHP处理动态内容,可能还需要phpMyAdmin进行数据库管理。所有服务都需要通过Docker容器来部署,并且要确保它们能够相互通信。

今天就带着大家如何使用Docker Compose实现一键部署!

一、架构设计与服务规划

1.1 LNMP容器架构图

PHP请求
静态文件
用户
Nginx:80
PHP-FPM:9000
项目代码
MySQL:3306
Redis:6379
MySQL数据卷

二、项目结构准备

lnmp-docker/
├── docker-compose.yml
├── nginx/
│   ├── conf.d/
│   │   └── app.conf
│   └── nginx.conf
├── php/
│   └── Dockerfile
├── mysql/
│   └── my.cnf
├── html/
│   └── index.php
└── .env

三、核心配置文件

3.1 docker-compose.yml

version: '3.8'

services:
  # Web服务
  nginx:
    image: nginx:1.25-alpine
    ports:
      - "80:80"
      - "443:443"
    volumes:
      - ./nginx/conf.d:/etc/nginx/conf.d
      - ./nginx/nginx.conf:/etc/nginx/nginx.conf
      - ./html:/var/www/html
      - ./ssl:/etc/nginx/ssl
    depends_on:
      php:
        condition: service_healthy
    networks:
      - lnmp-net

  # PHP处理
  php:
    build: ./php
    volumes:
      - ./html:/var/www/html
    environment:
      - TZ=Asia/Shanghai
    healthcheck:
      test: ["CMD", "php-fpm", "-t"]
      interval: 10s
      timeout: 5s
      retries: 3
    networks:
      - lnmp-net

  # 数据库
  mysql:
    image: mysql:8.0-debian
    volumes:
      - mysql_data:/var/lib/mysql
      - ./mysql/my.cnf:/etc/mysql/conf.d/my.cnf
    environment:
      - MYSQL_ROOT_PASSWORD=${DB_ROOT_PASSWORD}
      - MYSQL_DATABASE=${DB_NAME}
      - MYSQL_USER=${DB_USER}
      - MYSQL_PASSWORD=${DB_PASSWORD}
    networks:
      - lnmp-net

  # 数据库管理
  phpmyadmin:
    image: phpmyadmin:5.2
    ports:
      - "8080:80"
    environment:
      - PMA_HOST=mysql
      - PMA_USER=root
      - PMA_PASSWORD=${DB_ROOT_PASSWORD}
    depends_on:
      - mysql
    networks:
      - lnmp-net

volumes:
  mysql_data:

networks:
  lnmp-net:
    driver: bridge

3.2 PHP Dockerfile

FROM php:8.2-fpm-alpine

# 安装扩展
RUN apk add --no-cache \
    freetype-dev \
    libjpeg-turbo-dev \
    libpng-dev \
    libzip-dev \
    && docker-php-ext-configure gd --with-freetype --with-jpeg \
    && docker-php-ext-install -j$(nproc) gd pdo_mysql mysqli zip opcache

# 生产环境优化
RUN { \
    echo 'opcache.enable=1'; \
    echo 'opcache.memory_consumption=128'; \
    echo 'opcache.max_accelerated_files=10000'; \
    echo 'opcache.revalidate_freq=60'; \
} > /usr/local/etc/php/conf.d/opcache.ini

WORKDIR /var/www/html

3.3 Nginx配置

# nginx/conf.d/app.conf
server {
    listen 80;
    server_name localhost;
    
    root /var/www/html;
    index index.php index.html;

    location / {
        try_files $uri $uri/ /index.php?$args;
    }

    location ~ \.php$ {
        fastcgi_pass php:9000;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    }
}

四、环境变量配置(.env)

# 数据库配置
DB_ROOT_PASSWORD=SuperSecretRootPass!
DB_NAME=app_prod
DB_USER=app_user
DB_PASSWORD=UserStrongPass123

# 时区配置
TZ=Asia/Shanghai

五、部署与验证

5.1 启动命令

# 构建并启动服务
docker compose up -d --build

# 查看服务状态
docker compose ps

# 查看实时日志
docker compose logs -f

5.2 环境验证

<?php
// html/index.php
phpinfo();

// 测试数据库连接
try {
    $pdo = new PDO(
        'mysql:host=mysql;dbname='.getenv('DB_NAME'),
        getenv('DB_USER'),
        getenv('DB_PASSWORD')
    );
    echo "Database connection OK!";
} catch (Exception $e) {
    echo "Connection failed: " . $e->getMessage();
}

六、生产环境优化建议

  1. SSL加密:在nginx配置中添加443端口SSL证书
  2. 资源限制:在compose文件中添加资源限制
    deploy:
      resources:
        limits:
          cpus: '2'
          memory: 1G
    
  3. 日志切割:配置logrotate管理容器日志
  4. 备份策略:定时备份MySQL数据卷
    docker compose exec mysql sh -c 'exec mysqldump --all-databases -uroot -p"$MYSQL_ROOT_PASSWORD"' > backup.sql
    

架构师提醒:通过docker compose config验证配置完整性,使用--env-file指定不同环境配置。建议将敏感信息存储在Docker Secrets中,使用docker scan定期扫描镜像漏洞。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值