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 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

word image 3331 1

=>> 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;

word image 3331 2

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.

word image 3331 3

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.

 

Datalinks.vn

Hello các bạn, tôi là Dương Nguyễn (DuoDBA - https://www.youtube.com/@DuoDBA) tác giả của blog này. Mong muốn được chia sẻ kiến thức và kinh nghiệm về cơ sở dữ liệu với những người đam mê và quan tâm đến lĩnh vực này. Tôi có tổ chức các khoá Coaching về #OracleDatabase và luyện thi #OCP thường xuyên, các bạn muốn có người đồng hành thì alo tôi nhé. Call/Zalo: 0765 871 888. Thanks you !.....
0 0 đánh giá
Đánh giá bài viết
Theo dõi
Thông báo của
guest

0 Góp ý
Phản hồi nội tuyến
Xem tất cả bình luận