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]ローカルでのバックアップの設定>))