Db2-backup-and-recovery

提供:Dev Guides
移動先:案内検索

DB2-バックアップとリカバリー

この章では、データベースのバックアップおよび復元方法について説明します。

バックアップ

前書き

バックアップと復元の方法は、情報を安全に保つために設計されています。 バックアップおよび回復ユーティリティを使用するコマンドラインインターフェイス(CLI)またはグラフィカルユーザーインターフェイス(GUI)では、DB2 UDBのデータベースのデータをバックアップまたは復元できます。

ロギング

ログファイルはエラーログで構成され、アプリケーションエラーから回復するために使用されます。 ログには、データベースの変更の記録が保持されます。 以下に説明するように、ロギングには2つのタイプがあります。

循環ログ

これは、新しいトランザクションログファイルを割り当てる必要があるときに古いトランザクションログを上書きし、ログファイルのシーケンスを消去して再利用する方法です。 オフラインモードでは、完全なバックアップのみを取ることができます。 つまり、完全バックアップを取得するにはデータベースをオフラインにする必要があります。

アーカイブログ

このモードは、ロールフォワードリカバリと呼ばれるログファイルを使用したオンラインバックアップとデータベースリカバリをサポートします。 logretainまたはuserexitをONに設定することにより、バックアップのモードを循環からアーカイブに変更できます。 アーカイブロギングの場合、バックアップ設定データベースには、DB2プロセス用に書き込み可能なディレクトリが必要です。

バックアップ

*Backup* コマンドを使用すると、データベース全体のコピーを取得できます。 このバックアップコピーには、データベースシステムファイル、データファイル、ログファイル、制御情報などが含まれます。

バックアップは、オンラインだけでなくオフラインでも作業できます。

オフラインバックアップ

構文: [アクティブなアプリケーション/データベースを一覧表示するには]

db2 list application

出力:

Auth Id  Application    Appl.      Application Id
DB       # of
         Name           Handle
Name    Agents
-------- -------------- ---------- ---------------------
----------------------------------------- -------- -----
DB2INST1 db2bp          39
*LOCAL.db2inst1.140722043938
ONE      1

構文: [アプリを使用してアプリケーションを強制する。 処理済みID]

db2 "force application (39)"

出力:

DB20000I  The FORCE APPLICATION command completed
successfully.

DB21024I  This command is asynchronous and may not
be effective immediately.

構文: [データベース接続を終了するには]

db2 terminate

構文: [データベースを非アクティブ化するには]

db2 deactivate database one

構文: [バックアップファイルを取得するには]

db2 backup database <db_name> to <location>

例:

db2 backup database one to/home/db2inst1/

出力:

Backup successful. The timestamp for this backup image is :
20140722105345

オンラインバックアップ

開始するには、モードを*循環ログ*から*アーカイブログ*に変更する必要があります。

構文: [データベースが循環ログまたはアーカイブログを使用しているかどうかを確認するには]

db2 get db cfg for one | grep LOGARCH

出力:

First log archive method (LOGARCHMETH1) = OFF
 Archive compression for logarchmeth1  (LOGARCHCOMPR1) = OFF
 Options for logarchmeth1              (LOGARCHOPT1) =
 Second log archive method             (LOGARCHMETH2) = OFF
 Archive compression for logarchmeth2  (LOGARCHCOMPR2) = OFF
 Options for logarchmeth2              (LOGARCHOPT2) =

上記の出力では、強調表示された値はオフモードの[logarchmeth1およびlogarchmeth2]です。これは、現在のデータベースが「CIRCULLAR LOGGING」モードであることを意味します。 「アーカイブロギング」モードで作業する必要がある場合は、構成ファイルにある変数logarchmeth1およびlogarchmeth2のパスを変更または追加する必要があります。

必要なアーカイブディレクトリでlogarchmeth1を更新する

構文: [ディレクトリを作成するには]

mkdir backup
mkdir backup/ArchiveDest

構文: [フォルダのユーザー権限を提供するには]

chown db2inst1:db2iadm1 backup/ArchiveDest

構文: [構成LOGARCHMETH1を更新するには]

db2 update database configuration for one using LOGARCHMETH1
'DISK:/home/db2inst1/backup/ArchiveDest'

安全のためにオフラインバックアップを作成し、データベースをアクティブにして、接続できます。

構文: [オンラインバックアップを取る]

db2 backup database one online to
/home/db2inst1/onlinebackup/compress include logs

出力:

db2 backup database one online to
/home/db2inst1/onlinebackup/compress include logs

