WUD (What's up docker?) Keep your containers up-to-date!

Not wanting to submit a bug report on github ( because not sure if just my own error :wink: ) but Iā€™m trying out WUD for the first time and it picks up all my containers just fine.

Only, updates are not noticedā€¦ as an example, I have Docker Hub listed and the image used is with tag Latest.
But there is a newer version online created 31 August and my image is from May.

So did I do something wrong on why Iā€™m not getting update notifications in the WUD list overview?

Hi @Depechie ,

Welcome on board!

If you want WUD to find updates when Digest change (and not when there is a newer tag), typically when youā€™re relying on latest tagsā€¦

You need to add wud.watch.digest=true labels on your container.

Please find the related documentation here and examples here and here

To let you know, this feature is disabled by default because:

  1. It causes extensive usage of Docker Hub API which is restricted by quotas
  2. Itā€™s not the core feature of WUD (better consider using immutable tags as most as possible)

Thx for the reply @fmartinou ! Love the tool :slight_smile:

I read that part, but thought it was only needed when specifying single containers to watchā€¦ I did not add any container in the wud compose script, hence just all my containers are visible.

But just to be correct, better option would be to really specify the containers in the docker compose file and add the digest label?

By default:

  • all containers are discovered.
  • digests are not tracked

So the only change you need is to add in your Docker Compose file the wud.watch.digest=true label on all your containers.

By the way, regarding your example with Calibre-Web (which I use as well), you could use a release tag and let WUD get you notified when thereā€™s an update available:

services:
    calibre:
        image: linuxserver/calibre-web:0.6.12-ls129
        labels:
            - 'wud.tag.include=^\d*\.\d*\.\d*-ls\d*$$'

Good suggestionā€¦ maybe a final thing though. Adding those single containers in the services of the WUD compose, will actually also create those docker containers. ( so an extra calibre-web is being created )
I donā€™t seem to see the option to not create and watch a previous created running container? Or is that not how we should use WUD?
( Sorry for being a noob :slight_smile: )

Iā€™m not sure to understand :thinking:

I donā€™t suggest to run an additional container but to recreate your existing containers with the appropriate options.

Either
you add a wud.watch.digest=true on your containers and you keep working with latest tags

Or
you change the tag to use semver tags (like0.6.12-ls129) and add a wud.tag.include label to filter what tags to consider on the Hub.

For both cases, when youā€™ll run Docker Compose, it will recreate all the containers containing changes.

If you donā€™t want to lost data, please check before you have mounted external volumes (but Iā€™m pretty sure you did).

Ow I now see the confusion. My other containers are all setup through portainer UI and not in a compose file.
Only WUD is in a compose file.

I will add the extra label for the other containers in portainer :slight_smile:

Ok, I get it now :sweat_smile:

I will add the extra label for the other containers in portainer

Absolutely, thatā€™s the right thing to do :+1:

1 Like

Why is wud the only container defined in Docker Compose?
You should be able to define it through Portainer as the others no?

Maybe none of my businessā€¦:grin:

No that is a good question :slight_smile: itā€™s because of : Portainer v2.6.2 - unable to start containers

@mwolter @fmartinou providing certs to Debian/RPI seems to be very easy with scripts by mwolter ā† Special thanks. Now I need to do the same thing for Synology. Any idea on how to do it?

Sorry I donā€™t.
Canā€™t you access your Nas with ssh?

I just googled thatā€¦ I donā€™t know if itā€™s relevantā€¦

unsure but using docker-socket-proxy is getting very close to have it running. Currently, my problem is most probably on the certificate error on the server side. Still trying to make it work. @mwolter create a greater script but on for client-side and not from the server-side. Trying to add but somehow it keeps saying my IP is not on the list.

Will share the logs and if using docker-socket-proxy work, it will make very easy install to all machine. So got my finger cross. Iā€™m using this ranrinc/docker-socket-proxy: Secure Containerized Socat Proxy for the Docker Unix Socket (github.com)

UPDATE:

For those who would like to implement @mwolter scripts for Synology, I make some adjustments for implementing it. However, it works and you guys can just follow my guide at KRDesigns.com

Again special thanks to @fmartinou for WUD (must-have for docker user) and @mwolter for his remarkable LTS certs scripts and implementations which will work for WUD and Docker Monitor.

Who is this for?
One with multiple machines + docker running which allow you to install single WUD and single Portainer yet you will have the ability to remote and control the rest of your docker.

2 Likes

@fmartinou Curious why there are logs from each host for a single container that needs updating?

In this instance ā€˜container=frigate-lxc_frigateā€™. Frigate does need to be updated but this container is only on one host ā€˜frigate-lxcā€™. Why is there a line from each watcher for this one container?

This is clogging up the logs and makes them difficult to review. There are six containers that need updating. Instead of there being six lines (one for each container), there are 54 (one for each container and host).

07:00:01.616  INFO whats-up-docker/watcher.docker.home-assistant-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.616  INFO whats-up-docker/watcher.docker.timescaledb-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.616  INFO whats-up-docker/watcher.docker.prometheus-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.615  INFO whats-up-docker/watcher.docker.utility-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.615  INFO whats-up-docker/watcher.docker.node-red-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.614  INFO whats-up-docker/watcher.docker.grafana-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.614  INFO whats-up-docker/watcher.docker.frigate-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.613  INFO whats-up-docker/watcher.docker.gateway-pi: Update available (container=frigate-lxc_frigate)
07:00:01.613  INFO whats-up-docker/watcher.docker.pihole-lxc: Update available (container=frigate-lxc_frigate)
07:00:01.612  INFO whats-up-docker/watcher.docker.loki-lxc: Update available (container=frigate-lxc_frigate)

Hi @mwolter

Why is there a line from each watcher for this one container?

Looks like a weird bug :thinking:.
Does that happen only with logs?
Or triggers are also activated 54 times instead of 6 times?

Can you create an issue on GitHub, please? Iā€™ll take a look.

Not sure if itā€™s affecting triggers. Primarily monitor updates via Prometheus. Sure, Iā€™ll start an issue there.

Hi!

I would like to share with you some interesting features you may not know (because added over time).

:tada:
Any feedbacks are welcome!

1. Authentication
WUD allows, by default, anonymous access.
If you want to expose it publicly, it can be an issue (except if you handle authentication on your end with a Reverse Proxy for example).

Now you can directly configure authentication strategies in WUD (Basic Auth and Openid Connect are currently supported).

# Basic auth example
version: '3'

services:
  whatsupdocker:
    image: fmartinou/whats-up-docker
    ...
    environment:
      - WUD_AUTH_BASIC_JOHN_USER=john
      - WUD_AUTH_BASIC_JOHN_HASH=$$apr1$$8zDVtSAY$$62WBh9DspNbUKMZXYRsjS/
      - WUD_AUTH_BASIC_JANE_USER=jane
      - WUD_AUTH_BASIC_JANE_HASH=$$apr1$$5iyu65pm$$m/6I35fjUT7.1CMnS2w9d1
      - WUD_AUTH_BASIC_BOB_USER=bob
      - WUD_AUTH_BASIC_BOB_HASH=$apr1$$aefKbZEa$$ZSA5Y3zv9vDQOxr283NGx/
# Openid Connect example with Auth0
version: '3'

services:
  whatsupdocker:
    image: fmartinou/whats-up-docker
    ...
    environment:
      - WUD_AUTH_OIDC_AUTH0_CLIENTID=21fdsf065dfsdf05616f
      - WUD_AUTH_OIDC_AUTH0_CLIENTSECRET=rthjrtsd5640grtgfgh654
      - WUD_AUTH_OIDC_AUTH0_DISCOVERY=https://dev-sdfsdf8t.us.auth0.com/.well-known/openid-configuration

2. Release notes links
Letā€™s say that you know that Maria DB 10.4 changelog is published under
https://mariadb.com/kb/en/mariadb-1064-changelog.

So we can describe the release notes link by a string template https://mariadb.com/kb/en/mariadb-${major}${minor}${patch}-changelog

You can now define this template as a Docker label on your Container.

version: '3'

services:

  mariadb:
    image: mariadb:10.6.4
    labels:
      - wud.link.template=https://mariadb.com/kb/en/mariadb-$${major}$${minor}$${patch}-changelog

And triggers then will render the links

{
    "id":"b46d2c68ef2b3fd87b2687da8d4c6d55cf45945f79748b869c831bbb215ca039",
    "name":"nextcloud_db",
    "watcher":"local",
    "includeTags":"^\d+\.\d+\.\d+$",
    "linkTemplate":"https://mariadb.com/kb/en/mariadb-${major}${minor}${patch}-changelog",
    "image":{
        "id":"sha256:992bce5ed7107642a27af59c2a2ddb7e589a44b639342b9501044511ab00aca0",
        "registry":{
            "url":"https://registry-1.docker.io/v2",
            "name":"hub"
        },
        "name":"library/mariadb",
        "tag":{
            "value":"10.5.9",
            "semver":true
        },
        "digest":{
            "watch":false,
            "repo":"sha256:36288c675a192bd0a8a99cd6ba0780e31df85f0bfd0cbb204837cd108be3d236"
        },
        "architecture":"amd64",
        "os":"linux",
        "created":"2021-04-24T00:32:46.309Z"
    },
    "updateAvailable":true,
    "link":"https://mariadb.com/kb/en/mariadb-1059-changelog",
    "result":{
        "tag":"10.6.4",
        "link":"https://mariadb.com/kb/en/mariadb-1064-changelog"
    }
}

3. Timezone
WUD runs by default with UTC time (CRON, logsā€¦).
If you prefer running it on your local timezone, just set on WUD the regular TZ environment variable

version: '3'

services:
  whatsupdocker:
    image: fmartinou/whats-up-docker
    ...
    environment:
      - TZ=Europe/Paris

4. Watch all containers except few ones
You want to watch for updates almost all your containers except few ones.?
This can be easily achieved with the following combination:

  1. Configure WUD to watch all containers by default (WUD_WATCHER_{watcher_name}_WATCHBYDEFAULT=true)
  2. Exclude the few containers from being watched by adding on them a wud.watch=false label
version: '3'

services:
  mariadb:
    image: mariadb:10.4.5
    ...
    labels:
      wud.watch=false
2 Likes

Hey @fmartinou I went from 5.6.0 to 5.7.2 and now some containers are shown as needing an update but the tag is pointing to the architecture instead of the digets/version?
Do we need to change the config for watching?

Hi @Depechie,

Started from version 5.7.1, I changed the update resolution algorithm regarding non-semver tags (like latest).
Now, for them, WUD sorts registry tags alphabetically desc (z->a) and proposes the highest one as a candidate update.

Maybe I will rollback this feature because it surprised lots of users (as you were).

In the meantime, as a quick fix, you can add
wud.tag.include=^latest$ labels on your containers to prevent WUD from considering other tags than latest.

1 Like