2023-01-18 10:47:52 +00:00
|
|
|
# dockcheck
|
2023-01-22 12:40:19 +00:00
|
|
|
### A script checking updates for docker images **without the need of pulling** - then having the option to auto-update.
|
2023-01-22 12:37:28 +00:00
|
|
|
|
2023-01-19 11:29:22 +00:00
|
|
|
With the help of [`regctl`](https://github.com/regclient/regclient).
|
2023-01-18 20:03:42 +00:00
|
|
|
This is just a concept for fun and inspiration, use with care.
|
2023-01-18 12:46:00 +00:00
|
|
|
___
|
2023-01-18 12:44:39 +00:00
|
|
|
|
2023-01-18 12:45:15 +00:00
|
|
|
## Dependencies:
|
2023-01-18 12:46:00 +00:00
|
|
|
Running docker (duh) and compose, either standalone or plugin.
|
2023-01-19 11:16:49 +00:00
|
|
|
`regctl` by [regclient](https://github.com/regclient/regclient)
|
|
|
|
The script will ask to download `regctl` if it's not in PATH or current directory.
|
2023-01-18 12:46:00 +00:00
|
|
|
___
|
2023-01-18 12:45:30 +00:00
|
|
|
## `dockcheck.sh`
|
2023-01-18 20:07:52 +00:00
|
|
|
```bash
|
2023-01-22 12:37:28 +00:00
|
|
|
$ ./dockcheck.sh -h
|
2023-01-19 11:16:49 +00:00
|
|
|
Syntax: dockcheck.sh [OPTION] [optional string to filter names]
|
|
|
|
|
|
|
|
Options:
|
|
|
|
-h Print this Help.
|
|
|
|
-a Automatic updates, without interaction.
|
|
|
|
-n No updates, only checking availability.
|
|
|
|
```
|
2023-01-22 12:44:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
![](https://github.com/mag37/dockcheck/blob/main/example_run.gif)
|
2023-01-19 11:20:02 +00:00
|
|
|
|
2023-01-19 11:16:49 +00:00
|
|
|
Basic example:
|
|
|
|
```bash
|
2023-01-22 12:37:28 +00:00
|
|
|
$ ./dockcheck.sh
|
2023-01-18 20:07:52 +00:00
|
|
|
. . .
|
|
|
|
Containers with updates available:
|
|
|
|
whoogle-search
|
|
|
|
|
|
|
|
Containers on latest version:
|
|
|
|
glances
|
|
|
|
homer
|
|
|
|
|
|
|
|
Do you want to update? y/[n]
|
|
|
|
y
|
2023-01-18 20:12:00 +00:00
|
|
|
```
|
2023-01-19 11:20:02 +00:00
|
|
|
Then it proceedes to run `pull` and `up -d` on every container with updates.
|
|
|
|
|
|
|
|
|
2023-01-19 11:16:49 +00:00
|
|
|
|
2023-01-19 11:21:05 +00:00
|
|
|
And with `-n` *No updates* and `gl` for `*gl*` filtering:
|
2023-01-19 11:16:49 +00:00
|
|
|
```bash
|
2023-01-22 12:37:28 +00:00
|
|
|
$ ./dockcheck.sh -n gl
|
2023-01-19 11:16:49 +00:00
|
|
|
. . .
|
|
|
|
Containers with updates available:
|
|
|
|
whoogle-search
|
|
|
|
|
|
|
|
Containers on latest version:
|
|
|
|
glances
|
|
|
|
|
|
|
|
No updates installed, exiting
|
|
|
|
```
|
2023-01-18 20:07:52 +00:00
|
|
|
|
2023-01-22 12:37:28 +00:00
|
|
|
### :beetle: Squashed Bugs:
|
|
|
|
- ~~No options for running without updates or auto update.~~
|
|
|
|
- ~~No filter to check only specific containers.~~
|
|
|
|
- ~~Faulty registry checkups stopped the updates completely.~~
|
|
|
|
- ~~No clear checks to skip containers producing errors.~~
|
|
|
|
- ~~Multi-digest images didn't correctly check with registry, giving false positives on updates.~~
|
|
|
|
|
|
|
|
### :hammer: Known issues
|
|
|
|
- No granular choice of what to update (except initial name filter).
|
|
|
|
- No detailed error feedback (just skip + list what's skipped) .
|
|
|
|
|
2023-01-19 11:24:34 +00:00
|
|
|
## `dupc_function.sh`
|
2023-01-19 11:28:15 +00:00
|
|
|
Function to quickly check for updates on a single contianer or list of containers by name. **Without the need of pulling**.
|
2023-01-18 20:03:42 +00:00
|
|
|
Preferably placed in `.bashrc` or similar.
|
|
|
|
Example:
|
2023-01-19 09:03:43 +00:00
|
|
|
```
|
2023-01-19 11:24:34 +00:00
|
|
|
$ dupc ng
|
2023-01-19 09:03:26 +00:00
|
|
|
Updates available for local_nginx.
|
|
|
|
nginx_reverse is already latest.
|
|
|
|
Updates available for paperless-ng.
|
2023-01-18 20:03:42 +00:00
|
|
|
```
|