From ecf8ae121843f12f47492cbaca176b3788cb21f0 Mon Sep 17 00:00:00 2001 From: Jonas Kaninda Date: Tue, 19 Dec 2023 04:07:18 +0100 Subject: [PATCH] Update README.md --- .DS_Store | Bin 6148 -> 6148 bytes README.md | 41 +++++++++++++++++++++++++++++++++++++++++ backup_script.sh | 8 ++++++++ 3 files changed, 49 insertions(+) create mode 100755 backup_script.sh diff --git a/.DS_Store b/.DS_Store index 6a6c6e64e3883c5a0f36bcdc1bb4e4d4eff50404..9b5fb6b8c547ffb72bb5a2ee503e71a1d27a1bcf 100644 GIT binary patch delta 21 ccmZoMXffDuf`!A_*jPuw$iQOr1r`%w07@$cIsgCw delta 21 ccmZoMXffDuf`!A#)KW*m$k2TA1r`%w07`iVK>z>% diff --git a/README.md b/README.md index cd598d9..3c5fbd6 100644 --- a/README.md +++ b/README.md @@ -45,7 +45,13 @@ bkup -o backup ```sh bkup --operation backup --destination s3 ``` +## Docker run: +```sh +docker run --rm --network your_network_name --name mysql-bkup -v $PWD/backup:/backup/ -e "DB_HOST=database_host_name" -e "DB_USERNAME=username" -e "DB_PASSWORD=password" jkaninda/mysql-bkup:latest bkup -o backup -db database_name +``` + +## Docker compose file: ```yaml version: '3' services: @@ -89,6 +95,15 @@ bkup -o restore -f database_20231217_115621.sql ```sh bkup --operation restore --source s3 --file database_20231217_115621.sql ``` + +## Docker run: + +```sh +docker run --rm --network your_network_name --name mysql-bkup -v $PWD/backup:/backup/ -e "DB_HOST=database_host_name" -e "DB_USERNAME=username" -e "DB_PASSWORD=password" jkaninda/mysql-bkup:latest bkup -o backup -db database_name -f napata_20231219_022941.sql.gz +``` + +## Docker compose file: + ```yaml version: '3' services: @@ -153,6 +168,32 @@ bkup --operation backup --destination s3 -database mydatabase - S3_ENDPOINT=${S3_ENDPOINT} ``` +## Run "docker run" from crontab + +Make an automated backup (every night at 1). + +> backup_script.sh + +```sh +#!/bin/sh +DB_USERNAME='db_username' +DB_PASSWORD='password' +DB_HOST='db_hostname' +DB_NAME='db_name' +BACKUP_DIR='/some/path/backup/' + +docker run --rm --name mysql-bkup -v $BACKUP_DIR:/backup/ -e "DB_HOST=$DB_HOST" -e "DB_USERNAME=$DB_USERNAME" -e "DB_PASSWORD=$DB_PASSWORD" jkaninda/mysql-bkup:latest bkup -o backup -db $DB_NAME +``` + +```sh +chmod +x backup_script.sh +``` + +Your crontab looks like this: + +```conf +0 1 * * * /path/to/backup_script.sh +``` ## Kubernetes CronJob diff --git a/backup_script.sh b/backup_script.sh new file mode 100755 index 0000000..8bfef6a --- /dev/null +++ b/backup_script.sh @@ -0,0 +1,8 @@ +#!/bin/sh +DB_USERNAME='db_username' +DB_PASSWORD='password' +DB_HOST='db_hostname' +DB_NAME='db_name' +BACKUP_DIR="$PWD/backup" + +docker run --rm --name mysql-bkup -v $BACKUP_DIR:/backup/ -e "DB_HOST=$DB_HOST" -e "DB_USERNAME=$DB_USERNAME" -e "DB_PASSWORD=$DB_PASSWORD" jkaninda/mysql-bkup:latest bkup -o backup -db $DB_NAME \ No newline at end of file