IT pass HikiWiki - [Memo2014][ITPASS]ローカルでのバックアップの設定 Diff
- Added parts are displayed like this.
- Deleted parts are displayed
like this.
{{toc_here}}
= 予備ディスクの準備
== 予備ディスクのパーティショニングとフォーマット
予備ディスクが本体ディスクと同じパーティション構成になっているか確認した.
ITPASS サーバーに接続されているディスクは GPT 形式でフォーマットされているため, cfdisk や sfdisk といったコマンドでは確認できなかった.
cfdisk 実行時に GNU Parted を使うようにとのメッセージが出たため, それをインストールした.
# apt-get install parted
インストールした parted コマンドを使って, パーティション構成を確認した.
# parted -l
Model: ATA Hitachi HDS72302 (scsi)
Disk /dev/sda: 2000GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Number Start End Size File system Name Flags
1 17.4kB 60.0GB 60.0GB ext3 boot
2 60.0GB 92.0GB 32.0GB linux-swap(v1)
3 92.0GB 2000GB 1908GB ext3
Model: ATA Hitachi HDS72302 (scsi)
Disk /dev/sdb: 2000GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Number Start End Size File system Name Flags
1 17.4kB 60.0GB 60.0GB ext3
2 60.0GB 92.0GB 32.0GB linux-swap(v1)
3 92.0GB 2000GB 1908GB ext3
同じであることが確認できた.
== fstab の設定 (予備ディスクのマウント)
予備ディスクがマウントされているか確認した.
# df -h
ファイルシス サイズ 使用 残り 使用% マウント位置
rootfs 56G 13G 40G 24% /
udev 10M 0 10M 0% /dev
tmpfs 1.6G 428K 1.6G 1% /run
/dev/disk/by-uuid/28c65901-9450-42e8-a724-20925e65352c 56G 13G 40G 24% /
tmpfs 5.0M 0 5.0M 0% /run/lock
tmpfs 16G 0 16G 0% /run/shm
/dev/sda3 1.8T 370G 1.3T 23% /home
マウントされていなかったため, /etc/fstab の設定を行った.
まず, 設定に必要なパーティションの uuid を確認した.
# ls -l /dev/disk/by-uuid
合計 0
lrwxrwxrwx 1 root root 10 9月 12 09:02 28c65901-9450-42e8-a724-20925e65352c -> ../../sda1
lrwxrwxrwx 1 root root 10 10月 17 16:35 358c2195-cec8-4aac-99ed-6912552dd9f7 -> ../../sdb3
lrwxrwxrwx 1 root root 10 9月 12 09:02 52909f40-36c0-41f7-8efe-ee19292a0d6f -> ../../sda3
lrwxrwxrwx 1 root root 10 9月 12 09:02 bcfacd51-6f55-4f32-8deb-0d637291fb0a -> ../../sda2
lrwxrwxrwx 1 root root 10 10月 17 16:35 ee223273-9551-4832-8d3c-9c979033adf8 -> ../../sdb1
lrwxrwxrwx 1 root root 10 9月 12 09:02 f3c2a4ab-09ab-4d33-87a4-d4114a325c19 -> ../../sdb2
/dev/sdb1, /dev/sdb3 の uuid が確認できた.
/dev/sdb1 を /bk に, /dev/sdb3 を /home.bk にマウントするため, /etc/fstab に以下の 3 行を追加した.
# for local backup
UUID=ee223273-9551-4832-8d3c-9c979033adf8 /bk ext3 defaults,errors=remount-ro 0 2
UUID=358c2195-cec8-4aac-99ed-6912552dd9f7 /home.bk ext3 defaults,usrquota 0 2
マウントするためのディレクトリを作成した.
# mkdir /bk /home.bk
マウントした.
# mount -a
意図通りにマウントされているか確認した.
# df -h
ファイルシス サイズ 使用 残り 使用% マウント位置
rootfs 56G 13G 40G 24% /
udev 10M 0 10M 0% /dev
tmpfs 1.6G 412K 1.6G 1% /run
/dev/disk/by-uuid/28c65901-9450-42e8-a724-20925e65352c 56G 13G 40G 24% /
tmpfs 5.0M 0 5.0M 0% /run/lock
tmpfs 16G 0 16G 0% /run/shm
/dev/sda3 1.8T 370G 1.3T 23% /home
/dev/sdb1 56G 180M 53G 1% /bk
/dev/sdb3 1.8T 196M 1.7T 1% /home.bk
= バックアップスクリプトの設置
バックアップ用スクリプトを設置した.
* root ディレクトリ用: rsync_localbk_root.sh を, /etc/cron.local/daily/220_rsync_localbk_root へ設置した
# wget http://itpass.scitec.kobe-u.ac.jp/server/2011/system_backup/rsync_localbk_root.sh
# mv rsync_localbk_root.sh /etc/cron.local/daily/220_rsync_localbk_root
* home ディレクトリ用: rsync_localbk_home.sh を, /etc/cron.local/daily/225_rsync_localbk_home へ設置した
# wget http://itpass.scitec.kobe-u.ac.jp/server/2011/system_backup/rsync_localbk_home.sh
# mv ./rsync_localbk_home.sh /etc/cron.local/daily/225_rsync_localbk_home
設置したスクリプトに実行権限を追加した.
# chmod 744 /etc/cron.local/daily/220_rsync_localbk_root
# chmod 744 /etc/cron.local/daily/225_rsync_localbk_home
= crontab の編集
/etc/crontab に以下の一行が存在することを確認した.
25 6 * * * root cd / && run-parts --report /etc/cron.local/daily |mail -s "`hostname -f` daily run outputs" xxx@xxx.xxxx
= バックアップログファイルの作成
ログファイルのためのディレクトリとファイルを作成した.
ただし ディレクトリは既に存在していた.
mkdir /var/log/rsync-log
touch /var/log/rsync-log/{localbk_root.log,localbk_home.log}
= バックアップログファイルの logrotate の設定
rsync のログを 1 週間毎に分割する. /etc/logrotate.d/ 以下に rsync_localbk_root という設定ファイルを作成した.
# vim /etc/logrotate.d/rsync_localbk_root
以下の内容を書き込んだ.
/var/log/rsync-log/localbk_root.log {
weekly
create 0644 root root
rotate 12
}
同様に rsync_localbk_home も作成した.
# vim /etc/logrotate.d/rsync_localbk_home
以下の内容を書き込んだ.
/var/log/rsync-log/localbk_home.log {
weekly
create 0644 root root
rotate 12
}
= バックアップのテスト
# cd /etc/cron.local/daily/
# ./220_rsync_localbk_root
# ./225_rsync_localbk_home
バックアップができていることを, ログファイルで確認した.
= 本サーバから予備サーバへのバックアップの停止
ローカルバックアップが cron によって実行されたことを確認し, 本サーバから予備サーバへのバックアップを止めた. 具体的には, 本サーバから予備サーバへのバックアップを行っているスクリプトの実行権限を消した.
# chmod 644 /etc/cron.local/daily/230_rsync_itpassbk
= 参考文献
((<[ITPASS2012]ローカルでのバックアップの設定>))
= 予備ディスクの準備
== 予備ディスクのパーティショニングとフォーマット
予備ディスクが本体ディスクと同じパーティション構成になっているか確認した.
ITPASS サーバーに接続されているディスクは GPT 形式でフォーマットされているため, cfdisk や sfdisk といったコマンドでは確認できなかった.
cfdisk 実行時に GNU Parted を使うようにとのメッセージが出たため, それをインストールした.
# apt-get install parted
インストールした parted コマンドを使って, パーティション構成を確認した.
# parted -l
Model: ATA Hitachi HDS72302 (scsi)
Disk /dev/sda: 2000GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Number Start End Size File system Name Flags
1 17.4kB 60.0GB 60.0GB ext3 boot
2 60.0GB 92.0GB 32.0GB linux-swap(v1)
3 92.0GB 2000GB 1908GB ext3
Model: ATA Hitachi HDS72302 (scsi)
Disk /dev/sdb: 2000GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Number Start End Size File system Name Flags
1 17.4kB 60.0GB 60.0GB ext3
2 60.0GB 92.0GB 32.0GB linux-swap(v1)
3 92.0GB 2000GB 1908GB ext3
同じであることが確認できた.
== fstab の設定 (予備ディスクのマウント)
予備ディスクがマウントされているか確認した.
# df -h
ファイルシス サイズ 使用 残り 使用% マウント位置
rootfs 56G 13G 40G 24% /
udev 10M 0 10M 0% /dev
tmpfs 1.6G 428K 1.6G 1% /run
/dev/disk/by-uuid/28c65901-9450-42e8-a724-20925e65352c 56G 13G 40G 24% /
tmpfs 5.0M 0 5.0M 0% /run/lock
tmpfs 16G 0 16G 0% /run/shm
/dev/sda3 1.8T 370G 1.3T 23% /home
マウントされていなかったため, /etc/fstab の設定を行った.
まず, 設定に必要なパーティションの uuid を確認した.
# ls -l /dev/disk/by-uuid
合計 0
lrwxrwxrwx 1 root root 10 9月 12 09:02 28c65901-9450-42e8-a724-20925e65352c -> ../../sda1
lrwxrwxrwx 1 root root 10 10月 17 16:35 358c2195-cec8-4aac-99ed-6912552dd9f7 -> ../../sdb3
lrwxrwxrwx 1 root root 10 9月 12 09:02 52909f40-36c0-41f7-8efe-ee19292a0d6f -> ../../sda3
lrwxrwxrwx 1 root root 10 9月 12 09:02 bcfacd51-6f55-4f32-8deb-0d637291fb0a -> ../../sda2
lrwxrwxrwx 1 root root 10 10月 17 16:35 ee223273-9551-4832-8d3c-9c979033adf8 -> ../../sdb1
lrwxrwxrwx 1 root root 10 9月 12 09:02 f3c2a4ab-09ab-4d33-87a4-d4114a325c19 -> ../../sdb2
/dev/sdb1, /dev/sdb3 の uuid が確認できた.
/dev/sdb1 を /bk に, /dev/sdb3 を /home.bk にマウントするため, /etc/fstab に以下の 3 行を追加した.
# for local backup
UUID=ee223273-9551-4832-8d3c-9c979033adf8 /bk ext3 defaults,errors=remount-ro 0 2
UUID=358c2195-cec8-4aac-99ed-6912552dd9f7 /home.bk ext3 defaults,usrquota 0 2
マウントするためのディレクトリを作成した.
# mkdir /bk /home.bk
マウントした.
# mount -a
意図通りにマウントされているか確認した.
# df -h
ファイルシス サイズ 使用 残り 使用% マウント位置
rootfs 56G 13G 40G 24% /
udev 10M 0 10M 0% /dev
tmpfs 1.6G 412K 1.6G 1% /run
/dev/disk/by-uuid/28c65901-9450-42e8-a724-20925e65352c 56G 13G 40G 24% /
tmpfs 5.0M 0 5.0M 0% /run/lock
tmpfs 16G 0 16G 0% /run/shm
/dev/sda3 1.8T 370G 1.3T 23% /home
/dev/sdb1 56G 180M 53G 1% /bk
/dev/sdb3 1.8T 196M 1.7T 1% /home.bk
= バックアップスクリプトの設置
バックアップ用スクリプトを設置した.
* root ディレクトリ用: rsync_localbk_root.sh を, /etc/cron.local/daily/220_rsync_localbk_root へ設置した
# wget http://itpass.scitec.kobe-u.ac.jp/server/2011/system_backup/rsync_localbk_root.sh
# mv rsync_localbk_root.sh /etc/cron.local/daily/220_rsync_localbk_root
* home ディレクトリ用: rsync_localbk_home.sh を, /etc/cron.local/daily/225_rsync_localbk_home へ設置した
# wget http://itpass.scitec.kobe-u.ac.jp/server/2011/system_backup/rsync_localbk_home.sh
# mv ./rsync_localbk_home.sh /etc/cron.local/daily/225_rsync_localbk_home
設置したスクリプトに実行権限を追加した.
# chmod 744 /etc/cron.local/daily/220_rsync_localbk_root
# chmod 744 /etc/cron.local/daily/225_rsync_localbk_home
= crontab の編集
/etc/crontab に以下の一行が存在することを確認した.
25 6 * * * root cd / && run-parts --report /etc/cron.local/daily |mail -s "`hostname -f` daily run outputs" xxx@xxx.xxxx
= バックアップログファイルの作成
ログファイルのためのディレクトリとファイルを作成した.
ただし ディレクトリは既に存在していた.
mkdir /var/log/rsync-log
touch /var/log/rsync-log/{localbk_root.log,localbk_home.log}
= バックアップログファイルの logrotate の設定
rsync のログを 1 週間毎に分割する. /etc/logrotate.d/ 以下に rsync_localbk_root という設定ファイルを作成した.
# vim /etc/logrotate.d/rsync_localbk_root
以下の内容を書き込んだ.
/var/log/rsync-log/localbk_root.log {
weekly
create 0644 root root
rotate 12
}
同様に rsync_localbk_home も作成した.
# vim /etc/logrotate.d/rsync_localbk_home
以下の内容を書き込んだ.
/var/log/rsync-log/localbk_home.log {
weekly
create 0644 root root
rotate 12
}
= バックアップのテスト
# cd /etc/cron.local/daily/
# ./220_rsync_localbk_root
# ./225_rsync_localbk_home
バックアップができていることを, ログファイルで確認した.
= 本サーバから予備サーバへのバックアップの停止
ローカルバックアップが cron によって実行されたことを確認し, 本サーバから予備サーバへのバックアップを止めた. 具体的には, 本サーバから予備サーバへのバックアップを行っているスクリプトの実行権限を消した.
# chmod 644 /etc/cron.local/daily/230_rsync_itpassbk
= 参考文献
((<[ITPASS2012]ローカルでのバックアップの設定>))