标签云
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,772)
- DB2 (22)
- MySQL (77)
- Oracle (1,612)
- 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 监听 (29)
- Oracle备份恢复 (593)
- Oracle安装升级 (98)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (31)
- pdu工具 (6)
- PostgreSQL恢复 (10)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (39)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (22)
-
最近发表
- 由于空间满导致PostgreSQL数据库异常处理
- 一次非常幸运的ORA-600 16703(tab$被清空)故障恢复
- Oracle 19c 202507补丁(RUs+OJVM)-19.28
- 2025年的Oracle 8.0.5数据库恢复
- ORA-600 kokiasg1故障分析(obj$中核心字典序列全部被恶意删除)
- ORA-00756 ORA-10567故障数据0丢失恢复
- 数据库文件变成32k故障恢复
- tcp连接过多导致监听TNS-12532 TNS-12560 TNS-00502错误
- 文件系统格式化MySQL数据库恢复
- .sstop勒索加密数据库恢复
- 解决一次硬件恢复之后数据文件0kb的故障恢复case
- 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 个一致性错误
分类目录归档:Oracle
找出调用DBLINK的SESSION信息
怎么找出通过dblink访问的用户信息?这个问题困惑了很久,今天在朋友的帮助下,终于通过基表实现了这个功能,记录下来
SELECT /*+ ORDERED */ S.KSUSEMNM "O_HOSTNAME",S.KSUSEPID "O_SPID",--操作dblink用户信息 G.K2GTITID_ORA "O_TXID", S.INDX "S_SID",S.KSUSESER "S_SERIAL#",--dblink session信息 DECODE(BITAND(KSUSEIDL, 11), 1, 'ACTIVE', 0, DECODE(BITAND(KSUSEFLG, 4096), 0, 'INACTIVE', 'CACHED'), 2, 'SNIPED', 3, 'SNIPED', 'KILLED') "S_STATUS", S.KSUUDNAM "DBLINK_USER" FROM SYS.X$K2GTE G, SYS.X$KTCXB T, SYS.X$KSUSE S WHERE G.K2GTDXCB = T.KTCXBXBA AND G.K2GTDSES = T.KTCXBSES AND S.ADDR = G.K2GTDSES;
查询结果如下
O_HOSTNAME O_SPID O_TXID S_SID S_SERIAL# S_STATUS DBLINK_USER ----------------------- ---------- ----------------------- ---------- ---------- -------- ------------ localhost.localdomain 2571 MCRM.757120d4.8.31.21425 5462 20 INACTIVE TEST1 localhost.localdomain 1021 MCRM.757120d4.6.17.21298 5467 664 INACTIVE TEST localhost.localdomain 1385 MCRM.757120d4.10.2.16138 5473 155 INACTIVE TEST
如果需要获取更加信息的信息,可以通过结合两端的v$session和v$process视图获得
发表在 Oracle
评论关闭
ORA-01075: you are currently logged on
rm删除文件后alert中出现错误
Mon Apr 16 21:36:59 2012 Errors in file /home/oracle/oracle/admin/XGS/bdump/xgs_j000_1349.trc: ORA-00603: ORACLE server session terminated by fatal error ORA-01116: error in opening database file 3 ORA-01110: data file 3: '/home/oracle/oracle/oradata/XGS/sysaux01.dbf' ORA-27041: unable to open file Linux Error: 2: No such file or directory Additional information: 3 ORA-01116: error in opening database file 3 ORA-01110: data file 3: '/home/oracle/oracle/oradata/XGS/sysaux01.dbf' ORA-27041: unable to open file Linux Error: 2: No such file or directory Additional information: 3 ORA-01116: error in opening database file 6 ORA-01110: data file 6: '/home/oracle/oracle/oradata/XGS/undotbs02.dbf' ORA-27041: unable to open file Linux Error: 2: No such file or directory Additional information: 3
数据库进程还在运行
oracle 779 1 0 21:21 ? 00:00:01 ora_pmon_XGS oracle 781 1 0 21:21 ? 00:00:10 ora_psp0_XGS oracle 783 1 0 21:21 ? 00:00:00 ora_mman_XGS oracle 785 1 0 21:21 ? 00:00:00 ora_dbw0_XGS oracle 787 1 0 21:21 ? 00:00:00 ora_lgwr_XGS oracle 789 1 0 21:21 ? 00:00:00 ora_ckpt_XGS oracle 791 1 0 21:21 ? 00:00:00 ora_smon_XGS oracle 793 1 0 21:21 ? 00:00:00 ora_reco_XGS oracle 795 1 0 21:21 ? 00:00:00 ora_cjq0_XGS oracle 797 1 0 21:21 ? 00:00:01 ora_mmon_XGS oracle 799 1 0 21:21 ? 00:00:00 ora_mmnl_XGS oracle 801 1 0 21:21 ? 00:00:00 ora_d000_XGS oracle 803 1 0 21:21 ? 00:00:00 ora_s000_XGS
尝试登陆数据库
[oracle@dbtest ~]$ sqlplus / as sysdba SQL*Plus: Release 10.2.0.1.0 - Production on Mon Apr 16 21:40:06 2012 Copyright (c) 1982, 2005, Oracle. All rights reserved. ERROR: ORA-01075: you are currently logged on Enter user-name: sys Enter password: ERROR: ORA-00604: error occurred at recursive SQL level 2 ORA-01116: error in opening database file 1 ORA-01110: data file 1: '/home/oracle/oracle/oradata/XGS/system01.dbf' ORA-27041: unable to open file Linux Error: 2: No such file or directory Additional information: 3 ORA-00604: error occurred at recursive SQL level 1 ORA-01116: error in opening database file 6 ORA-01110: data file 6: '/home/oracle/oracle/oradata/XGS/undotbs02.dbf' ORA-27041: unable to open file Linux Error: 2: No such file or directory Additional information: 3
问题原因
Internal triggers are trying to fire but one or more datafiles for the SYSAUX tablespace is offline, this is preventing the database from allowing new connections. NOTE: At this point, you cannot connect to verify the status in V$DATAFILE, but you may find an indication of the offline datafile(s) in the alert.log file. For example: In one case, a media problem occurred which made disks unavailable. This caused several files to be taken offline automatically including a SYSAUX datafile.
解决方法
kill进程,重启数据库到mount状态,然后根据特定情况恢复数据库或者online相关文件
记录一次ORA-00600[kdsgrp1]分析
数据库版本
SQL> select * from v$version; BANNER ---------------------------------------------------------------- Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi PL/SQL Release 10.2.0.4.0 - Production CORE 10.2.0.4.0 Production TNS for IBM/AIX RISC System/6000: Version 10.2.0.4.0 - Productio NLSRTL Version 10.2.0.4.0 - Production
找出报错对象
--方法1 *** SESSION ID:(795.16405) 2012-04-05 09:36:11.958 row 080095ee.26 continuation at file# 32 block# 38382 slot 39 not found ************************************************** KDSTABN_GET: 0 ..... ntab: 1 curSlot: 39 ..... nrows: 19 ************************************************** SQL> SELECT OWNER, SEGMENT_NAME, SEGMENT_TYPE, TABLESPACE_NAME, A.PARTITION_NAME 2 FROM DBA_EXTENTS A 3 WHERE FILE_ID = &FILE_ID 4 AND &BLOCK_ID BETWEEN BLOCK_ID AND BLOCK_ID + BLOCKS - 1; Enter value for file_id: 32 old 3: WHERE FILE_ID = &FILE_ID new 3: WHERE FILE_ID = 32 Enter value for block_id: 38382 old 4: AND &BLOCK_ID BETWEEN BLOCK_ID AND BLOCK_ID + BLOCKS - 1 new 4: AND 38382 BETWEEN BLOCK_ID AND BLOCK_ID + BLOCKS - 1 OWNER ------------------------------ SEGMENT_NAME -------------------------------------------------------------------------------- SEGMENT_TYPE TABLESPACE_NAME PARTITION_NAME ------------------ ------------------------------ ------------------------------ AHV8 TBL_IVR_LOG TABLE PARTITION CSS_PARTITION IVR_LOG_2012_MONTH04 --方法2 *** 2012-04-05 09:36:11.965 ksedmp: internal or fatal error ORA-00600: internal error code, arguments: [kdsgrp1], [], [], [], [], [], [], [] Current SQL statement for this session: INSERT INTO TBL_CONTACT_INFO_FAILED_TMP select * from TBL_IVR_LOG SO: 70000017f954f50, type: 4, owner: 70000017f65a840, flag: INIT/-/-/0x00 (session) sid: 795 trans: 70000017464a1e8, creator: 70000017f65a840, flag: (40110041) USR/- BSY/-/-/-/-/- DID: 0002-0067-000305BD, short-term DID: 0002-0067-000305BE txn branch: 0 oct: 2, prv: 0, sql: 70000015180ee98, psql: 700000180d67550, user: 49/AHV8 service name: SYS$USERS O/S info: user: oracle10, term: UNKNOWN, ospid: 12976218, machine: zwq_kfdb2 program: oracle@zwq_kfdb2 (J002) last wait for 'db file sequential read' blocking sess=0x0 seq=226 wait_time=17071 seconds since wait started=1 file#=20, block#=95ee, blocks=1 --方法3 Block header dump: 0x080095ee Object id on Block? Y seg/obj: 0x11eeb csc: 0x6f2.848e814 itc: 2 flg: E typ: 1 - DATA brn: 1 bdba: 0x7c09c89 ver: 0x01 opc: 0 inc: 0 exflg: 0 SQL> select to_number('11eeb','xxxxxxxx') from dual; TO_NUMBER('11EEB','XXXXXXXX') ----------------------------- 73451 SQL> select owner,object_name,subobject_name,object_type from dba_objects where data_object_id='73451'; OWNER ------------------------------ OBJECT_NAME -------------------------------------------------------------------------------- SUBOBJECT_NAME OBJECT_TYPE ------------------------------ ------------------- AHV8 TBL_IVR_LOG IVR_LOG_2012_MONTH04 TABLE PARTITION
验证是否真的坏块
SQL> select name from v$datafile where file#=32; NAME ------------------------------------------------------ /dev/rdb1_data27 [zwq_kfdb2:/home/oraeye]dbv file='/dev/rdb1_data27' blocksize=8192 DBVERIFY: Release 10.2.0.4.0 - Production on Fri Apr 13 15:33:10 2012 Copyright (c) 1982, 2007, Oracle. All rights reserved. DBVERIFY - Verification starting : FILE = /dev/rdb1_data27 DBVERIFY - Verification complete Total Pages Examined : 1048448 Total Pages Processed (Data) : 947357 Total Pages Failing (Data) : 0 Total Pages Processed (Index): 0 Total Pages Failing (Index): 0 Total Pages Processed (Other): 4756 Total Pages Processed (Seg) : 0 Total Pages Failing (Seg) : 0 Total Pages Empty : 96335 Total Pages Marked Corrupt : 0 Total Pages Influx : 0 Highest block SCN : 297329920 (1778.297329920) SQL> select count(*) from AHV8.TBL_IVR_LOG partition(IVR_LOG_2012_MONTH04); COUNT(*) ---------- 8798030
总结:很明显这次出现这个问题,因为内存中出现坏块导致,经过一段时间buffer cache中的坏块内容已经被老化,所以现在不能重现(甚至不用做任何操作)。如果内存中出现了坏块,而且还没有被老化掉,可以刷新data buffer;如果是数据块出现坏块,根据实际情况决定处理