No description
Find a file
2015-03-08 15:28:01 -07:00
sample add samples to readme 2014-05-14 07:38:20 -07:00
.gitignore initial skeleton 2014-04-21 09:30:55 -07:00
cli.go initial skeleton 2014-04-21 09:30:55 -07:00
containers.go viz for containers 2014-05-13 07:06:20 -07:00
images.go start of implementing direct client access 2015-03-08 15:28:01 -07:00
images_test.go add short summary for docker images 2015-02-26 21:06:24 -08:00
LICENSE Initial commit 2014-04-21 09:17:32 -07:00
README.md add short summary for docker images 2015-02-26 21:06:24 -08:00

dockviz

Visualizing Docker Data

This command takes the raw Docker JSON and visualizes it in various ways.

For image information, output can be formatted as Graphviz, as a tree in the terminal, or in a short summary.

For container information, only Graphviz output has been implemented.

Examples

Containers

Currently, containers are visualized with labeled lines for links. Containers that aren't running are greyed out.

Images

Image info is visualized with lines indicating parent images:

Or in short form:

nate/mongodb: latest
redis: latest
ubuntu: 12.04, precise, 12.10, quantal, 13.04, raring

Or as a tree in the terminal:

└─511136ea3c5a Virtual Size: 0.0 B
  |─f10ebce2c0e1 Virtual Size: 103.7 MB
  | └─82cdea7ab5b5 Virtual Size: 103.9 MB
  |   └─5dbd9cb5a02f Virtual Size: 103.9 MB
  |     └─74fe38d11401 Virtual Size: 209.6 MB Tags: ubuntu:12.04, ubuntu:precise
  |─ef519c9ee91a Virtual Size: 100.9 MB
  | └─07302703becc Virtual Size: 101.2 MB
  |   └─cf8dc907452c Virtual Size: 101.2 MB
  |     └─a7cf8ae4e998 Virtual Size: 171.3 MB Tags: ubuntu:12.10, ubuntu:quantal
  |       |─e18d8001204e Virtual Size: 171.3 MB
  |       | └─d0525208a46c Virtual Size: 171.3 MB
  |       |   └─59dac4bae93b Virtual Size: 242.5 MB
  |       |     └─89541b3b35f2 Virtual Size: 511.8 MB
  |       |       └─7dac4e98548e Virtual Size: 511.8 MB
  |       |         └─341d0cc3fac8 Virtual Size: 511.8 MB
  |       |           └─2f96171d2098 Virtual Size: 511.8 MB
  |       |             └─67b8b7262a67 Virtual Size: 513.7 MB
  |       |               └─0fe9a2bc50fe Virtual Size: 513.7 MB
  |       |                 └─8c32832f07ba Virtual Size: 513.7 MB
  |       |                   └─cc4e1358bc80 Virtual Size: 513.7 MB
  |       |                     └─5c0d04fba9df Virtual Size: 513.7 MB Tags: nate/mongodb:latest
  |       └─398d592f2009 Virtual Size: 242.2 MB
  |         └─0cd8e7f50270 Virtual Size: 243.6 MB
  |           └─594b6f8e6f92 Virtual Size: 243.6 MB
  |             └─f832a63e87a4 Virtual Size: 243.6 MB Tags: redis:latest
  └─02dae1c13f51 Virtual Size: 98.3 MB
    └─e7206bfc66aa Virtual Size: 98.5 MB
      └─cb12405ee8fa Virtual Size: 98.5 MB
        └─316b678ddf48 Virtual Size: 169.4 MB Tags: ubuntu:13.04, ubuntu:raring

Running

TCP

When docker is listening on the TCP port:

$ curl -s http://localhost:4243/images/json?all=1 | dockviz images --tree
$ curl -s http://localhost:4243/containers/json?all=1 | dockviz containers --dot | dot -Tpng -o containers.png

Socket

When docker is listening on the socket:

$ echo -e "GET /images/json?all=1 HTTP/1.0\r\n" | nc -U /var/run/docker.sock | tail -n +5 | dockviz images --tree
$ echo -e "GET /containers/json?all=1 HTTP/1.0\r\n" | nc -U /var/run/docker.sock | tail -n +5 | dockviz containers --dot | dot -Tpng -o containers.png

GNU netcat doesn't support -U (UNIX socket) flag, so OpenBSD variant can be used.

Direct from Docker

Someday soon the Docker command line will allow dumping the image and container JSON directly.

Binaries

See the releases area for binaries.

Build

go get ./...
go build