Skip to content

sebeksd/Docker-Update-Script

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 

Repository files navigation

Docker update script

README

Description

Simple script designed for "home" use to update multiply docker containers. Script should be run from same directory as docker-compose configuration files are contained in. It also support building images from docker file + docker-compose file.

Env files are also supported, when env file with same name as ".yaml" file is present script will use it with docekr-compose, e.g. MySQL.env + MySQL.yaml in same directory (script will show info about that).

Usage:

  • Run script to update all containers (files with "!" as prefix are ignored): ./Update.sh
  • Run script providing a single file name to update only that container (files with "!" are NOT ignored): ./Update.sh NextCloud.yaml (extension can be omitted)

Containers (by default):

  • that don't require update (no changes found) will not be restarted.
  • that are in state stopped/created will be updated but not started.

How to run

  1. Directory contains: Update.sh, NextCloud.yaml, Nextcloud.dockerfile, MySQL.yaml
  • Run: ./Update.sh
  • Result: Create or update (with build from docker file) NextCloud, Create or update (without build) MySQL
  1. Directory contains: Update.sh, NextCloud.yaml, Nextcloud.dockerfile, MySQL.yaml
  • Run: ./Update.sh MySQL.yaml
  • Result: Create or update (without build) only MySQL (can contain multiply containers)
  • Extension ".yaml" can be omitted

Additional options

-h, --help - Help message -c - check only, it will pull images without updating running containers, in this mode there is no cleanup (ignores -r0, -r1, -r2, -rv, -ri, -po)
-r0, -r1, -r2 - cleanup options, r0 - no cleanup, r1 - cleanup on script finish, r2 - cleanup after every update (useful when low on disk space)
-rv - cleanup only volumes (works with -r1 and -r2)
-ri - cleanup only images (works with -r1 and -r2)
-po - "pulled only" update containers that have already pulled images only, can be used after first running script with -c\

Default is: -r1 (both unused images and volumes will be removed)

File structure example:

Yaml file can contain multiply containers definition, it can also contain "image" node or "build" node, e.g.:

Image:

services:
  nodered:
    image: nodered/node-red

Build:

services:
  nextcloud:
    build:
        context: ./
        dockerfile: Nextcloud.dockerfile

ReadmeScreenshot.png

Donation

If you like this and you think it is worth of your money or you just have to much money, feel free to donate to my Bitcoin Address :)

Bitcoin address: 17dys6rtkz8yeJLVoB7VahVYQ7TNgyuMUy

About

Script to update multiply docker compose containers

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages