docker-wait 是一个轻量级(仅9MB)的Docker实用工具,其核心功能是阻塞当前进程,直到指定的其他容器或主机开始接受TCP连接。如果在设定的超时时间内无法建立连接,工具会报错并退出。该工具主要用于确保依赖服务(如数据库、缓存等)完全启动并可连接后,再启动依赖它的服务,从而避免因依赖服务未就绪导致的启动失败问题。
EXPOSE端口并等待其TCP连接适用于Docker环境中需要控制容器启动顺序的场景,特别是:
当容器通过--link参数链接到其他容器时,docker-wait会自动检测被链接容器的所有EXPOSE端口并等待其TCP连接。
示例:
shell# 启动一个需要等待的服务容器 $ docker run -d --name mycontainer some-image-or-other # 运行wait工具,链接到目标容器并等待其所有暴露端口 $ docker run --link mycontainer:mycontainer --rm dokku/wait Waiting for 172.17.0.105:5432 . up! Everything is up
注意:链接别名(此处为
mycontainer)不影响检测结果,工具会自动识别被链接容器的所有暴露端口。
通过-p参数可以指定仅等待被链接容器的部分端口,忽略其他未指定的端口。
参数格式:-p <端口1>,<端口2>,...(多个端口用逗号分隔)
示例:
shell# 启动服务容器 $ docker run -d --name mycontainer some-image-or-other # 仅等待5432端口(忽略其他暴露端口如6379) $ docker run --link mycontainer:mycontainer --rm dokku/wait -p 5432 Not checking 172.17.0.105:6379 because port is not included. Waiting for 172.17.0.105:5432 . up! Everything is up
当需要等待未通过Docker链接的主机或端口时,可通过-c参数手动指定目标连接。
参数格式:-c <主机1>:<端口1>,<主机2>:<端口2>,...(多个目标用逗号分隔)
示例:
shell# 等待8.8.8.8的53端口和github.com的443端口 $ docker run --rm dokku/wait -c 8.8.8.8:53,github.com:443 Waiting for 8.8.8.8:53 . up! Waiting for github.com:443 . up! Everything is up
默认每个连接的超时时间为30秒,可通过-t参数自定义超时秒数。超时后工具会立即报错并以状态码1退出。
参数格式:-t <超时秒数>
示例:
shell# 等待github.com的5432端口,超时时间设为15秒 $ docker run dokku/wait -c github.com:5432 -t 15 Waiting for github.com:5432 ............................... ERROR: unable to connect
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务