
最新のOpenBSDでサーバーを起動する予定です。 (Web、クラウドなど)ffs2パーティションを定期的にバックアップする必要があります(例:cronを使用)。
ただし、これに関する文書はなく、ダンプユーティリティの文書のみがあります。私が理解したのは、アンマウントされたデバイスだけをダンプすることです。 (FreeBSDのダンプにはライブファイルシステムのバックアップを許可する-Lオプションがありますが、OpenBSDにはこの機能はありません。)
マウントされた/アクティブなパーティションをダンプする方法は?別のファイルシステムを使用することを提案しますか?
答え1
dump
アクティブパーティションで使用できます。rsnapshots
(OpenBSDベースではありませんがパッケージとして提供されています)も便利です。
一般的な推奨事項に従って、バックアップを慎重に計画してください。データベース(MySQLなど)には独自のバックアップツールやマスター - スレーブ同期があることがよくあります。これは便利で、回復を容易にします。メールのバックアップは、主に次の点によって異なります。どのようにあなた/あなたのユーザーがそれを使用する予定の場合、毎日のバックアップはあまり役に立ちません(たとえば、誤って削除されたメッセージを回復したい場合は、メッセージは頻繁にすばやく移動します(少なくともDovecotはIMAPマスター - スレーブを同期します)。が含まれています。)バックアップバージョンのあるリポジトリ(たとえば、gitリポジトリ)は本質的に「自分でバックアップする」ため、意味がありません。
答え2
答えはダンプを使うことです。
OpenBSDバージョンダンプは、FreeBSDの-Lと同じフラグなしでマウントされたファイルシステム用です。(UPD:本当ではありません。下記をご覧ください)
もちろん、ライブFSのすべての読み取り/書き込み操作にロックは必要ありません。 maildir(メールの保存に最もよく使われる形式、imap/smtp サーバーで使用される)形式は、読み書き操作がそれぞれのタスクとインターリーブできるように設計されているためです。その他。
ddを使用しないでください。ファイルシステムレベルではなくバイトレベルで動作するため、ddを使用すると一貫性のないデータコピーが生成される可能性があります。 dd周辺のラッパーであるOpenBSD / altroot機能を使用しないでください。
修正する:
ライブFSのダンプはR / Oフラグを使用して再マウントされます。
:(
したがって、/ varパーティションをダンプするために使用することはできません。リアルタイムFSにはtarを使用してください。
これが私のOpenBSDサーバーをバックアップするためのソリューションです。興味があれば、あなたのシステムに私のbackup.shを採用してください。
#!/usr/bin/env bash
# TODO:
#
# - full backup => incremental backup?
function use
{
echo "Usage: $0 local backup_dir"
exit 1
}
if [ $# -ne 2 ]
then
use
fi
if [[ $1 == local ]]
then
:
else
use
fi
BACKUPS="/home/neva_blyad/Облако/Загрузки/Система/Резервные образы/srv | LoveCry.pt/$2"
function remount_rw
{
DEV="$1"
# Filesystem path
DIR=`mount | grep "$DEV" | awk '{ print $3 }'`
[ "$DIR" = / ] || DIR="$DIR/"
# Remount back in R/W mode
mount -fu -o rw "$DIR"
}
function backup
{
DISK="$1"
DEV="$2"
FILENAME="$3"
# Filesystem path
DIR=`mount | grep "$DEV" | awk '{ print $3 }'`
[ "$DIR" = / ] || DIR="$DIR/"
# Backup a partition
echo "Backing up partition $DEV ($DIR)..."
# Store filesystem into archive
if [ "$DIR" = /var/ ]
then
# TODO
#
# Warning! This branch was not tested.
# (Do exclusions work properly?)
# Can't remount as R/O even for several minutes.
# We should use tar.
cd "$DIR"
gtar cf - --exclude=home \
--exclude=mail \
--exclude=opt/local \
--exclude=tmp \
--exclude=usr/local \
--exclude=var \
--exclude=Облако ./ |
pv -perab -s $(du -ksx ./ | cut -f1)K | \
#lz4 --force --quiet - "$BACKUPS/${DISK}_${FILENAME}.tar.lz4" && chown neva_blyad:neva_blyad "$BACKUPS/{$DI
xz --quiet > "$BACKUPS/${DISK}_${FILENAME}.tar.xz" && chown neva_blyad:neva_blyad "$BACKUPS/${DISK}_${FILEN
cd /
else
# Remount in R/O mode.
# (Really, it is not neccessary, dump will do it anyway.)
mount -fu -o ro "$DIR"
# Use dump
cd "$DIR"
dump -0uan -h0 -f - ./ |
pv -perab -s $(du -ksx ./ | cut -f1)K | \
#lz4 --force --quiet - "$BACKUPS/${DISK}_${FILENAME}_dump.lz4" && chown neva_blyad:neva_blyad "$BACKUPS/{$D
xz --quiet > "$BACKUPS/${DISK}_${FILENAME}_dump.xz" && chown neva_blyad:neva_blyad "$BACKUPS/${DISK}_${FILE
cd /
# Remount back in R/W
mount -fu -o rw "$DIR"
fi
}
# Make sure only root can run our script
if [ $EUID -ne 0 ]
then
echo 'This script must be run as root'
exit 1
fi
# Create backup directory
doas -u neva_blyad mkdir -p "$BACKUPS"
# Backup GPT of /dev/sd{0,1,2,4,5,6}*
echo 'Backing up GUID partition tables (GPT) of disks /dev/sd{0,1,2,4,5,6}*...'
fdisk sd0 > "$BACKUPS/sd0_fdisk"
fdisk sd1 > "$BACKUPS/sd1_fdisk"
fdisk sd2 > "$BACKUPS/sd2_fdisk"
fdisk sd4 > "$BACKUPS/sd4_fdisk"
fdisk sd5 > "$BACKUPS/sd5_fdisk"
fdisk sd6 > "$BACKUPS/sd6_fdisk"
chown neva_blyad:neva_blyad "$BACKUPS"/sd*_fdisk
# Backup BSD labels of /dev/sd{0,1,2,4,5,6}*
echo 'Backing up partition labels of BSD slices /dev/sd{0,1,2,4,5,6}*...'
disklabel sd0 > "$BACKUPS/sd0_disklabel"
disklabel sd1 > "$BACKUPS/sd1_disklabel"
disklabel sd2 > "$BACKUPS/sd2_disklabel"
disklabel sd4 > "$BACKUPS/sd4_disklabel"
disklabel sd5 > "$BACKUPS/sd5_disklabel"
disklabel sd6 > "$BACKUPS/sd6_disklabel"
chown neva_blyad:neva_blyad "$BACKUPS"/sd*_disklabel
# Backup BSD labels of /dev/sd{0,1,2,4,5,6}* (detailed)
echo 'Backing up partition labels of BSD slices /dev/sd{0,1,2,4,5,6}* (detailed)...'
disklabel -v sd0 > "$BACKUPS/sd0_disklabel_detailed"
disklabel -v sd1 > "$BACKUPS/sd1_disklabel_detailed"
disklabel -v sd2 > "$BACKUPS/sd2_disklabel_detailed"
disklabel -v sd4 > "$BACKUPS/sd4_disklabel_detailed"
disklabel -v sd5 > "$BACKUPS/sd5_disklabel_detailed"
disklabel -v sd6 > "$BACKUPS/sd6_disklabel_detailed"
chown neva_blyad:neva_blyad "$BACKUPS"/sd*_disklabel_detailed
#sync
# Cleanup before exiting if the program receives a signal during execution
function cleanup
{
# Remount /dev/sd4* back in R/W
remount_rw /dev/sd4a
remount_rw /dev/sd4b
remount_rw /dev/sd4d
remount_rw /dev/sd4e
#remount_rw /dev/sd4f
# Mark files back with dump flag
chflags dump /home/
chflags dump /home/neva_blyad/Облако/
chflags dump /opt/local/
chflags dump /tmp/
chflags dump /usr/local/
chflags dump /var/
chflags dump /var/mail/
}
trap cleanup INT TERM
# Backup /dev/sd4* (/)
chflags nodump /home/
chflags nodump /opt/local/
chflags nodump /tmp/
chflags nodump /usr/local/
chflags nodump /var/
backup sd4 /dev/sd4a root
chflags dump /home/
chflags dump /opt/local/
chflags dump /tmp/
chflags dump /usr/local/
chflags dump /var/
# Backup /dev/sd4* (/home/)
chflags nodump /home/neva_blyad/Облако/
backup sd4 /dev/sd4b home
chflags dump /home/neva_blyad/Облако/
# Backup /dev/sd4* (/opt/local/, /tmp/, /usr/local/)
backup sd4 /dev/sd4d opt_local
#backup sd4 /dev/sd4e tmp # Used actively, should not remount as R/O
backup sd4 /dev/sd4f usr_local
# Backup /dev/sd5* (/var/)
chflags nodump /var/mail/
backup sd5 /dev/sd5a var
chflags dump /var/mail/
echo Done
Cronデーモンはそれを定期的に駆動します。
$ doas crontab -l
# Environment
SHELL=/bin/sh
PATH=/root/.local/bin/:/usr/local/sbin/:/usr/local/bin/:/usr/sbin/:/usr/bin/:/sbin/:/bin/
HOME=/var/log/
MAILTO=root
...
# Make backup everyday at 05:00
#0 5 * * MON backup.sh local mon
#0 5 * * TUE backup.sh local tue
#0 5 * * WED backup.sh local wed
#0 5 * * THU backup.sh local thu
#0 5 * * FRI backup.sh local fri
0 5 * * SAT backup.sh local sat
#0 5 * * SUN backup.sh local sun