Compare commits
33 commits
server/22.
...
master
Author | SHA1 | Date | |
---|---|---|---|
Jérémy Lecour | 859bb800d4 | ||
21533c6fb9 | |||
9510546d48 | |||
Mathieu Trossevin | f1d4e6ed9d | ||
Jérémy Lecour | 491c839014 | ||
4298da250b | |||
d359883700 | |||
Bruno TATU | 4cd1554780 | ||
981f5118ce | |||
Jérémy Lecour | 5dac827bb5 | ||
4807dfbc99 | |||
fd9bb57f8b | |||
d62455cd1a | |||
72f5900cf3 | |||
Jérémy Lecour | 05a62e17b5 | ||
Jérémy Lecour | 8babc64e0d | ||
Jérémy Lecour | aa7366ce2e | ||
Jérémy Lecour | ef744f77cf | ||
Jérémy Lecour | 80426c9ba9 | ||
Jérémy Lecour | b34ee2c3dc | ||
Jérémy Lecour | 94b470770f | ||
Jérémy Lecour | ed0645c9d2 | ||
Jérémy Lecour | 140a498e28 | ||
bdd3ef7350 | |||
6e0ab85c6b | |||
ff681275e3 | |||
1a892ba002 | |||
e3a969f3e2 | |||
ca4fe4ffb5 | |||
2338c92fe3 | |||
d2a76dce9c | |||
4476802182 | |||
Mathieu Trossevin | 1e35aaa4db |
20
.Jenkinsfile
20
.Jenkinsfile
|
@ -1,24 +1,15 @@
|
||||||
pipeline {
|
pipeline {
|
||||||
agent { label 'docker' }
|
agent { label 'sbuild' }
|
||||||
stages {
|
stages {
|
||||||
stage('Build Debian package') {
|
stage('Build Debian package') {
|
||||||
agent {
|
|
||||||
docker {
|
|
||||||
image 'evolix/gbp:bullseye'
|
|
||||||
args '-u root --privileged'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
when {
|
when {
|
||||||
branch 'debian'
|
branch 'debian'
|
||||||
}
|
}
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
sh 'mk-build-deps --install --remove debian/control'
|
sh 'gbp buildpackage'
|
||||||
sh 'rm -rf {source,*.gz,*.bz2,*.xz,*.deb,*.dsc,*.changes,*.buildinfo,lintian.txt,.git}'
|
|
||||||
sh "gbp clone --debian-branch=$GIT_BRANCH $GIT_URL source"
|
|
||||||
sh 'cd source && git checkout $GIT_BRANCH && gbp buildpackage -us -uc'
|
|
||||||
}
|
}
|
||||||
archiveArtifacts allowEmptyArchive: true, artifacts: '*.gz,*.bz2,*.xz,*.deb,*.dsc,*.changes,*.buildinfo,lintian.txt'
|
archiveArtifacts allowEmptyArchive: true, artifacts: 'build-area/*.gz,build-area/*.bz2,build-area/*.xz,build-area/*.deb,build-area/*.dsc,build-area/*.changes,build-area/*.buildinfo,build-area/*.build,build-area/lintian.txt'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,10 +19,7 @@ pipeline {
|
||||||
}
|
}
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
sh 'echo Dummy line to remove once something actually happens.'
|
sh 'rsync -avP build-area/bkctld*.deb build-area/bkctld*.changes build-area/bkctld*.buildinfo pub.evolix.org:/srv/upload/'
|
||||||
/* No crendentials yet.
|
|
||||||
sh 'rsync -avP bkctld* droneci@pub.evolix.net:/home/droneci/bkctld/'
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
35
.drone.yml
35
.drone.yml
|
@ -1,35 +0,0 @@
|
||||||
kind: pipeline
|
|
||||||
name: default
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: fetch
|
|
||||||
image: alpine/git
|
|
||||||
commands:
|
|
||||||
- git fetch --tags
|
|
||||||
|
|
||||||
- name: build debian package
|
|
||||||
image: evolix/gbp:bullseye
|
|
||||||
branches:
|
|
||||||
- debian
|
|
||||||
commands:
|
|
||||||
- mk-build-deps --install --remove debian/control
|
|
||||||
- git clean --force
|
|
||||||
- gbp buildpackage -us -uc
|
|
||||||
when:
|
|
||||||
branch:
|
|
||||||
- debian
|
|
||||||
|
|
||||||
- name: upload debian package
|
|
||||||
image: drillster/drone-rsync
|
|
||||||
settings:
|
|
||||||
hosts: ["pub.evolix.net"]
|
|
||||||
port: 22
|
|
||||||
user: droneci
|
|
||||||
key:
|
|
||||||
from_secret: drone_private_key
|
|
||||||
target: /home/droneci/bkctld/
|
|
||||||
source: ../bkctld*
|
|
||||||
delete: true
|
|
||||||
when:
|
|
||||||
branch:
|
|
||||||
- debian
|
|
|
@ -10,6 +10,17 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
|
### Deprecated
|
||||||
|
|
||||||
|
### Removed
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
### Security
|
||||||
|
|
||||||
|
## [22.12]
|
||||||
|
### Changed
|
||||||
|
|
||||||
* Use --dump-dir instead of --backup-dir to suppress dump-server-state warning
|
* Use --dump-dir instead of --backup-dir to suppress dump-server-state warning
|
||||||
* Do not use rsync compression
|
* Do not use rsync compression
|
||||||
* Replace rsync option --verbose by --itemize-changes
|
* Replace rsync option --verbose by --itemize-changes
|
||||||
|
@ -18,17 +29,19 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
* Add AGPL License and README
|
* Add AGPL License and README
|
||||||
* Script now depends on Bash
|
* Script now depends on Bash
|
||||||
* tolerate absence of mtr or traceroute
|
* tolerate absence of mtr or traceroute
|
||||||
|
* Only one loop for all Redis instances
|
||||||
### Deprecated
|
* remodel how we build the rsync command
|
||||||
|
* use sub shells instead of moving around
|
||||||
|
* Separate Rsync for the canary file if the main Rsync has finished without errors
|
||||||
|
|
||||||
### Removed
|
### Removed
|
||||||
|
|
||||||
|
* No more fallback if dump-server-state is missing
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
* Make start_time and stop_time compatible with OpenBSD
|
* Make start_time and stop_time compatible with OpenBSD
|
||||||
|
|
||||||
### Security
|
|
||||||
|
|
||||||
## [22.03]
|
## [22.03]
|
||||||
|
|
||||||
Split client and server parts of the project
|
Split client and server parts of the project
|
||||||
|
|
|
@ -1,3 +1,3 @@
|
||||||
Pour l'installation de `zzz_evobackup`, voir <https://intra.evolix.net/Installation_jail_backup_Evolix#installation-du-client-evobackup>
|
Pour l'installation de `zzz_evobackup`, voir <https://intra.evolix.net/OutilsInternes/EvoBackupClient#installer-et-configurer-le-client-evobackup>
|
||||||
|
|
||||||
Pour `update-evobackup-canary`, voir <https://intra.evolix.net/OutilsInternes/update-evobackup-canary>
|
Pour `update-evobackup-canary`, voir <https://intra.evolix.net/OutilsInternes/update-evobackup-canary>
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
|
|
||||||
##### Configuration ###################################################
|
##### Configuration ###################################################
|
||||||
|
|
||||||
VERSION="22.05"
|
VERSION="22.12"
|
||||||
|
|
||||||
# email adress for notifications
|
# email adress for notifications
|
||||||
MAIL=jdoe@example.com
|
MAIL=jdoe@example.com
|
||||||
|
@ -48,6 +48,9 @@ PIDFILE="/var/run/${PROGNAME}.pid"
|
||||||
# Customize the log path if you have multiple scripts and with separate logs
|
# Customize the log path if you have multiple scripts and with separate logs
|
||||||
LOGFILE="/var/log/evobackup.log"
|
LOGFILE="/var/log/evobackup.log"
|
||||||
|
|
||||||
|
# Full Rsync log file, reset each time
|
||||||
|
RSYNC_LOGFILE="/var/log/${PROGNAME}.rsync.log"
|
||||||
|
|
||||||
HOSTNAME=$(hostname)
|
HOSTNAME=$(hostname)
|
||||||
|
|
||||||
DATE_FORMAT="%Y-%m-%d %H:%M:%S"
|
DATE_FORMAT="%Y-%m-%d %H:%M:%S"
|
||||||
|
@ -57,7 +60,77 @@ DATE_FORMAT="%Y-%m-%d %H:%M:%S"
|
||||||
# Enable/disable sync tasks (default: enabled)
|
# Enable/disable sync tasks (default: enabled)
|
||||||
: "${SYNC_TASKS:=1}"
|
: "${SYNC_TASKS:=1}"
|
||||||
|
|
||||||
##### SETUP AND FUNCTIONS #############################################
|
CANARY_FILE="/zzz_evobackup_canary"
|
||||||
|
|
||||||
|
# Source paths can be customized
|
||||||
|
# Empty lines, and lines containing # or ; are ignored
|
||||||
|
# NOTE: remember to single-quote paths if they contain globs (*)
|
||||||
|
# and you want to defer expansion
|
||||||
|
RSYNC_INCLUDES="
|
||||||
|
/etc
|
||||||
|
/root
|
||||||
|
/var
|
||||||
|
/home
|
||||||
|
"
|
||||||
|
|
||||||
|
# Excluded paths can be customized
|
||||||
|
# Empty lines, and lines beginning with # or ; are ignored
|
||||||
|
# NOTE: remember to single-quote paths if they contain globs (*)
|
||||||
|
# and you want to defer expansion
|
||||||
|
RSYNC_EXCLUDES="
|
||||||
|
/dev
|
||||||
|
/proc
|
||||||
|
/run
|
||||||
|
/sys
|
||||||
|
/tmp
|
||||||
|
/usr/doc
|
||||||
|
/usr/obj
|
||||||
|
/usr/share/doc
|
||||||
|
/usr/src
|
||||||
|
/var/apt
|
||||||
|
/var/cache
|
||||||
|
'/var/db/munin/*.tmp'
|
||||||
|
/var/lib/amavis/amavisd.sock
|
||||||
|
/var/lib/amavis/tmp
|
||||||
|
/var/lib/amavis/virusmails
|
||||||
|
'/var/lib/clamav/*.tmp'
|
||||||
|
/var/lib/elasticsearch
|
||||||
|
/var/lib/metche
|
||||||
|
/var/lib/mongodb
|
||||||
|
'/var/lib/munin/*tmp*'
|
||||||
|
/var/lib/mysql
|
||||||
|
/var/lib/php/sessions
|
||||||
|
/var/lib/php5
|
||||||
|
/var/lib/postgres
|
||||||
|
/var/lib/postgresql
|
||||||
|
/var/lib/sympa
|
||||||
|
/var/lock
|
||||||
|
/var/run
|
||||||
|
/var/spool/postfix
|
||||||
|
/var/spool/smtpd
|
||||||
|
/var/spool/squid
|
||||||
|
/var/state
|
||||||
|
/var/tmp
|
||||||
|
lost+found
|
||||||
|
'.nfs.*'
|
||||||
|
'lxc/*/rootfs/tmp'
|
||||||
|
'lxc/*/rootfs/usr/doc'
|
||||||
|
'lxc/*/rootfs/usr/obj'
|
||||||
|
'lxc/*/rootfs/usr/share/doc'
|
||||||
|
'lxc/*/rootfs/usr/src'
|
||||||
|
'lxc/*/rootfs/var/apt'
|
||||||
|
'lxc/*/rootfs/var/cache'
|
||||||
|
'lxc/*/rootfs/var/lib/php5'
|
||||||
|
'lxc/*/rootfs/var/lib/php/sessions'
|
||||||
|
'lxc/*/rootfs/var/lock'
|
||||||
|
'lxc/*/rootfs/var/run'
|
||||||
|
'lxc/*/rootfs/var/state'
|
||||||
|
'lxc/*/rootfs/var/tmp'
|
||||||
|
/home/mysqltmp
|
||||||
|
"
|
||||||
|
|
||||||
|
|
||||||
|
##### FUNCTIONS #######################################################
|
||||||
|
|
||||||
local_tasks() {
|
local_tasks() {
|
||||||
log "START LOCAL_TASKS"
|
log "START LOCAL_TASKS"
|
||||||
|
@ -76,7 +149,7 @@ local_tasks() {
|
||||||
# rm -rf ${LOCAL_BACKUP_DIR}/mysql
|
# rm -rf ${LOCAL_BACKUP_DIR}/mysql
|
||||||
# rm -rf ${LOCAL_BACKUP_DIR}/mysqlhotcopy
|
# rm -rf ${LOCAL_BACKUP_DIR}/mysqlhotcopy
|
||||||
# rm -rf /home/mysqldump
|
# rm -rf /home/mysqldump
|
||||||
# rm -f ${LOCAL_BACKUP_DIR}/*.err ${LOCAL_BACKUP_DIR}/**/*.err
|
# find ${LOCAL_BACKUP_DIR}/ -type f -name '*.err' -delete
|
||||||
|
|
||||||
## example with global and compressed mysqldump
|
## example with global and compressed mysqldump
|
||||||
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 \
|
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 \
|
||||||
|
@ -90,7 +163,7 @@ local_tasks() {
|
||||||
## example with compressed SQL dump (with data) for each databases
|
## example with compressed SQL dump (with data) for each databases
|
||||||
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/mysql/
|
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/mysql/
|
||||||
# for i in $(mysql --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 -e 'show databases' -s --skip-column-names \
|
# for i in $(mysql --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 -e 'show databases' -s --skip-column-names \
|
||||||
# | egrep -v "^(Database|information_schema|performance_schema|sys)"); do
|
# | grep --extended-regexp --invert-match "^(Database|information_schema|performance_schema|sys)"); do
|
||||||
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf --force -P 3306 --events --hex-blob $i 2> ${LOCAL_BACKUP_DIR}/${i}.err | gzip --best > ${LOCAL_BACKUP_DIR}/mysql/${i}.sql.gz
|
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf --force -P 3306 --events --hex-blob $i 2> ${LOCAL_BACKUP_DIR}/${i}.err | gzip --best > ${LOCAL_BACKUP_DIR}/mysql/${i}.sql.gz
|
||||||
# last_rc=$?
|
# last_rc=$?
|
||||||
# if [ ${last_rc} -ne 0 ]; then
|
# if [ ${last_rc} -ne 0 ]; then
|
||||||
|
@ -119,7 +192,7 @@ local_tasks() {
|
||||||
## example with SQL dump (schema only, no data) for each databases
|
## example with SQL dump (schema only, no data) for each databases
|
||||||
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/mysql/
|
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/mysql/
|
||||||
# for i in $(mysql --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 -e 'show databases' -s --skip-column-names \
|
# for i in $(mysql --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 -e 'show databases' -s --skip-column-names \
|
||||||
# | egrep -v "^(Database|information_schema|performance_schema|sys)"); do
|
# | grep --extended-regexp --invert-match "^(Database|information_schema|performance_schema|sys)"); do
|
||||||
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf --force -P 3306 --no-data --databases $i 2> ${LOCAL_BACKUP_DIR}/${i}.schema.err > ${LOCAL_BACKUP_DIR}/mysql/${i}.schema.sql
|
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf --force -P 3306 --no-data --databases $i 2> ${LOCAL_BACKUP_DIR}/${i}.schema.err > ${LOCAL_BACKUP_DIR}/mysql/${i}.schema.sql
|
||||||
# last_rc=$?
|
# last_rc=$?
|
||||||
# if [ ${last_rc} -ne 0 ]; then
|
# if [ ${last_rc} -ne 0 ]; then
|
||||||
|
@ -141,7 +214,7 @@ local_tasks() {
|
||||||
|
|
||||||
## example with two dumps for each table (.sql/.txt) for all databases
|
## example with two dumps for each table (.sql/.txt) for all databases
|
||||||
# for i in $(echo SHOW DATABASES | mysql --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 \
|
# for i in $(echo SHOW DATABASES | mysql --defaults-extra-file=/etc/mysql/debian.cnf -P 3306 \
|
||||||
# | egrep -v "^(Database|information_schema|performance_schema|sys)" ); do
|
# | grep --extended-regexp --invert-match "^(Database|information_schema|performance_schema|sys)" ); do
|
||||||
# mkdir -p -m 700 /home/mysqldump/$i ; chown -RL mysql /home/mysqldump
|
# mkdir -p -m 700 /home/mysqldump/$i ; chown -RL mysql /home/mysqldump
|
||||||
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf --force -P 3306 -Q --opt --events --hex-blob --skip-comments \
|
# mysqldump --defaults-extra-file=/etc/mysql/debian.cnf --force -P 3306 -Q --opt --events --hex-blob --skip-comments \
|
||||||
# --fields-enclosed-by='\"' --fields-terminated-by=',' -T /home/mysqldump/$i $i 2> /home/mysqldump/$i.err"
|
# --fields-enclosed-by='\"' --fields-terminated-by=',' -T /home/mysqldump/$i $i 2> /home/mysqldump/$i.err"
|
||||||
|
@ -163,7 +236,7 @@ local_tasks() {
|
||||||
|
|
||||||
## example for multiples MySQL instances
|
## example for multiples MySQL instances
|
||||||
# mysqladminpasswd=$(grep -m1 'password = .*' /root/.my.cnf|cut -d" " -f3)
|
# mysqladminpasswd=$(grep -m1 'password = .*' /root/.my.cnf|cut -d" " -f3)
|
||||||
# grep -E "^port\s*=\s*\d*" /etc/mysql/my.cnf |while read instance; do
|
# grep --extended-regexp "^port\s*=\s*\d*" /etc/mysql/my.cnf | while read instance; do
|
||||||
# instance=$(echo "$instance"|awk '{ print $3 }')
|
# instance=$(echo "$instance"|awk '{ print $3 }')
|
||||||
# if [ "$instance" != "3306" ]
|
# if [ "$instance" != "3306" ]
|
||||||
# then
|
# then
|
||||||
|
@ -188,9 +261,10 @@ local_tasks() {
|
||||||
# mv ~postgres/pg.dump.bak ${LOCAL_BACKUP_DIR}/
|
# mv ~postgres/pg.dump.bak ${LOCAL_BACKUP_DIR}/
|
||||||
|
|
||||||
## another method with gzip directly piped
|
## another method with gzip directly piped
|
||||||
# cd /var/lib/postgresql
|
# (
|
||||||
# sudo -u postgres pg_dumpall | gzip > ${LOCAL_BACKUP_DIR}/pg.dump.bak.gz
|
# cd /var/lib/postgresql;
|
||||||
# cd - > /dev/null
|
# sudo -u postgres pg_dumpall | gzip > ${LOCAL_BACKUP_DIR}/pg.dump.bak.gz
|
||||||
|
# )
|
||||||
|
|
||||||
## example with all tables from MYBASE excepts TABLE1 and TABLE2
|
## example with all tables from MYBASE excepts TABLE1 and TABLE2
|
||||||
# pg_dump -p 5432 -h 127.0.0.1 -U USER --clean -F t --inserts -f ${LOCAL_BACKUP_DIR}/pg-backup.tar -t 'TABLE1' -t 'TABLE2' MYBASE
|
# pg_dump -p 5432 -h 127.0.0.1 -U USER --clean -F t --inserts -f ${LOCAL_BACKUP_DIR}/pg-backup.tar -t 'TABLE1' -t 'TABLE2' MYBASE
|
||||||
|
@ -201,10 +275,11 @@ local_tasks() {
|
||||||
## example with compressed PostgreSQL dump for each databases
|
## example with compressed PostgreSQL dump for each databases
|
||||||
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/postgresql
|
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/postgresql
|
||||||
# chown postgres:postgres ${LOCAL_BACKUP_DIR}/postgresql
|
# chown postgres:postgres ${LOCAL_BACKUP_DIR}/postgresql
|
||||||
# cd /var/lib/postgresql
|
# (
|
||||||
# dbs=$(sudo -u postgres psql -U postgres -lt | awk -F\| '{print $1}' |grep -v template*)
|
# cd /var/lib/postgresql
|
||||||
# for databases in $dbs ; do sudo -u postgres /usr/bin/pg_dump --create -s -U postgres -d $databases | gzip --best -c > ${LOCAL_BACKUP_DIR}/postgresql/$databases.sql.gz ; done
|
# dbs=$(sudo -u postgres psql -U postgres -lt | awk -F\| '{print $1}' |grep -v template*)
|
||||||
# cd - > /dev/null
|
# for databases in $dbs ; do sudo -u postgres /usr/bin/pg_dump --create -U postgres -d $databases | gzip --best -c > ${LOCAL_BACKUP_DIR}/postgresql/$databases.sql.gz ; done
|
||||||
|
# )
|
||||||
|
|
||||||
## MongoDB
|
## MongoDB
|
||||||
|
|
||||||
|
@ -224,15 +299,14 @@ local_tasks() {
|
||||||
## Purge previous dumps
|
## Purge previous dumps
|
||||||
# rm -rf ${LOCAL_BACKUP_DIR}/redis/
|
# rm -rf ${LOCAL_BACKUP_DIR}/redis/
|
||||||
# rm -rf ${LOCAL_BACKUP_DIR}/redis-*
|
# rm -rf ${LOCAL_BACKUP_DIR}/redis-*
|
||||||
## example with copy .rdb file
|
## Copy dump.rdb file for each found instance
|
||||||
## for the default instance :
|
# for instance in $(find /var/lib/ -mindepth 1 -maxdepth 1 '(' -type d -o -type l ')' -name 'redis*'); do
|
||||||
# mkdir -p -m 700 ${LOCAL_BACKUP_DIR}/redis/
|
# if [ -f "${instance}/dump.rdb" ]; then
|
||||||
# cp /var/lib/redis/dump.rdb ${LOCAL_BACKUP_DIR}/redis/
|
# name=$(basename $instance)
|
||||||
## for multiple instances :
|
# mkdir -p ${LOCAL_BACKUP_DIR}/${name}
|
||||||
# for instance in $(ls -d /var/lib/redis-*); do
|
# cp -a "${instance}/dump.rdb" "${LOCAL_BACKUP_DIR}/${name}"
|
||||||
# name=$(basename $instance)
|
# gzip "${LOCAL_BACKUP_DIR}/${name}/dump.rdb"
|
||||||
# mkdir -p ${LOCAL_BACKUP_DIR}/${name}
|
# fi
|
||||||
# cp -a ${instance}/dump.rdb ${LOCAL_BACKUP_DIR}/${name}
|
|
||||||
# done
|
# done
|
||||||
|
|
||||||
## ElasticSearch
|
## ElasticSearch
|
||||||
|
@ -251,7 +325,7 @@ local_tasks() {
|
||||||
# else
|
# else
|
||||||
# echo 'Cannot make a snapshot of elasticsearch, at least one node is not mounting the repository.'
|
# echo 'Cannot make a snapshot of elasticsearch, at least one node is not mounting the repository.'
|
||||||
# fi
|
# fi
|
||||||
## If you need to keep older snapshot, for example the last 10 daily snapshots, replace the XDELETE and XPUT lines by :
|
## If you need to keep older snapshot, for example the last 10 daily snapshots, replace the XDELETE and XPUT lines by :
|
||||||
# for snapshot in $(curl -s -XGET "localhost:9200/_snapshot/snaprepo/_all?pretty=true" | grep -Eo 'snapshot_[0-9]{4}-[0-9]{2}-[0-9]{2}' | head -n -10); do
|
# for snapshot in $(curl -s -XGET "localhost:9200/_snapshot/snaprepo/_all?pretty=true" | grep -Eo 'snapshot_[0-9]{4}-[0-9]{2}-[0-9]{2}' | head -n -10); do
|
||||||
# curl -s -XDELETE "localhost:9200/_snapshot/snaprepo/${snapshot}" | grep -v -Fx '{"acknowledged":true}'
|
# curl -s -XDELETE "localhost:9200/_snapshot/snaprepo/${snapshot}" | grep -v -Fx '{"acknowledged":true}'
|
||||||
# done
|
# done
|
||||||
|
@ -261,11 +335,11 @@ local_tasks() {
|
||||||
## RabbitMQ
|
## RabbitMQ
|
||||||
|
|
||||||
## export config
|
## export config
|
||||||
#rabbitmqadmin export ${LOCAL_BACKUP_DIR}/rabbitmq.config >> "${LOGFILE}"
|
# rabbitmqadmin export ${LOCAL_BACKUP_DIR}/rabbitmq.config >> "${LOGFILE}"
|
||||||
|
|
||||||
## MegaCli config
|
## MegaCli config
|
||||||
|
|
||||||
#megacli -CfgSave -f ${LOCAL_BACKUP_DIR}/megacli_conf.dump -a0 >/dev/null
|
# megacli -CfgSave -f ${LOCAL_BACKUP_DIR}/megacli_conf.dump -a0 >/dev/null
|
||||||
|
|
||||||
## Dump network routes with mtr and traceroute (warning: could be long with aggressive firewalls)
|
## Dump network routes with mtr and traceroute (warning: could be long with aggressive firewalls)
|
||||||
network_targets="8.8.8.8 www.evolix.fr travaux.evolix.net"
|
network_targets="8.8.8.8 www.evolix.fr travaux.evolix.net"
|
||||||
|
@ -285,53 +359,11 @@ local_tasks() {
|
||||||
server_state_dir="${LOCAL_BACKUP_DIR}/server-state"
|
server_state_dir="${LOCAL_BACKUP_DIR}/server-state"
|
||||||
|
|
||||||
dump_server_state_bin=$(command -v dump-server-state)
|
dump_server_state_bin=$(command -v dump-server-state)
|
||||||
|
if [ -z "${dump_server_state_bin}" ]; then
|
||||||
if [ "${SYSTEM}" = "linux" ]; then
|
error "dump-server-state is missing"
|
||||||
if [ -n "${dump_server_state_bin}" ]; then
|
rc=1
|
||||||
${dump_server_state_bin} --all --force --dump-dir "${server_state_dir}"
|
|
||||||
last_rc=$?
|
|
||||||
if [ ${last_rc} -ne 0 ]; then
|
|
||||||
error "dump-server-state returned an error ${last_rc}, check ${server_state_dir}"
|
|
||||||
rc=1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
mkdir -p "${server_state_dir}"
|
|
||||||
|
|
||||||
## Dump system and kernel versions
|
|
||||||
uname -a > ${server_state_dir}/uname.txt
|
|
||||||
|
|
||||||
## Dump process with ps
|
|
||||||
ps auwwx > ${server_state_dir}/ps.txt
|
|
||||||
|
|
||||||
## Dump network connections with ss
|
|
||||||
ss -taupen > ${server_state_dir}/netstat.txt
|
|
||||||
|
|
||||||
## List Debian packages
|
|
||||||
dpkg -l > ${server_state_dir}/packages
|
|
||||||
dpkg --get-selections > ${server_state_dir}/packages.getselections
|
|
||||||
apt-cache dumpavail > ${server_state_dir}/packages.available
|
|
||||||
|
|
||||||
## Dump iptables
|
|
||||||
if [ -x /sbin/iptables ]; then
|
|
||||||
{ /sbin/iptables -L -n -v; /sbin/iptables -t filter -L -n -v; } > ${server_state_dir}/iptables.txt
|
|
||||||
fi
|
|
||||||
|
|
||||||
## Dump findmnt(8) output
|
|
||||||
FINDMNT_BIN=$(command -v findmnt)
|
|
||||||
if [ -x "${FINDMNT_BIN}" ]; then
|
|
||||||
${FINDMNT_BIN} > ${server_state_dir}/findmnt.txt
|
|
||||||
fi
|
|
||||||
|
|
||||||
## Dump MBR / table partitions
|
|
||||||
disks=$(lsblk -l | grep disk | grep -v -E '(drbd|fd[0-9]+)' | awk '{print $1}')
|
|
||||||
for disk in ${disks}; do
|
|
||||||
dd if="/dev/${disk}" of="${server_state_dir}/MBR-${disk}" bs=512 count=1 2>&1 | grep -Ev "(records in|records out|512 bytes)"
|
|
||||||
fdisk -l "/dev/${disk}" > "${server_state_dir}/partitions-${disk}" 2>&1
|
|
||||||
done
|
|
||||||
cat ${server_state_dir}/partitions-* > ${server_state_dir}/partitions
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
if [ -n "${dump_server_state_bin}" ]; then
|
if [ "${SYSTEM}" = "linux" ]; then
|
||||||
${dump_server_state_bin} --all --force --dump-dir "${server_state_dir}"
|
${dump_server_state_bin} --all --force --dump-dir "${server_state_dir}"
|
||||||
last_rc=$?
|
last_rc=$?
|
||||||
if [ ${last_rc} -ne 0 ]; then
|
if [ ${last_rc} -ne 0 ]; then
|
||||||
|
@ -339,37 +371,93 @@ local_tasks() {
|
||||||
rc=1
|
rc=1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
mkdir -p "${server_state_dir}"
|
${dump_server_state_bin} --all --force --dump-dir "${server_state_dir}"
|
||||||
|
last_rc=$?
|
||||||
## Dump system and kernel versions
|
if [ ${last_rc} -ne 0 ]; then
|
||||||
uname -a > ${server_state_dir}/uname
|
error "dump-server-state returned an error ${last_rc}, check ${server_state_dir}"
|
||||||
|
rc=1
|
||||||
## Dump process with ps
|
fi
|
||||||
ps auwwx > ${server_state_dir}/ps.out
|
|
||||||
|
|
||||||
## Dump network connections with fstat
|
|
||||||
fstat | head -1 > ${server_state_dir}/netstat.out
|
|
||||||
fstat | grep internet >> ${server_state_dir}/netstat.out
|
|
||||||
|
|
||||||
## List OpenBSD packages
|
|
||||||
pkg_info -m > ${server_state_dir}/packages
|
|
||||||
|
|
||||||
## Dump MBR / table partitions
|
|
||||||
disklabel sd0 > ${server_state_dir}/partitions
|
|
||||||
|
|
||||||
## Dump pf infos
|
|
||||||
pfctl -sa > ${server_state_dir}/pfctl-sa.txt
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
## Dump rights
|
## Dump rights
|
||||||
#getfacl -R /var > ${server_state_dir}/rights-var.txt
|
# getfacl -R /var > ${server_state_dir}/rights-var.txt
|
||||||
#getfacl -R /etc > ${server_state_dir}/rights-etc.txt
|
# getfacl -R /etc > ${server_state_dir}/rights-etc.txt
|
||||||
#getfacl -R /usr > ${server_state_dir}/rights-usr.txt
|
# getfacl -R /usr > ${server_state_dir}/rights-usr.txt
|
||||||
#getfacl -R /home > ${server_state_dir}/rights-home.txt
|
# getfacl -R /home > ${server_state_dir}/rights-home.txt
|
||||||
|
|
||||||
log "STOP LOCAL_TASKS"
|
log "STOP LOCAL_TASKS"
|
||||||
}
|
}
|
||||||
|
build_rsync_main_cmd() {
|
||||||
|
###################################################################
|
||||||
|
# /!\ WARNING /!\ WARNING /!\ WARNING /!\ WARNING /!\ WARNING /!\ #
|
||||||
|
###################################################################
|
||||||
|
# DO NOT USE COMMENTS in rsync lines #
|
||||||
|
# DO NOT ADD WHITESPACES AFTER \ in rsync lines #
|
||||||
|
# It breaks the command and destroys data #
|
||||||
|
# You should not modify this, unless you are really REALLY sure #
|
||||||
|
###################################################################
|
||||||
|
|
||||||
|
# Create a temp file for excludes and includes
|
||||||
|
includes_file="$(mktemp --tmpdir "${PROGNAME}.includes.XXXXXX")"
|
||||||
|
excludes_file="$(mktemp --tmpdir "${PROGNAME}.excludes.XXXXXX")"
|
||||||
|
# … and add them to the list of files to delete at exit
|
||||||
|
temp_files="${includes_file} ${excludes_file}"
|
||||||
|
trap "rm -f ${temp_files}" EXIT
|
||||||
|
|
||||||
|
# Store includes/excludes in files
|
||||||
|
# without blank lines of comments (# or ;)
|
||||||
|
echo "${RSYNC_INCLUDES}" | sed -e 's/\s*\(#\|;\).*//; /^\s*$/d' > "${includes_file}"
|
||||||
|
echo "${RSYNC_EXCLUDES}" | sed -e 's/\s*\(#\|;\).*//; /^\s*$/d' > "${excludes_file}"
|
||||||
|
|
||||||
|
# Rsync command
|
||||||
|
cmd="$(command -v rsync)"
|
||||||
|
|
||||||
|
# Rsync main options
|
||||||
|
cmd="${cmd} --archive"
|
||||||
|
cmd="${cmd} --itemize-changes"
|
||||||
|
cmd="${cmd} --quiet"
|
||||||
|
cmd="${cmd} --stats"
|
||||||
|
cmd="${cmd} --human-readable"
|
||||||
|
cmd="${cmd} --relative"
|
||||||
|
cmd="${cmd} --partial"
|
||||||
|
cmd="${cmd} --delete"
|
||||||
|
cmd="${cmd} --delete-excluded"
|
||||||
|
cmd="${cmd} --force"
|
||||||
|
cmd="${cmd} --ignore-errors"
|
||||||
|
cmd="${cmd} --log-file=${RSYNC_LOGFILE}"
|
||||||
|
cmd="${cmd} --rsh='ssh -p ${SSH_PORT} -o \"ConnectTimeout ${SSH_CONNECT_TIMEOUT}\"'"
|
||||||
|
|
||||||
|
# Rsync excludes
|
||||||
|
while read line ; do
|
||||||
|
cmd="${cmd} --exclude ${line}"
|
||||||
|
done < "${excludes_file}"
|
||||||
|
|
||||||
|
# Rsync local sources
|
||||||
|
cmd="${cmd} ${default_includes}"
|
||||||
|
while read line ; do
|
||||||
|
cmd="${cmd} ${line}"
|
||||||
|
done < "${includes_file}"
|
||||||
|
|
||||||
|
# Rsync remote destination
|
||||||
|
cmd="${cmd} root@${SSH_SERVER}:/var/backup/"
|
||||||
|
|
||||||
|
# output final command
|
||||||
|
echo "${cmd}"
|
||||||
|
}
|
||||||
|
build_rsync_canary_cmd() {
|
||||||
|
# Rsync command
|
||||||
|
cmd="$(command -v rsync)"
|
||||||
|
# Rsync options
|
||||||
|
cmd="${cmd} --rsh='ssh -p ${SSH_PORT} -o \"ConnectTimeout ${SSH_CONNECT_TIMEOUT}\"'"
|
||||||
|
# Rsync local source
|
||||||
|
cmd="${cmd} ${CANARY_FILE}"
|
||||||
|
# Rsync remote destination
|
||||||
|
cmd="${cmd} root@${SSH_SERVER}:/var/backup/"
|
||||||
|
|
||||||
|
# output final command
|
||||||
|
echo "${cmd}"
|
||||||
|
}
|
||||||
sync_tasks() {
|
sync_tasks() {
|
||||||
n=0
|
n=0
|
||||||
server=""
|
server=""
|
||||||
|
@ -394,93 +482,48 @@ sync_tasks() {
|
||||||
SSH_SERVER=$(echo "${server}" | cut -d':' -f1)
|
SSH_SERVER=$(echo "${server}" | cut -d':' -f1)
|
||||||
SSH_PORT=$(echo "${server}" | cut -d':' -f2)
|
SSH_PORT=$(echo "${server}" | cut -d':' -f2)
|
||||||
|
|
||||||
if [ "${SYSTEM}" = "linux" ]; then
|
|
||||||
rep="/bin /boot /lib /opt /sbin /usr"
|
|
||||||
else
|
|
||||||
rep="/bsd /bin /sbin /usr"
|
|
||||||
fi
|
|
||||||
|
|
||||||
log "START SYNC_TASKS - server=${server}"
|
log "START SYNC_TASKS - server=${server}"
|
||||||
|
|
||||||
update-evobackup-canary --who "${PROGNAME}"
|
# default paths, depending on system
|
||||||
|
if [ "${SYSTEM}" = "linux" ]; then
|
||||||
|
default_includes="/bin /boot /lib /opt /sbin /usr"
|
||||||
|
else
|
||||||
|
default_includes="/bsd /bin /sbin /usr"
|
||||||
|
fi
|
||||||
|
|
||||||
# Remote shell command
|
# reset Rsync log file
|
||||||
RSH_COMMAND="ssh -p ${SSH_PORT} -o 'ConnectTimeout ${SSH_CONNECT_TIMEOUT}'"
|
if [ -n "$(command -v truncate)" ]; then
|
||||||
|
truncate -s 0 "${RSYNC_LOGFILE}"
|
||||||
|
else
|
||||||
|
printf "" > "${RSYNC_LOGFILE}"
|
||||||
|
fi
|
||||||
|
|
||||||
###################################################################
|
# Build the final Rsync command
|
||||||
# /!\ WARNING /!\ WARNING /!\ WARNING /!\ WARNING /!\ WARNING /!\ #
|
rsync_main_cmd=$(build_rsync_main_cmd)
|
||||||
###################################################################
|
|
||||||
# DO NOT USE COMMENTS in rsync lines #
|
|
||||||
# DO NOT ADD WHITESPACES AFTER \ in rsync lines #
|
|
||||||
# It breaks the command and destroys data #
|
|
||||||
# => Only remove (or add) lines. #
|
|
||||||
###################################################################
|
|
||||||
|
|
||||||
# ignore check because we want it to split the different arguments to $rep
|
# … log it
|
||||||
# shellcheck disable=SC2086
|
log "SYNC_TASKS - Rsync main command : ${rsync_main_cmd}"
|
||||||
rsync --archive \
|
|
||||||
--itemize-changes --stats --human-readable \
|
|
||||||
--relative --partial \
|
|
||||||
--delete --delete-excluded --force --ignore-errors \
|
|
||||||
--exclude "dev" \
|
|
||||||
--exclude "lost+found" \
|
|
||||||
--exclude ".nfs.*" \
|
|
||||||
--exclude "/usr/doc" \
|
|
||||||
--exclude "/usr/obj" \
|
|
||||||
--exclude "/usr/share/doc" \
|
|
||||||
--exclude "/usr/src" \
|
|
||||||
--exclude "/var/apt" \
|
|
||||||
--exclude "/var/cache" \
|
|
||||||
--exclude "/var/lib/amavis/amavisd.sock" \
|
|
||||||
--exclude "/var/lib/amavis/tmp" \
|
|
||||||
--exclude "/var/lib/clamav/*.tmp" \
|
|
||||||
--exclude "/var/lib/elasticsearch" \
|
|
||||||
--exclude "/var/lib/metche" \
|
|
||||||
--exclude "/var/lib/munin/*tmp*" \
|
|
||||||
--exclude "/var/db/munin/*.tmp" \
|
|
||||||
--exclude "/var/lib/mongodb" \
|
|
||||||
--exclude "/var/lib/mysql" \
|
|
||||||
--exclude "/var/lib/php5" \
|
|
||||||
--exclude "/var/lib/php/sessions" \
|
|
||||||
--exclude "/var/lib/postgres" \
|
|
||||||
--exclude "/var/lib/postgresql" \
|
|
||||||
--exclude "/var/lib/sympa" \
|
|
||||||
--exclude "/var/lock" \
|
|
||||||
--exclude "/var/run" \
|
|
||||||
--exclude "/var/spool/postfix" \
|
|
||||||
--exclude "/var/spool/smtpd" \
|
|
||||||
--exclude "/var/spool/squid" \
|
|
||||||
--exclude "/var/state" \
|
|
||||||
--exclude "/var/tmp" \
|
|
||||||
--exclude "lxc/*/rootfs/tmp" \
|
|
||||||
--exclude "lxc/*/rootfs/usr/doc" \
|
|
||||||
--exclude "lxc/*/rootfs/usr/obj" \
|
|
||||||
--exclude "lxc/*/rootfs/usr/share/doc" \
|
|
||||||
--exclude "lxc/*/rootfs/usr/src" \
|
|
||||||
--exclude "lxc/*/rootfs/var/apt" \
|
|
||||||
--exclude "lxc/*/rootfs/var/cache" \
|
|
||||||
--exclude "lxc/*/rootfs/var/lib/php5" \
|
|
||||||
--exclude "lxc/*/rootfs/var/lib/php/sessions" \
|
|
||||||
--exclude "lxc/*/rootfs/var/lock" \
|
|
||||||
--exclude "lxc/*/rootfs/var/log" \
|
|
||||||
--exclude "lxc/*/rootfs/var/run" \
|
|
||||||
--exclude "lxc/*/rootfs/var/state" \
|
|
||||||
--exclude "lxc/*/rootfs/var/tmp" \
|
|
||||||
--exclude "/home/mysqltmp" \
|
|
||||||
${rep} \
|
|
||||||
/etc \
|
|
||||||
/root \
|
|
||||||
/var \
|
|
||||||
/home \
|
|
||||||
/zzz_evobackup_canary \
|
|
||||||
-e "${RSH_COMMAND}" \
|
|
||||||
"root@${SSH_SERVER}:/var/backup/" \
|
|
||||||
| tail -30 >> "${LOGFILE}"
|
|
||||||
|
|
||||||
rsync_rc=$?
|
# … execute it
|
||||||
if [ ${rsync_rc} -ne 0 ]; then
|
eval "${rsync_main_cmd}"
|
||||||
error "rsync returned an error ${rsync_rc}, check ${LOGFILE}"
|
|
||||||
|
rsync_main_rc=$?
|
||||||
|
|
||||||
|
# Copy last lines of rsync log to the main log
|
||||||
|
tail -n 30 "${RSYNC_LOGFILE}" >> "${LOGFILE}"
|
||||||
|
|
||||||
|
if [ ${rsync_main_rc} -ne 0 ]; then
|
||||||
|
error "rsync returned an error ${rsync_main_rc}, check ${LOGFILE}"
|
||||||
rc=201
|
rc=201
|
||||||
|
else
|
||||||
|
# Build the canary Rsync command
|
||||||
|
rsync_canary_cmd=$(build_rsync_canary_cmd)
|
||||||
|
|
||||||
|
# … log it
|
||||||
|
log "SYNC_TASKS - Rsync canary command : ${rsync_canary_cmd}"
|
||||||
|
|
||||||
|
# … execute it
|
||||||
|
eval "${rsync_canary_cmd}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log "STOP SYNC_TASKS - server=${server}"
|
log "STOP SYNC_TASKS - server=${server}"
|
||||||
|
@ -584,8 +627,16 @@ main() {
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
echo "$$" > "${PIDFILE}"
|
echo "$$" > "${PIDFILE}"
|
||||||
|
|
||||||
|
# Initialize a list of files to delete at exit
|
||||||
|
# Any file added to the list will also be deleted at exit
|
||||||
|
temp_files="${PIDFILE}"
|
||||||
|
|
||||||
# shellcheck disable=SC2064
|
# shellcheck disable=SC2064
|
||||||
trap "rm -f ${PIDFILE}" EXIT
|
trap "rm -f ${temp_files}" EXIT
|
||||||
|
|
||||||
|
# Update canary to keep track of each run
|
||||||
|
update-evobackup-canary --who "${PROGNAME}"
|
||||||
|
|
||||||
if [ "${LOCAL_TASKS}" = "1" ]; then
|
if [ "${LOCAL_TASKS}" = "1" ]; then
|
||||||
local_tasks
|
local_tasks
|
||||||
|
|
|
@ -15,3 +15,5 @@
|
||||||
#LOGLEVEL=6
|
#LOGLEVEL=6
|
||||||
#NODE=''
|
#NODE=''
|
||||||
#ARCHIVESDIR='/backup/archives'
|
#ARCHIVESDIR='/backup/archives'
|
||||||
|
#WARNING=48
|
||||||
|
#CRITICAL=72
|
||||||
|
|
|
@ -11,17 +11,17 @@ Warning: `cp`-ing the files without `-n` or `-i` will replace existing files !
|
||||||
~~~
|
~~~
|
||||||
# git clone https://gitea.evolix.org/evolix/evobackup.git
|
# git clone https://gitea.evolix.org/evolix/evobackup.git
|
||||||
# cd evobackup
|
# cd evobackup
|
||||||
# cp bkctld /usr/local/sbin/
|
# cp server/bkctld /usr/local/sbin/
|
||||||
# mkdir -p /usr/local/lib/bkctld
|
# mkdir -p /usr/local/lib/bkctld
|
||||||
# cp lib/* /usr/local/lib/bkctld/
|
# cp server/lib/* /usr/local/lib/bkctld/
|
||||||
# mkdir -p /usr/local/share/bkctld
|
# mkdir -p /usr/local/share/bkctld
|
||||||
# cp tpl/* /usr/local/share/bkctld/
|
# cp server/tpl/* /usr/local/share/bkctld/
|
||||||
# cp bkctld.service /lib/systemd/system/
|
# cp server/bkctld.service /lib/systemd/system/
|
||||||
# mkdir -p /usr/local/share/doc/bkctld
|
# mkdir -p /usr/local/share/doc/bkctld
|
||||||
# cp zzz_evobackup /usr/local/share/doc/bkctld/
|
# cp client/zzz_evobackup /usr/local/share/doc/bkctld/
|
||||||
# mkdir -p /usr/local/share/bash_completion/
|
# mkdir -p /usr/local/share/bash_completion/
|
||||||
# cp bash_completion /usr/local/share/bash_completion/bkctld
|
# cp server/bash_completion /usr/local/share/bash_completion/bkctld
|
||||||
# cp bkctld.conf /etc/default/bkctld
|
# cp server/bkctld.conf /etc/default/bkctld
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
## Chroot dependencies
|
## Chroot dependencies
|
||||||
|
|
|
@ -51,15 +51,15 @@ if dry_run; then
|
||||||
else
|
else
|
||||||
mv "${jail_path}" "${new_jail_path}"
|
mv "${jail_path}" "${new_jail_path}"
|
||||||
fi
|
fi
|
||||||
if dry_run; then
|
|
||||||
if [ -d "${incs_path}" ]; then
|
if [ -d "${incs_path}" ]; then
|
||||||
|
if dry_run; then
|
||||||
echo "[dry-run] rename ${incs_path} to ${new_incs_path}"
|
echo "[dry-run] rename ${incs_path} to ${new_incs_path}"
|
||||||
fi
|
else
|
||||||
else
|
|
||||||
if [ -d "${incs_path}" ]; then
|
|
||||||
mv "${incs_path}" "${new_incs_path}"
|
mv "${incs_path}" "${new_incs_path}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d "${jail_config_dir}" ]; then
|
if [ -d "${jail_config_dir}" ]; then
|
||||||
if dry_run; then
|
if dry_run; then
|
||||||
echo "[dry-run] rename ${jail_config_dir} to ${new_jail_config_dir}"
|
echo "[dry-run] rename ${jail_config_dir} to ${new_jail_config_dir}"
|
||||||
|
|
|
@ -136,7 +136,7 @@ is_btrfs() {
|
||||||
|
|
||||||
inode=$(stat --format=%i "${path}")
|
inode=$(stat --format=%i "${path}")
|
||||||
|
|
||||||
test $inode -eq 256
|
test "$inode" -eq 256
|
||||||
}
|
}
|
||||||
|
|
||||||
# Returns the list of jails found in the "jails" directory (default)
|
# Returns the list of jails found in the "jails" directory (default)
|
||||||
|
|
Loading…
Reference in a new issue