X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=btrbk-run;h=2e1bc6352193f861031bd6e2cf4bbfeff81889a7;hb=fefb2a411185c293de6bb6aa8aec698a80db3659;hp=1b6cec5406802048fbeb1583ddf569867dd87e16;hpb=602a1874cc11a7d371890cdae4c0dc982267ea89;p=distro-setup diff --git a/btrbk-run b/btrbk-run index 1b6cec5..2e1bc63 100644 --- a/btrbk-run +++ b/btrbk-run @@ -63,7 +63,13 @@ conf_only=false dry_run=false # mostly for testing rate_limit=no verbose=true; verbose_arg=-v -progress_arg="--progress" +if [[ $INVOCATION_ID ]]; then + # INVOCATION_ID means running as a systemd service. we cant show progress in this case, + # but if we pass the arg, it will insert mbuffer into the command. + progress_arg= +else + progress_arg="--progress" +fi incremental_strict=false pull_reexec=false @@ -102,8 +108,8 @@ while true; do # Comma separated mountpoints to backup. This has defaults set below. -m) IFS=, mountpoints=($2); unset IFS; shift 2 ;; -n) dry_run=true; dry_run_arg=-n; shift ;; - # show progress - -p) progress_arg="--progress"; shift ;; + # hide progress + -p) progress_arg=; shift ;; # internal option for rerunning under newer SOURCE_HOST version. --pull-reexec) pull_reexec=true; shift ;; # quiet @@ -145,7 +151,7 @@ case $cmd_arg in # run it directly, eg: # time s btrbk -v archive /mnt/r7/amy/boot/btrbk ssh://bo/mnt/boot2/btrbk archive) - cmd=resume + cmd_arg=resume std_preserve="999h 999d 999w 999m" q_preserve="$std_preserve" preserve_arg=-p @@ -196,7 +202,8 @@ if [[ ! -v targets && ! $source ]]; then at_work=false - targets=(frodo.b8.nz) + # todo, fix this up once frodo is back + # targets=(frodo.b8.nz) case $HOSTNAME in x2|kw) at_work=true @@ -218,10 +225,13 @@ if [[ ! -v targets && ! $source ]]; then home=b8.nz fi ;;& + x2) + targets+=($home) + ;; kw) targets+=($home x2.office.fsf.org) ;; - x2|x3|sy|bo) + x3|sy|bo) targets+=($home) if $at_work; then targets+=(x2.office.fsf.org x2.b8.nz) @@ -230,12 +240,21 @@ if [[ ! -v targets && ! $source ]]; then fi ;; kd) - targets+=(x2wg.b8.nz x3.b8.nz) + if ping -q -c1 -w1 x2.office.fsf.org &>/dev/null; then + targets+=(x2.office.fsf.org) + else + targets+=(x2wg.b8.nz) + fi if ping -q -c1 -w1 sy.b8.nz &>/dev/null; then targets+=(sy.b8.nz) else targets+=(syw.b8.nz) fi + if ping -q -c1 -w1 x3.b8.nz &>/dev/null; then + targets+=(x3.b8.nz) + else + targets+=(x3w.b8.nz) + fi ;; frodo) # no targets @@ -279,19 +298,19 @@ else if [[ $source_host == "$MAIL_HOST" ]]; then prospective_mps+=(/o) fi + if [[ $source_host == "$HOST2" ]]; then + prospective_mps+=(/a /ar /qr /q) + fi else if [[ $HOSTNAME == "$MAIL_HOST" ]]; then - # HOST2 is really the mail host if it exists - if [[ $HOST2 && $HOST2 != "$HOSTNAME" ]]; then - echo "skipping /o because HOST2 is not us" - else - prospective_mps+=(/o) - fi + prospective_mps+=(/o) + fi + if [[ $HOSTNAME == "$HOST2" ]]; then + prospective_mps+=(/a /ar /qr /q) fi fi # note: put q last just in case its specific retention options were to # affect other config sections. I havent tested if that is the case. - prospective_mps+=(/a /ar /qr /q) ;; esac fi