标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-01595 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,761)
- DB2 (22)
- MySQL (76)
- Oracle (1,603)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (28)
- Oracle备份恢复 (588)
- Oracle安装升级 (97)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (85)
- PostgreSQL (30)
- pdu工具 (6)
- PostgreSQL恢复 (9)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (39)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (22)
-
最近发表
- Error in invoking target ‘libasmclntsh19.ohso libasmperl19.ohso client_sharedlib’问题处理
- ORA-01171: datafile N going offline due to error advancing checkpoint
- linux环境oracle数据库被文件系统勒索加密为.babyk扩展名溯源
- ORA-600 ksvworkmsgalloc: bad reaper
- ORA-600 krccfl_chunk故障处理
- Oracle Recovery Tools恢复案例总结—202505
- ORA-600 kddummy_blkchk 数据库循环重启
- 记录一次asm disk加入到vg通过恢复直接open库的案例
- CHECKDB 发现了 N 个分配错误和 M 个一致性错误
- 达梦数据库dm.ctl文件异常恢复
- Oracle Recovery Tools修复ORA-00742、ORA-600 ktbair2: illegal inheritance故障
- 可能是 tempdb 空间用尽或某个系统表不一致故障处理
- 11.2.0.4库中遇到ORA-600 kcratr_nab_less_than_odr报错
- [MY-013183] [InnoDB] Assertion failure故障处理
- Oracle 19c 202504补丁(RUs+OJVM)-19.27
- Oracle Recovery Tools修复ORA-600 6101/kdxlin:psno out of range故障
- pdu完美支持金仓数据库恢复(KingbaseES)
- 虚拟机故障引起ORA-00310 ORA-00334故障处理
- pg创建gbk字符集库
- PostgreSQL运行日志管理
分类目录归档:Oracle
Oracle Recovery Tools快速恢复断电引起的无法正常启动数据库(ORA-01555,MISSING000等问题)
由于异常断电,数据库启动报错ORA-01113和ORA-01110,ORA-00322和ORA-00312以及ORA-00314和ORA-00312错误
Mon Apr 17 09:35:04 2023 ALTER DATABASE OPEN Errors in file D:\APP\ADMINISTRATOR\diag\rdbms\orcl\orcl\trace\orcl_ora_10192.trc: ORA-01113: 文件 1 需要介质恢复 ORA-01110: 数据文件 1: 'D:\APP\ADMINISTRATOR\ORADATA\ORCL\SYSTEM01.DBF' ORA-1113 signalled during: ALTER DATABASE OPEN... Mon Apr 17 09:35:05 2023 Errors in file D:\APP\ADMINISTRATOR\diag\rdbms\orcl\orcl\trace\orcl_m000_9788.trc: ORA-00322: 日志 6 (用于线程 1) 不是最新副本 ORA-00312: 联机日志 6 线程 1: 'D:\APP\ADMINISTRATOR\ORADATA\ORCL\REDO06.LOG' Errors in file D:\APP\ADMINISTRATOR\diag\rdbms\orcl\orcl\trace\orcl_m000_9788.trc: ORA-00314: 日志 7 (用于线程 1) 要求的 sequence# 15257 与 15248 不匹配 ORA-00312: 联机日志 7 线程 1: 'D:\APP\ADMINISTRATOR\ORADATA\ORCL\REDO07.LOG'
客户那边技术尝试强制拉库之后,报ORA-00704、ORA-01555等错误,数据库启动失败
Mon Apr 17 10:10:49 2023 alter database open resetlogs RESETLOGS is being done without consistancy checks. This may result in a corrupted database. The database should be recreated. RESETLOGS after incomplete recovery UNTIL CHANGE 3159276957 Resetting resetlogs activation ID 1558785994 (0x5ce92fca) Mon Apr 17 10:11:11 2023 Setting recovery target incarnation to 3 Mon Apr 17 10:11:11 2023 Assigning activation ID 1662170916 (0x6312b724) Thread 1 opened at log sequence 1 Current log# 1 seq# 1 mem# 0: D:\APP\ADMINISTRATOR\ORADATA\ORCL\REDO01.LOG Successful open of redo thread 1 Mon Apr 17 10:11:11 2023 MTTR advisory is disabled because FAST_START_MTTR_TARGET is not set Mon Apr 17 10:11:12 2023 SMON: enabling cache recovery ORA-01555 caused by SQL statement below (SQL ID: 4krwuz0ctqxdt, SCN: 0x0000.bc4ebda4): select ctime, mtime, stime from obj$ where obj# = :1 Errors in file D:\APP\ADMINISTRATOR\diag\rdbms\orcl\orcl\trace\orcl_ora_9324.trc: ORA-00704: 引导程序进程失败 ORA-00704: 引导程序进程失败 ORA-00604: 递归 SQL 级别 1 出现错误 ORA-01555: 快照过旧: 回退段号 10 (名称为 "_SYSSMU10_3905543278$") 过小 Errors in file D:\APP\ADMINISTRATOR\diag\rdbms\orcl\orcl\trace\orcl_ora_9324.trc: ORA-00704: 引导程序进程失败 ORA-00704: 引导程序进程失败 ORA-00604: 递归 SQL 级别 1 出现错误 ORA-01555: 快照过旧: 回退段号 10 (名称为 "_SYSSMU10_3905543278$") 过小 Error 704 happened during db open, shutting down database USER (ospid: 9324): terminating the instance due to error 704 Instance terminated by USER, pid = 9324 ORA-1092 signalled during: alter database open resetlogs...
然后尝试一系列操作,比如重建ctl,再次拉库等等,均未绕过该错误.对于ORA-704 ORA-01555错误,使用开发的小工具Oracle Recovery Tools可以一键式解决,参考处理过的类似文章:Oracle Recovery Tools恢复—ORA-00704 ORA-01555故障,不过最近发布的版本中增加了直接修改内存SCN功能,可以更加快速的解决给问题
修复之后,数据库open成功
SQL> alter database open; 数据库已更改。 SQL> shutdown immediate; 数据库已经关闭。 已经卸载数据库。 ORACLE 例程已经关闭。 SQL> startup pfile='d:/pfile.txt' mount; ORACLE 例程已经启动。 Total System Global Area 1.7170E+10 bytes Fixed Size 2262088 bytes Variable Size 1.3153E+10 bytes Database Buffers 3959422976 bytes Redo Buffers 54947840 bytes 数据库装载完毕。 SQL> select name from v$datafile where name like '%MISSING%'; NAME -------------------------------------------------------------------------------- D:\APP\ADMINISTRATOR\PRODUCT\11.2.0\DBHOME_1\DATABASE\MISSING00012 D:\APP\ADMINISTRATOR\PRODUCT\11.2.0\DBHOME_1\DATABASE\MISSING00013 已选择2行。
很不幸技术在尝试重建ctl的恢复的过程中遗漏了两个数据库文件,通过Oracle Recovery Tools再次进行恢复
在sqlplus中恢复这两个文件成功
SQL> alter database rename file 'D:\APP\ADMINISTRATOR\PRODUCT\11.2.0\DBHOME_1\DATABASE\MISSING00012' 2 to 'D:\oradata\XIFENFEI_04.DBF'; 数据库已更改。 SQL> alter database rename file 'D:\APP\ADMINISTRATOR\PRODUCT\11.2.0\DBHOME_1\DATABASE\MISSING00013' 2 to 'D:\oradata\XIFENFEI_5.DBF'; 数据库已更改。 SQL> alter database datafile 12,13 online; 数据库已更改。 SQL> SQL> SQL> alter database open ; alter database open * 第 1 行出现错误: ORA-01113: 文件 12 需要介质恢复 ORA-01110: 数据文件 12: 'D:\ORADATA\XIFENFEI_04.DBF' SQL> recover datafile 12; 完成介质恢复。 SQL> recover datafile 13; 完成介质恢复。 SQL> alter database open; 数据库已更改。
至此数据库基本上恢复完成,剩余工作就是逻辑导出导入.
软件下载:OraRecovery工具
使用说明:Oracle_Recovery_Tools说明
login trigger导致ORA-16191问题
主库突然报ORA-16191错,主库无法传输日志到备库
at Apr 08 19:56:26 2023 Thread 1 advanced to log sequence 32548 (LGWR switch) Current log# 1 seq# 32548 mem# 0: /u01/app/oracle/oradata/orcl/redo01_a.rdo Current log# 1 seq# 32548 mem# 1: /oracle/fast_recovery_area/orcl/redo01_b.rdo Sat Apr 08 19:56:26 2023 Archived Log entry 61796 added for thread 1 sequence 32547 ID 0x5fc1b26f dest 1: Sat Apr 08 19:56:27 2023 LNS: Standby redo logfile selected for thread 1 sequence 32548 for destination LOG_ARCHIVE_DEST_2 Sat Apr 08 20:21:29 2023 NSA: Error 3135 archiving log 1 to 'orcldg' Errors in file /u01/app/oracle/diag/rdbms/orcl/orcl/trace/orcl_nsa2_26205.trc: ORA-03135: connection lost contact LNS: Failed to archive log 1 thread 1 sequence 32548 (3135) Sat Apr 08 20:26:26 2023 Thread 1 advanced to log sequence 32549 (LGWR switch) Current log# 2 seq# 32549 mem# 0: /u01/app/oracle/oradata/orcl/redo02_a.rdo Current log# 2 seq# 32549 mem# 1: /oracle/fast_recovery_area/orcl/redo02_b.rdo Sat Apr 08 20:26:26 2023 Archived Log entry 61798 added for thread 1 sequence 32548 ID 0x5fc1b26f dest 1: Sat Apr 08 20:26:55 2023 Error 1017 received logging on to the standby ------------------------------------------------------------ Check that the primary and standby are using a password file and remote_login_passwordfile is set to SHARED or EXCLUSIVE, and that the SYS password is same in the password files. returning error ORA-16191 ------------------------------------------------------------ PING[ARC2]: Heartbeat failed to connect to standby 'orcldg'. Error is 16191. Sat Apr 08 20:27:57 2023 Error 1017 received logging on to the standby ------------------------------------------------------------ Check that the primary and standby are using a password file and remote_login_passwordfile is set to SHARED or EXCLUSIVE, and that the SYS password is same in the password files. returning error ORA-16191 ------------------------------------------------------------ PING[ARC2]: Heartbeat failed to connect to standby 'orcldg'. Error is 16191.
备库报错
Sat Apr 08 19:29:09 2023 Media Recovery Waiting for thread 1 sequence 32548 (in transit) Recovery of Online Redo Log: Thread 1 Group 12 Seq 32548 Reading mem 0 Mem# 0: /u01/app/oracle/oradata/orcl/std_redo12.log Sat Apr 08 21:52:19 2023 RFS[9]: Possible network disconnect with primary database
检查主备库remote_login_passwordfile参数,都是为EXCLUSIVE,确认没有问题
--备库 SQL> show parameter pass; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ remote_login_passwordfile string EXCLUSIVE SQL> select open_mode from v$database; OPEN_MODE -------------------- READ ONLY WITH APPLY --主库 SQL> select database_role from v$database; DATABASE_ROLE ---------------- PRIMARY SQL> show parameter pass; NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ remote_login_passwordfile string EXCLUSIVE
检查主备库密码文件,证明主备库密码文件一致,也不是密码文件引起不同步
--主库 [oracle@oracle1 trace]$ cd $ORACLE_HOME/dbs [oracle@oracle1 dbs]$ echo $ORACLE_SID orcl [oracle@oracle1 dbs]$ ls -ltr orapw* -rw-r-----. 1 oracle oinstall 1536 Sep 16 2022 orapworcl [oracle@oracle1 dbs]$ md5sum orapworcl d27c234b5131b4d2e13b1eeb4388f0eb orapworcl --备库 [oracle@oracle2 trace]$ cd $ORACLE_HOME/dbs [oracle@oracle2 dbs]$ echo $ORACLE_SID orcl [oracle@oracle2 dbs]$ ls -l orapw* -rw-r----- 1 oracle oinstall 1536 Sep 16 2022 orapworcl [oracle@oracle2 dbs]$ md5sum orapworcl d27c234b5131b4d2e13b1eeb4388f0eb orapworcl
查看数据库有logon触发器
SQL> select owner,trigger_name from dba_triggers where triggering_event LIKE '%LOGON%'; OWNER TRIGGER_NAME ------------------------------ ------------------------------ DBTOOLS TRIGGER_LOGINLIMIT
根据Error 1017 / ORA-16191 In Standby Alertlog (Doc ID 2225190.1)中描述logon触发器可能导致dg传输日志失败.
V$Wait_Chains定位阻塞源头
从11.1开始,查询会话阻塞,V$Wait_Chains是一个非常好的视图,通过他可以快速找到阻塞源头.进行一个简单的测试
测试表create table t1 as select * from dba_objects;
会话1
SQL> delete from t1 where object_id>100 and object_id<10000; 9712 rows deleted.
会话2
SQL> delete from t1 where object_id<200; ---hang住
会话3
SQL> delete from t1 where object_id>88 and object_id<150; --hang住
会话4进行查询分析
SQL> set lines 150 SQL> SELECT chain_id, num_waiters, in_wait_secs, osid, blocker_osid, substr(wait_event_text,1,30) FROM v$wait_chains; CHAIN_ID NUM_WAITERS IN_WAIT_SECS OSID BLOCKER_OSID SUBSTR(WAIT_EVENT_TEXT,1,30) ---------- ----------- ------------ ------------------------- ------------------------- ---------------------------------- 1 0 438 17072 17005 enq: TX - row lock contention 1 1 483 17005 16930 enq: TX - row lock contention 1 2 505 16930 SQL*Net message from client SQL> set pages 1000 SQL> set lines 120 SQL> set heading off SQL> column w_proc format a50 tru SQL> column instance format a20 tru SQL> column inst format a28 tru SQL> column wait_event format a50 tru SQL> column p1 format a16 tru SQL> column p2 format a16 tru SQL> column p3 format a15 tru SQL> column Seconds format a50 tru SQL> column sincelw format a50 tru SQL> column blocker_proc format a50 tru SQL> column waiters format a50 tru SQL> column chain_signature format a100 wra SQL> column blocker_chain format a100 wra SQL> SQL> SELECT * 2 FROM (SELECT 'Current Process: '||osid W_PROC, 'SID '||i.instance_name INSTANCE, 3 'INST #: '||instance INST,'Blocking Process: '||decode(blocker_osid,null,'<none>',blocker_osid)|| 4 ' from Instance '||blocker_instance BLOCKER_PROC,'Number of waiters: '||num_waiters waiters, 5 'Wait Event: ' ||wait_event_text wait_event, 'P1: '||p1 p1, 'P2: '||p2 p2, 'P3: '||p3 p3, 6 'Seconds in Wait: '||in_wait_secs Seconds, 'Seconds Since Last Wait: '||time_since_last_wait_secs sincelw, 7 'Wait Chain: '||chain_id ||': '||chain_signature chain_signature,'Blocking Wait Chain: '||decode(blocker_chain_id,null, 8 '<none>',blocker_chain_id) blocker_chain 9 FROM v$wait_chains wc, 10 v$instance i 11 WHERE wc.instance = i.instance_number (+) 12 AND ( num_waiters > 0 13 OR ( blocker_osid IS NOT NULL 14 AND in_wait_secs > 10 ) ) 15 ORDER BY chain_id, 16 num_waiters DESC) 17 WHERE ROWNUM < 101; Current Process: 16930 SID orcl INST #: 1 Blocking Process: <none> from Instance Number of waiters: 2 Wait Event: SQL*Net message from client P1: 1650815232 P2: 1 P3: 0 Seconds in Wait: 140 Seconds Since Last Wait: Wait Chain: 1: 'SQL*Net message from client'<='enq: TX - row lock contention'<='enq: TX - row lock c ontention' Blocking Wait Chain: <none> Current Process: 17005 SID orcl INST #: 1 Blocking Process: 16930 from Instance 1 Number of waiters: 1 Wait Event: enq: TX - row lock contention P1: 1415053318 P2: 524290 P3: 8984 Seconds in Wait: 119 Seconds Since Last Wait: Wait Chain: 1: 'SQL*Net message from client'<='enq: TX - row lock contention'<='enq: TX - row lock c ontention' Blocking Wait Chain: <none> Current Process: 17072 SID orcl INST #: 1 Blocking Process: 17005 from Instance 1 Number of waiters: 0 Wait Event: enq: TX - row lock contention P1: 1415053318 P2: 458768 P3: 8720 Seconds in Wait: 74 Seconds Since Last Wait: Wait Chain: 1: 'SQL*Net message from client'<='enq: TX - row lock contention'<='enq: TX - row lock c ontention' Blocking Wait Chain: <none> SQL> set pages 1000 SQL> set lines 120 SQL> set heading off SQL> column w_proc format a50 tru SQL> column instance format a20 tru SQL> column inst format a28 tru SQL> column wait_event format a50 tru SQL> column p1 format a16 tru SQL> column p2 format a16 tru SQL> column p3 format a15 tru SQL> column Seconds format a50 tru SQL> column sincelw format a50 tru SQL> column blocker_proc format a50 tru SQL> column fblocker_proc format a50 tru SQL> column waiters format a50 tru SQL> column chain_signature format a100 wra SQL> column blocker_chain format a100 wra SQL> SELECT * 2 FROM (SELECT 'Current Process: '||osid W_PROC, 'SID '||i.instance_name INSTANCE, 3 'INST #: '||instance INST,'Blocking Process: '||decode(blocker_osid,null,'<none>',blocker_osid)|| 4 ' from Instance '||blocker_instance BLOCKER_PROC, 5 'Number of waiters: '||num_waiters waiters, 6 'Final Blocking Process: '||decode(p.spid,null,'<none>', 7 p.spid)||' from Instance '||s.final_blocking_instance FBLOCKER_PROC, 8 'Program: '||p.program image, 9 'Wait Event: ' ||wait_event_text wait_event, 'P1: '||wc.p1 p1, 'P2: '||wc.p2 p2, 'P3: '||wc.p3 p3, 10 'Seconds in Wait: '||in_wait_secs Seconds, 'Seconds Since Last Wait: '||time_since_last_wait_secs sincelw, 11 'Wait Chain: '||chain_id ||': '||chain_signature chain_signature,'Blocking Wait Chain: '||decode(blocker_chain_id,null, 12 '<none>',blocker_chain_id) blocker_chain 13 FROM v$wait_chains wc, 14 gv$session s, 15 gv$session bs, 16 gv$instance i, 17 gv$process p 18 WHERE wc.instance = i.instance_number (+) 19 AND (wc.instance = s.inst_id (+) and wc.sid = s.sid (+) 20 and wc.sess_serial# = s.serial# (+)) 21 AND (s.final_blocking_instance = bs.inst_id (+) and s.final_blocking_session = bs.sid (+)) 22 AND (bs.inst_id = p.inst_id (+) and bs.paddr = p.addr (+)) 23 AND ( num_waiters > 0 24 OR ( blocker_osid IS NOT NULL 25 AND in_wait_secs > 10 ) ) 26 ORDER BY chain_id, 27 num_waiters DESC) 28 WHERE ROWNUM < 101; Current Process: 16930 SID orcl INST #: 1 Blocking Process: <none> from Instance Number of waiters: 2 Final Blocking Process: <none> from Instance Program: Wait Event: SQL*Net message from client P1: 1650815232 P2: 1 P3: 0 Seconds in Wait: 177 Seconds Since Last Wait: Wait Chain: 1: 'SQL*Net message from client'<='enq: TX - row lock contention'<='enq: TX - row lock c ontention' Blocking Wait Chain: <none> Current Process: 17005 SID orcl INST #: 1 Blocking Process: 16930 from Instance 1 Number of waiters: 1 Final Blocking Process: 16930 from Instance 1 Program: oracle@iZbp1hx0enix3hix1kvyrxZ (TNS V1-V3) Wait Event: enq: TX - row lock contention P1: 1415053318 P2: 524290 P3: 8984 Seconds in Wait: 155 Seconds Since Last Wait: Wait Chain: 1: 'SQL*Net message from client'<='enq: TX - row lock contention'<='enq: TX - row lock c ontention' Blocking Wait Chain: <none> Current Process: 17072 SID orcl INST #: 1 Blocking Process: 17005 from Instance 1 Number of waiters: 0 Final Blocking Process: 16930 from Instance 1 Program: oracle@iZbp1hx0enix3hix1kvyrxZ (TNS V1-V3) Wait Event: enq: TX - row lock contention P1: 1415053318 P2: 458768 P3: 8720 Seconds in Wait: 110 Seconds Since Last Wait: Wait Chain: 1: 'SQL*Net message from client'<='enq: TX - row lock contention'<='enq: TX - row lock c ontention' Blocking Wait Chain: <none> SQL> col SES for a15 SQL> set linesize 150 SQL> WITH BLOCKED AS 2 (SELECT * 3 FROM (SELECT INSTANCE, 4 SID, 5 SESS_SERIAL#, 6 BLOCKER_INSTANCE, 7 BLOCKER_SID, 8 BLOCKER_SESS_SERIAL#, 9 LEVEL LV, 10 NUM_WAITERS, 11 BLOCKER_CHAIN_ID 12 FROM V$WAIT_CHAINS 13 CONNECT BY PRIOR SID = BLOCKER_SID 14 AND PRIOR SESS_SERIAL# = BLOCKER_SESS_SERIAL# 15 AND PRIOR INSTANCE = BLOCKER_INSTANCE 16 START WITH BLOCKER_IS_VALID = 'FALSE') 17 WHERE NUM_WAITERS > 0 18 OR BLOCKER_SID IS NOT NULL) 19 SELECT INSTANCE, 20 LPAD(' ', 2 * (LV - 1)) || B.SID SES, 21 B.SESS_SERIAL#, 22 B.BLOCKER_INSTANCE, 23 B.BLOCKER_SID, 24 B.BLOCKER_SESS_SERIAL# 25 FROM BLOCKED B ; INSTANCE SES SESS_SERIAL# BLOCKER_INSTANCE BLOCKER_SID BLOCKER_SESS_SERIAL# ---------- --------------- ------------ ---------------- ----------- -------------------- 1 42 1819 1 32 52659 1 42 1819 1 39 39865 1 32 52659
能够快速的定位到阻塞会话的源头,以及阻塞的级联关系