Docker Compose一键部署LNMP环境详细过程
作者:羊啊羊37
LNMP通常包括Nginx作为Web服务器,MySQL作为数据库,PHP处理动态内容,可能还需要phpMyAdmin进行数据库管理,今天给大家介绍下Docker Compose一键部署LNMP环境的详细过程,感兴趣的朋友一起看看吧
首先,我们得确定LNMP环境的各个组件。LNMP通常包括Nginx作为Web服务器,MySQL作为数据库,PHP处理动态内容,可能还需要phpMyAdmin进行数据库管理。所有服务都需要通过Docker容器来部署,并且要确保它们能够相互通信。
今天就带着大家如何使用Docker Compose实现一键部署!
一、架构设计与服务规划
1.1 LNMP容器架构图
二、项目结构准备
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: bridge3.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/html3.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();
}六、生产环境优化建议
- SSL加密:在nginx配置中添加443端口SSL证书
- 资源限制:在compose文件中添加资源限制
deploy:
resources:
limits:
cpus: '2'
memory: 1G- 日志切割:配置logrotate管理容器日志
- 备份策略:定时备份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定期扫描镜像漏洞。
到此这篇关于Docker Compose一键部署LNMP环境全攻略的文章就介绍到这了,更多相关Docker Compose部署LNMP环境内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
