Install
openclaw skills install qqyougit-docker-deploy-assistant「在我电脑上明明能跑」——因为少了Docker。帮你写Dockerfile、构建镜像、配置多环境、编排docker-compose,从本地开发到服务器部署一条龙。支持Node.js/Python/Go/Java/前端全栈,覆盖CI/CD集成、安全加固、监控告警,告别环境不一致的噩梦。 触发词:Docker部署、容器化、镜像构建、Dockerfile编写、写Docker、docker-compose编排、部署到服务器、Docker配置、Docker镜像优化、多阶段构建、Docker网络、Docker数据卷、Docker环境变量、Docker健康检查、Docker安全、容器报错排查、docker build失败、容器启动失败、Docker端口映射、Docker日志查看、Docker镜像瘦身、Dockerfile最佳实践、Docker compose up、容器编排、Docker Registry、Docker Swarm、Docker网络配置、Docker volume、Docker日志收集、Dockerfile模板、容器部署、一键部署Docker、Docker生产环境、Docker开发环境、docker镜像推送、Dockerfile多阶段、docker容器通信、Docker CI/CD、Docker自动化部署、docker镜像仓库、Docker容器监控、Docker entrypoint、docker CMD vs ENTRYPOINT、docker run参数、docker compose网络、docker secrets、docker容器资源限制、containerize、dockerize、docker deployment、Docker故障排查、Docker错误修复、Docker环境配置、Docker开发环境搭建、Docker生产环境配置、Docker一键部署、docker pull/push、Docker镜像管理、Docker容器管理 排除:Kubernetes/K8s编排、本地开发调试(非容器化)、虚拟机管理
openclaw skills install qqyougit-docker-deploy-assistant「在我电脑上明明能跑」——因为少了Docker。让你的应用在任何环境都能稳定运行。
| 类别 | 关键词 |
|---|---|
| 通用 | Docker / 容器 / 镜像 / 容器化 / dockerize / containerize |
| 文件 | Dockerfile / docker-compose / .dockerignore / docker-entrypoint.sh |
| 动作 | 部署 / 打包 / 构建镜像 / 推送到仓库 / 上线 / 一键部署 |
| 编排 | docker-compose / 编排 / 多容器 / 服务编排 / 容器间通信 |
| 排查 | 容器报错 / 启动失败 / 端口冲突 / 镜像太大 / 构建失败 / 报错排查 |
| 优化 | 多阶段构建 / 镜像瘦身 / 安全加固 / Alpine / distroless |
| 配置 | 端口映射 / 环境变量 / 数据持久化 / 网络配置 / 健康检查 |
| CI/CD | Docker+CI / 自动构建 / 自动部署 / GitHub Actions / GitLab CI |
| 英文 | docker deployment / containerize / docker build / docker compose / dockerfile / container orchestration |
| 场景 | 开发环境容器化 / 生产环境部署 / 多环境配置 / 本地模拟生产 |
Dockerfile 模板:
# ============================================
# 多阶段构建 Dockerfile
# ============================================
# ===== 阶段1:依赖安装 =====
FROM node:18-alpine AS deps
WORKDIR /app
# 先复制依赖文件,利用Docker缓存
COPY package*.json ./
RUN npm ci --only=production
# ===== 阶段2:构建 =====
FROM node:18-alpine AS builder
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build
# ===== 阶段3:生产运行 =====
FROM node:18-alpine AS runner
WORKDIR /app
# 环境配置
ENV NODE_ENV=production
ENV PORT=3000
# 安全:创建非root用户
RUN addgroup --system --gid 1001 nodejs && \
adduser --system --uid 1001 --ingroup nodejs appuser
# 复制依赖(来自deps阶段)
COPY --from=deps --chown=appuser:nodejs /app/node_modules ./node_modules
# 复制构建产物(来自builder阶段)
COPY --from=builder --chown=appuser:nodejs /app/dist ./dist
# 切换到非root用户
USER appuser
# 暴露端口
EXPOSE 3000
# 健康检查
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD wget -qO- http://localhost:3000/health || exit 1
# 启动命令
CMD ["node", "dist/index.js"]
docker-compose.yml 模板:
version: '3.8'
services:
app:
build:
context: .
dockerfile: Dockerfile
args:
NODE_ENV: production
image: myapp:${TAG:-latest}
container_name: myapp
restart: unless-stopped
ports:
- "${APP_PORT:-3000}:3000"
environment:
- NODE_ENV=production
- DB_HOST=postgres
- DB_PORT=5432
- DB_NAME=${DB_NAME}
- DB_USER=${DB_USER}
- DB_PASSWORD=${DB_PASSWORD}
- REDIS_HOST=redis
- REDIS_PORT=6379
env_file:
- .env
depends_on:
postgres:
condition: service_healthy
redis:
condition: service_started
volumes:
- app-data:/app/data
- ./logs:/app/logs
networks:
- backend
healthcheck:
test: ["CMD", "wget", "-qO-", "http://localhost:3000/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
deploy:
resources:
limits:
memory: 512M
cpus: '1.0'
reservations:
memory: 256M
cpus: '0.5'
logging:
driver: json-file
options:
max-size: '10m'
max-file: '3'
postgres:
image: postgres:15-alpine
restart: unless-stopped
container_name: postgres
environment:
POSTGRES_DB: ${DB_NAME}
POSTGRES_USER: ${DB_USER}
POSTGRES_PASSWORD: ${DB_PASSWORD}
POSTGRES_INITDB_ARGS: '--encoding=UTF8'
volumes:
- postgres-data:/var/lib/postgresql/data
- ./init.sql:/docker-entrypoint-initdb.d/init.sql:ro
networks:
- backend
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${DB_USER}"]
interval: 10s
timeout: 5s
retries: 5
deploy:
resources:
limits:
memory: 1G
cpus: '1.0'
redis:
image: redis:7-alpine
restart: unless-stopped
container_name: redis
command: >
redis-server
--appendonly yes
--requirepass ${REDIS_PASSWORD}
--maxmemory 256mb
--maxmemory-policy allkeys-lru
volumes:
- redis-data:/data
networks:
- backend
healthcheck:
test: ["CMD", "redis-cli", "-a", "${REDIS_PASSWORD}", "ping"]
interval: 10s
timeout: 5s
retries: 5
nginx:
image: nginx:alpine
restart: unless-stopped
container_name: nginx
ports:
- "80:80"
- "443:443"
volumes:
- ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
- ./nginx/conf.d:/etc/nginx/conf.d:ro
- ./certbot/conf:/etc/letsencrypt:ro
- ./certbot/www:/var/www/certbot:ro
- nginx-cache:/var/cache/nginx
- nginx-run:/var/run
depends_on:
- app
networks:
- backend
healthcheck:
test: ["CMD", "wget", "-qO-", "http://localhost/health"]
interval: 30s
timeout: 10s
retries: 3
volumes:
app-data:
postgres-data:
redis-data:
nginx-cache:
nginx-run:
networks:
backend:
driver: bridge
| 问题 | 原因 | 解决方案 |
|---|---|---|
| 端口被占用 | 宿主机端口冲突 | 修改映射端口或停掉占用进程 |
| 权限拒绝 | root运行+文件权限 | 创建非root用户,chown文件 |
| 镜像太大 | 包含构建工具/源码/文档 | 使用多阶段构建+Alpine镜像 |
| 构建缓存失效 | COPY顺序不对 | 先复制package.json,后复制源码 |
| 容器内连不上DB | 网络不通/主机名错误 | 使用docker-compose服务名代替localhost |
| 环境变量未生效 | .env文件路径错误/格式错误 | 检查env_file路径和变量名格式 |
| 容器不断重启 | 启动命令报错 | docker logs <container> 查看日志 |
| 磁盘空间不足 | 镜像/容器/构建缓存堆积 | docker system prune 清理 |
| 容器内中文乱码 | 字符集未设置 | 添加 ENV LANG=C.UTF-8 |
| 文件权限错误 | UID/GID不一致 | 使用 --chown 参数指定所有者 |
| 内存溢出(OOM) | 应用内存泄漏或限制太小 | 添加 memory limit 或检查应用 |
| 构建超时 | 网络慢或依赖太多 | 换国内镜像源或增加 timeout |
| Pull镜像失败 | 网络问题或镜像不存在 | 检查镜像名/换镜像源/配置代理 |
docker buildx中文输出