返回顶部
🇺🇸 English
🇨🇳 简体中文
🇨🇳 繁體中文
🇺🇸 English
🇯🇵 日本語
🇰🇷 한국어
🇫🇷 Français
🇩🇪 Deutsch
🇪🇸 Español
🇷🇺 Русский
D

Docker

Docker containers, images, Compose stacks, networking, volumes, debugging, production hardening, and the commands that keep real environments stable. Use when (1) the task touches Docker, Dockerfiles, images, containers, or Compose; (2) build reliability, runtime behavior, logs, ports, volumes, or security matter; (3) the agent needs Docker guidance and should apply it by default.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.4
安全检测
已通过
10,560
下载量
21
收藏
概述
安装方式
版本历史

Docker

## When to Use Use when the task involves Docker, Dockerfiles, container builds, Compose, image publishing, networking, volumes, logs, debugging, or production container operations. This skill is stateless and should be applied directly whenever Docker work appears. ## Quick Reference | Topic | File | |-------|------| | Essential commands | `commands.md` | | Dockerfile patterns | `images.md` | | Compose orchestration | `compose.md` | | Networking & volumes | `infrastructure.md` | | Security hardening | `security.md` | ## Core Rules ### 1. Pin Image Versions - `python:3.11.5-slim` not `python:latest` - Today's latest differs from tomorrow's — breaks immutable builds ### 2. Combine RUN Commands - `apt-get update && apt-get install -y pkg` in ONE layer - Separate layers = stale package cache weeks later ### 3. Non-Root by Default - Add `USER nonroot` in Dockerfile - Running as root fails security scans and platform policies ### 4. Set Resource Limits - `-m 512m` on every container - OOM killer strikes without warning otherwise ### 5. Configure Log Rotation - Default json-file driver has no size limit - One chatty container fills disk and crashes host ## Image Traps - Multi-stage builds: forgotten `--from=builder` copies from wrong stage silently - COPY before RUN invalidates cache on every file change — copy requirements first, install, then copy code - `ADD` extracts archives automatically — use `COPY` unless you need extraction - Build args visible in image history — never use for secrets ## Runtime Traps - `localhost` inside container is container's localhost — bind to `0.0.0.0` - Port already in use: previous container still stopping — wait or force remove - Exit code 137 = OOM killed, 139 = segfault — check with `docker inspect --format='{{.State.ExitCode}}'` - No shell in distroless images — `docker cp` files out or use debug sidecar ## Networking Traps - Container DNS only works on custom networks — default bridge can't resolve names - Published ports bind to `0.0.0.0` — use `127.0.0.1:5432:5432` for local-only - Zombie connections from killed containers — set health checks and restart policies ## Compose Traps - `depends_on` waits for container start, not service ready — use `condition: service_healthy` - `.env` file in wrong directory silently ignored — must be next to docker-compose.yml - Volume mounts overwrite container files — empty host dir = empty container dir - YAML anchors don't work across files — use multiple compose files instead ## Volume Traps - Anonymous volumes accumulate silently — use named volumes - Bind mounts have permission issues — container user must match host user - `docker system prune` doesn't remove named volumes — add `--volumes` flag - Stopped container data persists until container removed ## Resource Leaks - Dangling images grow unbounded — `docker image prune` regularly - Build cache grows forever — `docker builder prune` reclaims space - Stopped containers consume disk — `docker container prune` or `--rm` on run - Networks pile up from compose projects — `docker network prune` ## Secrets and Security - ENV and COPY bake secrets into layer history permanently — use secrets mount or runtime env - `--privileged` disables all security — almost never needed, find specific capability instead - Images from unknown registries may be malicious — verify sources - Build args visible in image history — don't use for secrets ## Debugging - Exit code 137 = OOM killed, 139 = segfault — check `docker inspect --format='{{.State.ExitCode}}'` - Container won't start: check logs even for failed containers — `docker logs <container>` - No shell in distroless images — `docker cp` files out or use debug sidecar - Inspect filesystem of dead container — `docker cp deadcontainer:/path ./local` ## Related Skills Install with `clawhub install <slug>` if user confirms: - `devops` — deployment pipelines - `linux` — host system management - `server` — server administration ## Feedback - If useful: `clawhub star docker` - Stay updated: `clawhub sync`

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 docker-1776329724 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 docker-1776329724 技能

通过命令行安装

skillhub install docker-1776329724

下载 Zip 包

⬇ 下载 Docker v1.0.4

文件大小: 7.78 KB | 发布时间: 2026-4-17 14:09

v1.0.4 最新 2026-4-17 14:09
Simplified the skill name and kept the stateless activation guidance

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部