DB2 - การสำรองและการกู้คืน
บทนี้อธิบายวิธีการสำรองและกู้คืนฐานข้อมูล
บทนำ
วิธีการสำรองและกู้คืนได้รับการออกแบบมาเพื่อให้ข้อมูลของเราปลอดภัย ใน Command Line Interface (CLI) หรือ Graphical User Interface (GUI) โดยใช้ยูทิลิตี้สำรองและกู้คืนคุณสามารถสำรองข้อมูลหรือกู้คืนข้อมูลของฐานข้อมูลใน DB2 UDB
การบันทึก
ไฟล์บันทึกประกอบด้วยบันทึกข้อผิดพลาดซึ่งใช้ในการกู้คืนจากข้อผิดพลาดของแอปพลิเคชัน บันทึกจะเก็บบันทึกการเปลี่ยนแปลงในฐานข้อมูล การบันทึกมีสองประเภทดังที่อธิบายไว้ด้านล่าง:
การบันทึกแบบวงกลม
เป็นวิธีการที่บันทึกธุรกรรมเก่าจะถูกเขียนทับเมื่อจำเป็นต้องจัดสรรไฟล์บันทึกธุรกรรมใหม่ดังนั้นจึงลบลำดับของไฟล์บันทึกและนำกลับมาใช้ใหม่ คุณได้รับอนุญาตให้สำรองข้อมูลทั้งหมดในโหมดออฟไลน์เท่านั้น กล่าวคือฐานข้อมูลต้องออฟไลน์เพื่อสำรองข้อมูลทั้งหมด
เก็บบันทึกการบันทึก
โหมดนี้รองรับการสำรองข้อมูลออนไลน์และการกู้คืนฐานข้อมูลโดยใช้ไฟล์บันทึกที่เรียกว่าการกู้คืนแบบย้อนกลับ โหมดของการสำรองข้อมูลสามารถเปลี่ยนจากแบบวงกลมเป็นไฟล์เก็บถาวรได้โดยตั้งค่า logretain หรือ userexit เป็น ON สำหรับการบันทึกการเก็บถาวรฐานข้อมูลการตั้งค่าการสำรองข้อมูลจำเป็นต้องมีไดเร็กทอรีที่เขียนได้สำหรับกระบวนการ DB2
การสำรองข้อมูล
การใช้ Backupคำสั่งคุณสามารถคัดลอกฐานข้อมูลทั้งหมด สำเนาสำรองนี้รวมถึงไฟล์ระบบฐานข้อมูลไฟล์ข้อมูลล็อกไฟล์ข้อมูลการควบคุมและอื่น ๆ
คุณสามารถสำรองข้อมูลขณะทำงานออฟไลน์และออนไลน์ได้
การสำรองข้อมูลแบบออฟไลน์
Syntax: [เพื่อแสดงรายการแอปพลิเคชัน / ฐานข้อมูลที่ใช้งานอยู่]
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:[ในการบังคับใช้แอปพลิเคชัน รหัสที่จัดการ]
db2 "force application (39)"
Output:
DB20000I The FORCE APPLICATION command completed
successfully.
DB21024I This command is asynchronous and may not
be effective immediately.
Syntax: [เพื่อยุติการเชื่อมต่อฐานข้อมูล]
db2 terminate
Syntax: [เพื่อปิดใช้งานฐานข้อมูล]
db2 deactivate database one
Syntax: [เพื่อใช้ไฟล์สำรอง]
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
การสำรองข้อมูลออนไลน์
ในการเริ่มต้นคุณต้องเปลี่ยนโหมดจาก Circular logging ถึง Archive Logging.
Syntax: [เพื่อตรวจสอบว่าฐานข้อมูลใช้การบันทึกแบบวงกลมหรือการเก็บถาวร]
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) =
ในเอาต์พุตด้านบนค่าที่ไฮไลต์คือ [logarchmeth1 และ logarchmeth2] ในโหมดปิดซึ่งหมายความว่าฐานข้อมูลปัจจุบันอยู่ในโหมด“ CIRCULLAR LOGGING” หากคุณต้องการทำงานกับโหมด "การบันทึกการเก็บข้อมูล" คุณต้องเปลี่ยนหรือเพิ่มเส้นทางในตัวแปร logarchmeth1 และ logarchmeth2 ที่มีอยู่ในไฟล์การกำหนดค่า
การอัพเดต logarchmeth1 ด้วยไดเร็กทอรีเก็บถาวรที่จำเป็น
Syntax: [เพื่อสร้างไดเรกทอรี]
mkdir backup
mkdir backup/ArchiveDest
Syntax: [เพื่อให้สิทธิ์ผู้ใช้สำหรับโฟลเดอร์]
chown db2inst1:db2iadm1 backup/ArchiveDest
Syntax: [เพื่ออัปเดตการกำหนดค่า LOGARCHMETH1]
db2 update database configuration for one using LOGARCHMETH1
'DISK:/home/db2inst1/backup/ArchiveDest'
คุณสามารถสำรองข้อมูลแบบออฟไลน์เพื่อความปลอดภัยเปิดใช้งานฐานข้อมูลและเชื่อมต่อกับฐานข้อมูล
Syntax: [เพื่อสำรองข้อมูลออนไลน์]
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
ตรวจสอบไฟล์สำรองโดยใช้คำสั่งต่อไปนี้:
Syntax:
db2ckbkp <location/backup file>
Example:
db2ckbkp
/home/db2inst1/ONE.0.db2inst1.DBPART000.20140722112743.001
รายการประวัติของไฟล์สำรอง
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:
การกู้คืนฐานข้อมูลจากการสำรองข้อมูล
ในการกู้คืนฐานข้อมูลจากไฟล์สำรองคุณต้องปฏิบัติตามไวยากรณ์ที่กำหนด:
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.
ม้วนบันทึกทั้งหมดที่อยู่ในไดเร็กทอรีบันทึกรวมถึงการเปลี่ยนแปลงล่าสุดก่อนที่ดิสก์ไดรฟ์จะล้มเหลว
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.