Phát hiện và sửa chữa sự cố hỏng cơ sở dữ liệu và các khối cơ sở dữ liệu trong Oracle là một phần quan trọng để duy trì tính toàn vẹn của dữ liệu. Dưới đây là hướng dẫn chi tiết về cách phát hiện và sửa chữa sự cố hỏng cơ sở dữ liệu và các khối cơ sở dữ liệu bằng cách sử dụng RMAN và các công cụ khác.
Repair database and database block corruption Oracle Database | Kiểm tra và sửa chữa datafile data block lỗi trong Oracle
Phát hiện sự cố hỏng cơ sở dữ liệu
Sử dụng lệnh DBVERIFY (DBV): DBV là một tiện ích độc lập để kiểm tra cấu trúc vật lý của các khối dữ liệu trong các tệp dữ liệu Oracle.
dbv file=/path/to/datafile.dbf blocksize=8192
- Thay /path/to/datafile.dbf bằng đường dẫn thực tế đến tệp dữ liệu cần kiểm tra.
- blocksize=8192 nên được thay thế bằng kích thước khối của cơ sở dữ liệu của bạn (thông thường là 8192 byte).
dbv file=/u01/app/oracle/oradata/DUODB/datafile/o1_mf_duong_tb_m6fo9dqy_.dbf blocksize=8192
=>> như này nghĩa là datafile kiểm tra không có lỗi.
Sử dụng lệnh ANALYZE trong SQL: Lệnh này có thể được sử dụng để kiểm tra bảng và chỉ mục cho sự cố hỏng.
ANALYZE TABLE TAB1 VALIDATE STRUCTURE CASCADE;
Sử dụng RMAN để kiểm tra các khối hỏng:
BACKUP VALIDATE CHECK LOGICAL DATABASE;
Lệnh này kiểm tra các khối logic của toàn bộ cơ sở dữ liệu mà không thực sự sao lưu dữ liệu.
Kiểm tra các bản ghi cảnh báo và tệp nhật ký: Kiểm tra tệp alert.log và các tệp nhật ký khác để tìm thông báo về sự cố hỏng khối.
tail -100f /u01/app/oracle/diag/rdbms/duodb/duodb/trace/alert_duodb.log
SỬA CHỮA SỰ CỐ HỎNG CƠ SỞ DỮ LIỆU VÀ CÁC KHỐI DỮ LIỆU
Sử dụng RMAN để sửa chữa các khối hỏng: Nếu bạn đã phát hiện các khối hỏng, bạn có thể sử dụng RMAN để sửa chữa chúng.
RMAN> BLOCKRECOVER DATAFILE n BLOCK b;
Thay n bằng số tệp dữ liệu và b bằng số khối hỏng.
RMAN> BLOCKRECOVER CORRUPTION LIST;
Lệnh này sẽ sửa chữa tất cả các khối được phát hiện là hỏng.
Sử dụng DBMS_REPAIR package: DBMS_REPAIR là một package PL/SQL giúp quản lý và sửa chữa các khối hỏng.
Tạo bảng sửa chữa và bảng nhật ký.
BEGIN DBMS_REPAIR.ADMIN_TABLES ( TABLE_NAME => 'REPAIR_TABLE', TABLE_TYPE => dbms_repair.repair_table, ACTION => dbms_repair.create_action, TABLESPACE => 'USERS' ); END; /
Kiểm tra các khối hỏng.
BEGIN DBMS_REPAIR.CHECK_OBJECT ( SCHEMA_NAME => 'schema_name', OBJECT_NAME => 'table_name', REPAIR_TABLE_NAME => 'REPAIR_TABLE' ); END; /
Sửa chữa các khối hỏng.
BEGIN DBMS_REPAIR.FIX_CORRUPT_BLOCKS ( SCHEMA_NAME => 'schema_name', OBJECT_NAME => 'table_name', REPAIR_TABLE_NAME => 'REPAIR_TABLE' ); END; /
Sử dụng lệnh RECOVER trong RMAN:
Khôi phục toàn bộ tệp dữ liệu nếu không thể sửa chữa các khối riêng lẻ.
RMAN> RECOVER DATAFILE n;
Thay n bằng số tệp dữ liệu.