DB2 - Pencadangan dan Pemulihan
Bab ini menjelaskan metode pencadangan dan pemulihan database.
pengantar
Metode pencadangan dan pemulihan dirancang untuk menjaga keamanan informasi kami. Di Command Line Interface (CLI) atau Graphical User Interface (GUI) menggunakan utilitas pencadangan dan pemulihan, Anda dapat membuat cadangan atau memulihkan data dari database di DB2 UDB.
Logging
File log terdiri dari log kesalahan, yang digunakan untuk memulihkan kesalahan aplikasi. Log menyimpan catatan perubahan dalam database. Ada dua jenis logging seperti yang dijelaskan di bawah ini:
Penebangan melingkar
Ini adalah metode di mana log transaksi lama ditimpa ketika ada kebutuhan untuk mengalokasikan file log transaksi baru, sehingga menghapus urutan file log dan menggunakannya kembali. Anda diizinkan untuk mengambil hanya cadangan penuh dalam mode offline. misalnya, database harus offline untuk mengambil cadangan penuh.
Arsipkan logging
Mode ini mendukung Pencadangan Online dan pemulihan database menggunakan file log yang disebut pemulihan roll forward. Mode pencadangan dapat diubah dari melingkar ke arsip dengan menyetel logretain atau userexit ke ON. Untuk pencatatan arsip, database pengaturan cadangan memerlukan direktori yang dapat ditulis untuk proses DB2.
Cadangan
Menggunakan Backupperintah Anda dapat mengambil salinan seluruh database. Salinan cadangan ini mencakup file sistem database, file data, file log, informasi kontrol, dan sebagainya.
Anda dapat membuat cadangan saat bekerja offline maupun online.
Pencadangan offline
Syntax: [Untuk membuat daftar aplikasi / database yang aktif]
db2 list application
Output:
Auth Id Application Appl. Application Id
DB # of
Name Handle
Name Agents
-------- -------------- ---------- ---------------------
----------------------------------------- -------- -----
DB2INST1 db2bp 39
*LOCAL.db2inst1.140722043938
ONE 1
Syntax:[Untuk memaksa aplikasi menggunakan aplikasi. ID yang ditangani]
db2 "force application (39)"
Output:
DB20000I The FORCE APPLICATION command completed
successfully.
DB21024I This command is asynchronous and may not
be effective immediately.
Syntax: [Untuk menghentikan Koneksi Database]
db2 terminate
Syntax: [Untuk menonaktifkan Database]
db2 deactivate database one
Syntax: [Untuk mengambil file cadangan]
db2 backup database <db_name> to <location>
Example:
db2 backup database one to /home/db2inst1/
Output:
Backup successful. The timestamp for this backup image is :
20140722105345
Cadangan online
Untuk memulai, Anda perlu mengubah mode dari Circular logging untuk Archive Logging.
Syntax: [Untuk memeriksa apakah database menggunakan melingkar atau pencatatan arsip]
db2 get db cfg for one | grep LOGARCH
Output:
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) =
Pada output di atas, nilai yang disorot adalah [logarchmeth1 dan logarchmeth2] dalam mode off, yang berarti bahwa database saat ini dalam mode “CIRCULLAR LOGGING”. Jika Anda perlu bekerja dengan mode 'ARCHIVE LOGGING', Anda perlu mengubah atau menambahkan jalur di variabel logarchmeth1 dan logarchmeth2 yang ada di file konfigurasi.
Memperbarui logarchmeth1 dengan direktori arsip yang diperlukan
Syntax: [Untuk membuat direktori]
mkdir backup
mkdir backup/ArchiveDest
Syntax: [Untuk memberikan izin pengguna untuk folder]
chown db2inst1:db2iadm1 backup/ArchiveDest
Syntax: [Untuk memperbarui konfigurasi LOGARCHMETH1]
db2 update database configuration for one using LOGARCHMETH1
'DISK:/home/db2inst1/backup/ArchiveDest'
Anda dapat mengambil cadangan offline untuk keamanan, mengaktifkan database, dan menyambungkannya.
Syntax: [Untuk mengambil cadangan online]
db2 backup database one online to
/home/db2inst1/onlinebackup/ compress include logs
Output:
db2 backup database one online to
/home/db2inst1/onlinebackup/ compress include logs
Verifikasi file Cadangan menggunakan perintah berikut:
Syntax:
db2ckbkp <location/backup file>
Example:
db2ckbkp
/home/db2inst1/ONE.0.db2inst1.DBPART000.20140722112743.001
Mencantumkan riwayat file cadangan
Syntax:
db2 list history backup all for one
Output:
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:
Mengembalikan database dari backup
Untuk memulihkan database dari file cadangan, Anda harus mengikuti sintaks yang diberikan:
Syntax:
db2 restore database <db_name> from <location>
taken at <timestamp>
Example:
db2 restore database one from /home/db2inst1/ taken at
20140722112743
Output:
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.
Gulirkan semua log yang terletak di direktori log, termasuk perubahan terbaru tepat sebelum drive disk gagal.
Syntax:
db2 rollforward db <db_name> to end of logs and stop
Example:
db2 rollforward db one to end of logs and stop
Output:
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.