次のコマンドを使用してバックアップファイルを確認します。

構文:

db2ckbkp <location/backup file>

例:

db2ckbkp
/home/db2inst1/ONE.0.db2inst1.DBPART000.20140722112743.001

バックアップファイルの履歴を一覧表示する

構文:

db2 list history backup all for one

出力:

                    List History File for one

Number of matching file entries = 4

Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
Backup ID
 -- --- ------------------ ---- --- ------------ ------------
 --------------
  B  D  20140722105345001   F    D  S0000000.LOG S0000000.LOG

 ------------------------------------------------------------
 ----------------

 Contains 4 tablespace(s):
 00001 SYSCATSPACE

 00002 USERSPACE1

 00003 SYSTOOLSPACE

 00004 TS1
  ------------------------------------------------------------
  ----------------
  Comment: DB2 BACKUP ONE OFFLINE

 Start Time: 20140722105345

   End Time: 20140722105347

     Status: A
 ------------------------------------------------------------
 ----------------
 EID: 3 Location:/home/db2inst1


 Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
 Backup ID
 -- --- ------------------ ---- --- ------------ ------------
 --------------
  B  D  20140722112239000   N       S0000000.LOG S0000000.LOG
 ------------------------------------------------------------
 -------------------------------------------------------------
 -------------------------------

 Comment: DB2 BACKUP ONE ONLINE

 Start Time: 20140722112239

   End Time: 20140722112240

     Status: A
 ------------------------------------------------------------
 ----------------
  EID: 4 Location:
SQLCA Information

 sqlcaid : SQLCA     sqlcabc: 136   sqlcode: -2413   sqlerrml: 0

 sqlerrmc:
 sqlerrp : sqlubIni
 sqlerrd : (1) 0                (2) 0                (3) 0

           (4) 0                (5) 0                (6) 0

 sqlwarn : (1)      (2)      (3)      (4)        (5)       (6)

           (7)      (8)      (9)      (10)       (11)
 sqlstate:

 Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
 Backup ID
  -- --- ------------------ ---- --- ------------ ------------
  --------------
   B  D  20140722112743001   F    D  S0000000.LOG S0000000.LOG

 ------------------------------------------------------------
 ----------------
 Contains 4 tablespace(s):

 00001 SYSCATSPACE

 00002 USERSPACE1

 00003 SYSTOOLSPACE

 00004 TS1
  -------------------------------------------------------------
  ----------------
  Comment: DB2 BACKUP ONE OFFLINE

 Start Time: 20140722112743

   End Time: 20140722112743

     Status: A
 -------------------------------------------------------------
  ----------------
 EID: 5 Location:/home/db2inst1

 Op Obj Timestamp+Sequence Type Dev Earliest Log Current Log
 Backup ID
  -------------------------------------------------------------
  ----------------

R  D  20140722114519001   F
20140722112743

 ------------------------------------------------------------
 ----------------
 Contains 4 tablespace(s):

 00001 SYSCATSPACE

  00002 USERSPACE1

 00003 SYSTOOLSPACE

 00004 TS1
 ------------------------------------------------------------
 ----------------
Comment: RESTORE ONE WITH RF

 Start Time: 20140722114519

   End Time: 20140722115015
     Status: A

 ------------------------------------------------------------
 ----------------
  EID: 6 Location:

バックアップからデータベースを復元する

バックアップファイルからデータベースを復元するには、指定された構文に従う必要があります。

構文:

db2 restore database <db_name> from <location>
taken at <timestamp>

例:

db2 restore database one from/home/db2inst1/taken at
20140722112743

出力:

SQL2523W  Warning!  Restoring to an existing database that is
different from

the database on the backup image, but have matching names.
The target database

will be overwritten by the backup version.  The Roll-forward
recovery logs

associated with the target database will be deleted.

Do you want to continue ? (y/n) y

DB20000I  The RESTORE DATABASE command completed successfully.

ログドライブに障害が発生する直前の最新の変更を含む、ログディレクトリにあるすべてのログをロールフォワードします。

構文:

db2 rollforward db <db_name> to end of logs and stop

例:

db2 rollforward db one to end of logs and stop

出力:

                                 Rollforward Status
 Input database alias                   = one
 Number of members have returned status = 1
 Member ID                              = 0
 Rollforward status                     = not pending
 Next log file to be read               =
 Log files processed                    = S0000000.LOG -
 S0000001.LOG
 Last committed transaction            = 2014-07-22-
 06.00.33.000000 UTC
DB20000I  The ROLLFORWARD command completed successfully.