Install
openclaw skills install project-containerize对项目进行完整的容器化适配。自动检测分析项目代码和文档,配置和优化代码容器化打包方案,生成专用Dockerfile,生成专用compose.yaml用于快捷部署,输出说明文档,最终生成适配项目的容器化部署方案。触发词:容器化、Docker、docker run、docker-compose、Dockerfile、容器部署、镜像打包、生成 Dockerfile、创建 Dockerfile、自动 Dockerfile、项目容器化、容器化适配、容器化改造
openclaw skills install project-containerize本 Skill 用于分析项目代码结构,生成代码打包和容器化部署所需的完整方案。
目标:全面了解项目结构、技术栈、文档和现有配置
分析项目结构
list_dir 查看项目根目录结构services/、apps/、packages/、src/ 等)分析项目文档
README.md 了解项目概述DEPLOY.md、deploy.md、部署指南.mdINSTALL.md、install.md、安装说明.mddocs/deploy*、docs/install*CONFIG.md、config.md、配置说明.md.env.example、.env.templateapplication*.yml、application*.yaml、application*.properties(Java)config/ 目录下的配置文件分析现有 Dockerfile
search_file 查找 **/Dockerfile*FROM maven、FROM node、pip install、npm install、mvn build 等构建指令COPY、ADD 制品、设置运行环境VOLUME、调试工具、热重载配置分析配置文件
.env*、config.env*.yml、*.yaml、*.json、*.properties、*.confconfig/、conf/、settings/输出分析报告
deploy/analysis-report.md,包含:
目标:创建打包环境,生成可部署的制品
确定制品类型 根据项目语言确定打包产物:
| 语言 | 制品类型 | 制品路径示例 |
|---|---|---|
| Java (Maven) | JAR 文件 | target/*.jar |
| Java (Gradle) | JAR 文件 | build/libs/*.jar |
| Node.js (前端) | 静态文件 | dist/、build/ |
| Node.js (后端) | 源码+依赖 | node_modules/ + src/ |
| Python | 源码+依赖 | *.py + requirements.txt |
| Go | 二进制文件 | bin/、* (可执行文件) |
| Rust | 二进制文件 | target/release/* |
| PHP | 源码 | *.php、public/ |
| Ruby | 源码+Gem | *.rb、Gemfile* |
创建打包 Dockerfile
deploy/Dockerfile.buildpython:{version}-slimnode:{version}-alpinemaven:{version}-eclipse-temurin-{jdk}-alpine 或 gradle:{version}-jdk{jdk}-alpinegolang:{version}-alpinerust:{version}-alpine创建打包 Compose 文件
deploy/compose.build.yamldeploy/artifacts/ 目录services:
builder:
build:
context: ..
dockerfile: deploy/Dockerfile.build
volumes:
- ./artifacts:/output
执行打包
execute_command 运行:docker compose -f deploy/compose.build.yaml up --builddeploy/artifacts/ 目录创建打包说明文档
deploy/BUILD.md目标:创建仅用于运行制品的最小化 Dockerfile
核心原则:
仅复制制品:禁止将源代码复制到容器内
最小依赖:只安装运行软件所必需的额外软件
遵循项目要求:如果项目明确要求使用非 root 用户,则配置非 root 用户;默认使用 root 用户
保留必要脚本:如果项目要求必须使用特定脚本或文件,按要求复制到容器中
创建部署 Dockerfile
deploy/Dockerfileeclipse-temurin:{jdk}-jre-alpinenode:{version}-alpinepython:{version}-slimgcr.io/distroless/static:nonroot 或 alpine:latestnginx:alpineRUN addgroup -g 1000 appgroup && adduser -u 1000 -G appgroup -s /bin/sh -D appuser
USER appuser
artifacts/ 复制制品创建部署说明文档
deploy/DEPLOY.md目标:根据阶段1的分析,准备配置文件模板
分析配置需求
复制原有配置文件
application.yml、config.json、.env 等):
deploy/config/ 目录deploy/config/
├── application.yml # 从项目 src/main/resources/ 复制
├── logback.xml # 从项目 src/main/resources/ 复制
└── nginx.conf # 如果是前端项目
创建环境变量模板
deploy/.env# 数据库配置
DB_HOST=localhost
DB_PORT=3306
DB_NAME=myapp
DB_USER=root
DB_PASSWORD=changeme
# 应用配置
APP_PORT=8080
LOG_LEVEL=info
创建配置说明文档
deploy/CONFIG.md目标:生成完整的部署脚本和编排文件,包含配置文件挂载
生成 docker-run 脚本
deploy/docker-run.shdocker run 命令docker run -d \
--name myapp \
-p 8080:8080 \
-v "$(pwd)/config/application.yml:/app/config/application.yml:ro" \
-v "$(pwd)/config/logback.xml:/app/config/logback.xml:ro" \
--env-file .env \
myapp:latest
生成 Compose 文件
deploy/compose.yamlservices:
app:
build:
context: ..
dockerfile: deploy/Dockerfile
container_name: myapp
ports:
- "${APP_PORT:-8080}:8080"
env_file:
- .env
volumes:
# 挂载配置文件到容器内指定路径
- ./config/application.yml:/app/config/application.yml:ro
- ./config/logback.xml:/app/config/logback.xml:ro
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8080/health"]
interval: 30s
timeout: 10s
retries: 3
restart: unless-stopped
创建快速参考文档
deploy/QUICKSTART.md目标:生成完整的容器化说明文档
创建主文档 CONTAINERIZATION.md
deploy/CONTAINERIZATION.md1. 项目概述
2. 代码打包
3. 容器镜像构建
4. 配置管理
5. 部署指南
6. 目录结构说明
deploy/
├── Dockerfile # 部署用 Dockerfile
├── Dockerfile.build # 打包用 Dockerfile
├── compose.yaml # 部署编排
├── compose.build.yaml # 打包编排
├── docker-run.sh # 部署脚本
├── .env # 环境变量
├── artifacts/ # 打包制品
├── config/ # 配置文件目录
│ ├── application.yml # 应用配置
│ └── ...
├── CONTAINERIZATION.md # 本文档
├── QUICKSTART.md # 快速参考
├── BUILD.md # 打包说明
├── DEPLOY.md # 部署说明
├── CONFIG.md # 配置说明
└── analysis-report.md # 分析报告
创建快速开始文档
deploy/QUICKSTART.md# 1. 代码打包
cd deploy && docker compose -f compose.build.yaml up --build
# 2. 启动服务
docker compose up -d
汇总所有文档
执行本 Skill 后,将在项目目录下创建以下结构:
deploy/
├── Dockerfile # 部署用 Dockerfile(仅制品)
├── Dockerfile.build # 打包用 Dockerfile
├── compose.yaml # 部署编排(含配置挂载)
├── compose.build.yaml # 打包编排
├── docker-run.sh # 部署脚本
├── .env # 环境变量
├── artifacts/ # 打包制品目录
├── config/ # 配置文件目录
│ ├── .env.template
│ └── [项目原有配置文件]
├── CONTAINERIZATION.md # ⭐ 完整容器化说明
├── QUICKSTART.md # 快速参考
├── BUILD.md # 打包说明
├── DEPLOY.md # 部署说明
├── CONFIG.md # 配置说明
└── analysis-report.md # 阶段1分析报告
| 项目类型 | 打包制品 | 部署基础镜像 | 备注 |
|---|---|---|---|
| Java (Maven/Gradle) | JAR 文件 | eclipse-temurin:{jdk}-jre-alpine | 多阶段构建 |
| Node.js 前端 | dist/ 或 build/ | nginx:alpine | 静态文件服务 |
| Node.js 后端 | node_modules/ + 源码 | node:{version}-alpine | 包含依赖 |
| Python | 源码 + 依赖 | python:{version}-slim | pip 安装依赖 |
| Go | 二进制文件 | gcr.io/distroless/static 或 alpine | 静态编译 |
| Rust | 二进制文件 | debian:slim 或 alpine | 静态链接 |
| PHP | 源码 | php:{version}-apache 或 nginx:alpine | 预装扩展 |
| Ruby | 源码 + Gem | ruby:{version}-slim | bundle 安装 |
DEPLOY.md 和 CONTAINERIZATION.md 中明确说明使用的用户权限deploy/config/ 目录CONFIG.md 和 CONTAINERIZATION.md 中详细说明: