一款用于监控跨多台主机 Docker 容器的实时终端

一款用于监控跨多台主机 Docker 容器的实时终端用户界面。可直接在终端跟踪 CPU、内存和网络指标。 速度极快,资源占用极低。

介绍

它支持 ssh、tcp 和本地连接,并与 Dozzle 集成用于容器日志。

优点:

  • 💻 实时监控 ------容器状态和指标的实时更新;

  • ⚡ 轻量化------用 Rust 极其快速且轻便;

  • 🌍 多主机支持 - 监控跨多主机的容器;

  • 🔍 Dozzle - 支持通过键盘快捷键打开 Dozzle 链接;

  • 📝 日志流------ 实时查看容器日志;

安装和更新

linux或macos下安装:

go 复制代码
brew install dtop

docker image 安装运行:

go 复制代码
docker run -v /var/run/docker.sock:/var/run/docker.sock -it ghcr.io/amir20/dtop

脚本安装:

go 复制代码
curl --proto '=https' --tlsv1.2 -LsSf https://github.com/amir20/dtop/releases/latest/download/dtop-installer.sh | sh

rust管理器cargo方式安装:

go 复制代码
cargo install dtop

更新:

go 复制代码
dtop update

使用帮助

默认情况下,dtop 会通过 /var/run/docker.sock 连接到本地的 Docker 守护进程。DOCKER_HOST 也支持连接其他主机。

go 复制代码
> dtop --help
A terminal-based Docker container monitoring tool with real-time CPU and memory metrics

Usage: dtop [OPTIONS] [COMMAND]

Commands:
  update  Update dtop to the latest version
  help    Print this message or the help of the given subcommand(s)

Options:
  -H, --host <HOST>
          Docker host(s) to connect to. Can be specified multiple times.
          
          Examples:
            --host local                    (Connect to local Docker daemon)
            --host ssh://user@host          (Connect via SSH)
            --host ssh://user@host:2222     (Connect via SSH with custom port)
            --host tcp://host:2375          (Connect via TCP to remote Docker daemon)
            --host tls://host:2376          (Connect via TLS)
            --host local --host ssh://user@server1 --host tls://server2:2376  (Multiple hosts)
          
          For TLS connections, set DOCKER_CERT_PATH to a directory containing:
            key.pem, cert.pem, and ca.pem
          
          If not specified, will use config file or default to "local"

  -i, --icons <ICONS>
          Icon style to use for the UI
          
          Options:
            unicode  - Standard Unicode icons (default, works everywhere)
            nerd     - Nerd Font icons (requires Nerd Font installed)

  -f, --filter <FILTER>
          Filter containers (can be specified multiple times)
          
          Examples:
            --filter status=running
            --filter name=nginx
            --filter label=com.example.version=1.0
            --filter ancestor=ubuntu:24.04
          
          Multiple filters of the same type use OR logic:
            --filter status=running --filter status=paused
          
          Different filter types use AND logic:
            --filter status=running --filter name=nginx
          
          Available filters:
            id, name, label, status, ancestor, before, since,
            volume, network, publish, expose, health, exited
          
          Note: Some filters only work with container listing, not events.
          Warnings will be shown if a filter is incompatible with events.

  -a, --all
          Show all containers (default shows only running containers)
          
          By default, dtop only shows running containers.
          Use this flag to show all containers including stopped, exited, and paused containers.
          
          Note: This flag can only enable showing all containers, not disable it.
          If your config file has 'all: true', you'll need to edit the config file
          or press 'a' in the UI to toggle back to showing only running containers.
          
          This is equivalent to pressing 'a' in the UI to toggle show all.

  -s, --sort <SORT>
          Default sort field for container list

          Options:
            uptime  - Sort by container uptime/creation time (default, newest first)
            name    - Sort by container name (alphabetically)
            cpu     - Sort by CPU usage (highest first)
            memory  - Sort by memory usage (highest first)

          You can also use short forms: u, n, c, m

          The sort direction can be toggled in the UI by pressing the same key again.

  -h, --help
          Print help (see a summary with '-h')

  -V, --version
          Print version

配置文件:

go 复制代码
1 ./config.yaml 或 ./config.yml
2. ./.dtop.yaml 或 ./.dtop.yml
3. ~/.config/dtop/config.yaml 或 ~/.config/dtop/config.yml
4. ~/.dtop.yaml 或 ~/.dtop.yml

示例配置:

go 复制代码
# Monitor production servers with filters and Dozzle integration
hosts:
  - host: ssh://user@prod-server1
    dozzle: https://dozzle.prod-server1.com/
    filter:
      - status=running
      - label=environment=production

  - host: ssh://user@prod-server2
    dozzle: https://dozzle.prod-server2.com/
    filter:
      - status=running
      - label=environment=production

# Use Nerd Font icons for better visuals
icons: nerd

或监控特定的应用:

go 复制代码
# Development environment - only show healthy web services
hosts:
  - host: local
    filter:
      - label=app=web
      - status=running
      - health=healthy

本地连接:

go 复制代码
dtop --host local
# or simply
dtop

tcp方式远程连接docker:

go 复制代码
dtop --host tcp://host2:2375

ssh连接docker:

go 复制代码
dtop --host ssh://user@host
# With custom port
dtop --host ssh://user@host:2222

tls加密方式连接远程docker(需要通过 DOCKER_CERT_PATH 环境变量配置证书。)

go 复制代码
export DOCKER_CERT_PATH=/path/to/certs  # Directory containing key.pem, cert.pem, and ca.pem
dtop --host tls://host2:2376

同时连接多个主机:

go 复制代码
dtop --host local --host tcp://host2:2375 --host ssh://user@host

演示视频:

相关推荐
腾讯蓝鲸智云6 小时前
【运维自动化-节点管理】节点管理的插件策略如何使用
运维·自动化·云计算·sass·paas
苍煜8 小时前
Docker容器网络详解+端口映射原理(系列第二篇:实战核心)
网络·docker·容器
疯狂成瘾者8 小时前
服务器的单体和集群
运维·服务器
liuhuizuikeai8 小时前
可视化门禁---Linux/Qt+SqLite篇
linux·运维·qt
charlie11451419111 小时前
嵌入式Linux驱动开发——新 API 字符设备驱动完整教程 - 从设备结构体到应用测试
linux·运维·驱动开发
gwjcloud12 小时前
Kubernetes从入门到精通(高级篇)04
云原生·容器·kubernetes
飞Link12 小时前
2000 亿砸向算力:字节跳动 AI 基建跨越,后端与运维的“万亿 Token”生死战
运维·人工智能
SWAGGY..12 小时前
Linux系统编程:(二)基础指令详解
linux·运维·服务器
张文君13 小时前
上古世纪服务端编译安装AAEmu docker编译安装
运维·docker·容器
雾岛心情13 小时前
小铭邮件管理工具箱的界面(公司版)
运维·服务器·工具·o365·小铭邮件工具箱(公司版)