mk-mode BLOG

このブログは自作の自宅サーバに構築した Debian GNU/Linux で運用しています。
PC・サーバ構築等の話題を中心に公開しております。(クローンサイト: GitHub Pages

ブログ開設日2009-01-05
サーバ連続稼働時間
Reading...
Page View 合計
Reading...
今日
Reading...
昨日
Reading...

サーバミラーリングデータを世代管理圧縮保存!

[ サーバ構築 ] [ Windows ]

こんばんは。

うちの稼動中のサーバの大事なデータを玄箱HG(Fedora10)へミラーリングコピーしているんですが、そいつらを世代管理して圧縮保存するようにしてみました。 ※なぜなら、サーバがトラブった時、「あの日に戻れたら!」なんてことがあるからです。

導入手順

※いつものように Fedoraで自宅サーバー構築自動バックアップ運用(tar+GnuPG+rsync/ftp) を参考にさせてもらいました。

【前提条件】 ・実サーバはFedora10でWebサーバ、メールサーバ、FTPサーバ等が稼動中。 ・バックアップ側もFedora10で、NTPサーバ、Sambaサーバが稼動中。 ・実サーバのIPアドレスは 192.168.11.3 、バックアップ側(玄箱HG)のIPアドレスは 192.168.11.2 。 ・実サーバ、バックアップ側(玄箱)どちらも「 Poderosa 」によるリモート接続による操作。 (実サーバはSSH2接続・鍵認証、バックアップ側(玄箱HG)はSSH2接続・パスワード認証) ・実サーバの大事なデータを玄箱側の「 /tmp/mirror 」フォルダ配下へミラーリングコピーするように設定済み。

※今回は全て、バックアップ(玄箱HG)での作業です。

1.玄箱HGにリモート接続

「 Poderosa 」により 玄箱HG・Fedora10 にリモート接続し、rootユーザになっておく。

2.圧縮スクリプトを作成

以下のように世代管理して圧縮保存するスクリプトを作成する。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
[root@KURO-BOX ~]# vi backup.sh

#!/bin/bash

#
# ローカル内でバックアップ
#

LANG=C

#
# 設定開始
#

# 圧縮対象リスト名
# ※圧縮対象をフルパスで記述したリスト
BACKUPLIST=/root/backuplist
[ ! -s $BACKUPLIST ] && echo "$BACKUPLIST is not found" && error_exit

# 圧縮対象外リスト名
# ※圧縮対象外をフルパスで記述したリスト
BACKUPNOLIST=/root/backupnolist

# 圧縮先ディレクトリ名
BACKUPDIR=/backup
mkdir -p $BACKUPDIR

# 圧縮ファイル保存世代数
# ※当日分を含めた過去分圧縮ファイルを保存する世代数
# ※過去分圧縮ファイルを保存しない場合は1を指定する
BACKUPGEN=8

# 暗号化・復号化パスフレーズ
# ※指定がないときは暗号化しない
PASS=''

# 圧縮ログファイル名
BACKUPLOG=/var/log/backup.log

#
# 設定終了
#

# 異常終了処理関数定義
error_exit () {
    rm -f $TMPBACKUPNOLIST
    exit 1
}

# 圧縮ファイルを圧縮対象外リストに追加
# ※圧縮先ファイルを圧縮しないようにする
TMPBACKUPNOLIST=`mktemp`
[ -s $BACKUPNOLIST ] && cat $BACKUPNOLIST > $TMPBACKUPNOLIST
echo "$BACKUPDIR/*backup.tar.bz2" >> $TMPBACKUPNOLIST

# 前回圧縮をリネーム
cd $BACKUPDIR
OLDBACKUPFILE=`ls backup.tar.bz2* 2>/dev/null`
if [ -f $OLDBACKUPFILE ]; then
    TIMESTAMP=`ls --full-time $OLDBACKUPFILE|awk '{print $6}'|tr -d -`
    mv $BACKUPDIR/$OLDBACKUPFILE $BACKUPDIR/${TIMESTAMP}$OLDBACKUPFILE > /dev/null 2>&1
fi

# 圧縮ログファイル作成
rm -f $BACKUPLOG
touch $BACKUPLOG
chmod 400 $BACKUPLOG

# 圧縮実行
echo "`date` backup start" >> $BACKUPLOG
tar cjvfP $BACKUPDIR/backup.tar.bz2 -T $BACKUPLIST -X $TMPBACKUPNOLIST >> $BACKUPLOG 2>&1

echo "`date` backup end" >> $BACKUPLOG

# 圧縮暗号化(暗号化・復号化パスフレーズ指定時のみ)
if [ ! -z $PASS ]; then
    echo "`date` encrypt start" >> $BACKUPLOG
    mkdir -p $HOME/.gnupg
    echo $PASS|gpg --passphrase-fd 0 --batch -c $BACKUPDIR/backup.tar.bz2 > /dev/null 2>&1
  code=$?
  if [ $code -ne 0 ]; then
      cat $BACKUPLOG | mail -s "BACKUP NG CODE IS $code" root
      rm -f $BACKUPDIR/backup.tar.bz2*
      error_exit
  fi
    rm -f $BACKUPDIR/backup.tar.bz2
    echo "`date` encrypt end" >> $BACKUPLOG
fi

# 圧縮ファイル保存世代を超えた古い圧縮ファイルを削除
if [ $(ls $BACKUPDIR/*backup.tar.bz2*|wc -l) -gt $BACKUPGEN ]; then
    OLDBACKUPCNT=`expr $(ls $BACKUPDIR/*backup.tar.bz2*|wc -l) - $BACKUPGEN`
    for file in `ls -t $BACKUPDIR/*backup.tar.bz2*|tail -n $OLDBACKUPCNT`
    do
        rm -f $file
    done
fi

# 圧縮対象外リスト削除
rm -f $TMPBACKUPNOLIST

[root@KURO-BOX ~]#

3.実行権限付与

以下のようにしてスクリプトに実行権限を付与する。

1
2
[root@KURO-BOX ~]# chmod 700 backup.sh
[root@KURO-BOX ~]#

4.圧縮対象リストの作成

今回圧縮保存の対象となるフォルダをしていする。

1
2
[root@KURO-BOX ~]# echo "/tmp/mirror" >> backuplist
[root@KURO-BOX ~]#

※今回は圧縮保存対象外リストは作成しない。 (「 /tmp/mirror 」配下は全て圧縮したいので)

5.スクリプトの試行

以下のようにしてスクリプトを試しに実行してみる。

1
2
[root@KURO-BOX ~]# ./backup.sh
[root@KURO-BOX ~]#

6.圧縮ファイル作成確認

正常に圧縮ファイルが作成されているか確認する。

1
2
[root@KURO-BOX ~]# ls -lh /backup
[root@KURO-BOX ~]#

7.圧縮内容確認

圧縮ファイルの内容を確認してみる。

1
2
3
4
5
[root@KURO-BOX ~]# tar tjvf /backup/backup.tar.bz2
・・・ 省略 ・・・
圧縮ファイルの内容が表示される
・・・ 省略 ・・・
[root@KURO-BOX ~]#

8.定期自動実行設定

毎日同じ時間に定期的に自動で実行されるよう設定する。

1
2
[root@KURO-BOX ~]# echo "0 3 * * * root /root/backup.sh" > /etc/cron.d/backup
[root@KURO-BOX ~]#

※しかし、上記ので試行してみたんですが、1時間経っても終わりませんでした。 玄箱HGの非力なCPUとメモリのせいだと思います。

結局、玄箱HGでの圧縮保存はヤメにしました。

今日はここまで。 じゃ。

Comments