标签云
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,744)
- DB2 (22)
- MySQL (75)
- Oracle (1,591)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (162)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (68)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (28)
- Oracle备份恢复 (582)
- Oracle安装升级 (95)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (84)
- PostgreSQL (29)
- pdu工具 (5)
- PostgreSQL恢复 (9)
- SQL Server (30)
- SQL Server恢复 (11)
- TimesTen (7)
- 达梦数据库 (2)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (37)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (20)
-
最近发表
- pg创建gbk字符集库
- PostgreSQL运行日志管理
- ora-600 kdsgrp1 错误描述
- GAM、SGAM 或 PFS 页上存在页错误处理
- ORA-600 krhpfh_03-1208
- VMware勒索加密恢复(vmdk勒索恢复)
- ORA-39773: parse of metadata stream failed故障处理
- sql数据库备份失败—失败: 23(数据错误(循环冗余检查)
- vmdk文件被加密恢复(虚拟机文件加密)
- 差点被误操作的ORA-600 kcratr_nab_less_than_odr故障
- win平台19c 打patch遭遇2个小问题汇总
- pg单个数据库目录恢复-pdu恢复单个数据库目录数据
- pg删除数据恢复—pdu恢复pg delete数据
- .[OnlyBuy@cyberfear.com].REVRAC勒索mysql恢复
- 表dml操作权限授权给public,导致只读用户失效
- 21c数据库恢复遭遇ora-600 ktugct: corruption detected
- pg_control丢失/损坏处理
- 当前主流数据库版本服务支持周期-202503
- pg启动报invalid checkpoint record处理
- 删除redo导致ORA-00313 ORA-00312故障处理
月归档:五月 2013
监控asm disk磁盘性能
使用ASM的朋友估计都有一个困惑,ASM就是一个黑盒子,怎么才能够做到类似如裸设备或者文件系统一样,通过系统的命令(iostat)来监控其磁盘IO的运行性能.其实ORACLE在设计ASM的过程中,也就考虑到了这个需求,把磁盘相关的情况都记录到了ASM相关视图中v$asm_disk和v$asm_disk_stat(这两个视图功能相同,只是查询v$asm_disk需要每次访问磁盘头获取数据,v$asm_disk_stat是磁盘头存储在内存中的数据,查询v$asm_disk_stat对磁盘影响非常小),所以我们可以通过查询v$asm_disk_stat中的数据,然后做减法就可以获得asm disk某个时间段的磁盘io性能情况.ORACLE提供了相关工具叫做asmiostat用来监控,具体可以参考ASMIOSTAT Script to collect iostats for ASM disks [ID 437996.1]
确保TIMED_STATISTICS=TRUE
虽然是默认值,多检查无错,因为到该值为false之时READ_TIME/WRITE_TIME为0
[grid@xifenfei tmp]$ sqlplus / as sysdba SQL*Plus: Release 12.1.0.1.0 Production on Fri Feb 1 08:29:01 2013 Copyright (c) 1982, 2013, Oracle. All rights reserved. Connected to: Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production With the Automatic Storage Management option SQL> show parameter TIMED_STATISTICS NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ timed_statistics boolean TRUE
asmiostat使用
[grid@xifenfei tmp]$ ./asmiostat.sh help=y Invalid parameter: <interval> must be > 0; <count> must be >= 0 ./asmiostat.sh [-s ASM ORACLE_SID] [-h ASM ORACLE_HOME] [-g diskgroup] [<interval>] [<count>] Output: DiskPath - Path to ASM disk DiskName - ASM disk name Gr - ASM disk group number Dsk - ASM disk number Reads - Reads Writes - Writes AvRdTm - Average read time (in msec) AvWrTm - Average write time (in msec) KBRd - Kilobytes read KBWr - Kilobytes written AvRdSz - Average read size (in bytes) AvWrSz - Average write size (in bytes) RdEr - Read errors WrEr - Write errors
相关值说明
DiskPath - Path to ASM disk DiskName - ASM disk name Gr - ASM disk group number Dsk - ASM disk number Reads - 指定时间内I/O读请求次数 Writes - 指定时间内I/O写请求次数 AvRdTm - 平均每次I/O读请求所需时间 (in msec) AvWrTm - 平均每次I/O写请求所需时间 (in msec) KBRd - 指定时间内读操作的量(KB) KBWr - 指定时间内写操作的量(KB) AvRdSz - 平均每次I/O读请求得到的数据量(B) AvWrSz - 平均每次I/O写请求得到的数据量(B) RdEr - 指定时间内I/O读请求错误次数 WrEr - 指定时间内I/O写请求错误次数
asmiostat效果展示
[grid@xifenfei tmp]$ ./asmiostat.sh -s $ORACLE_SID -h $ORACLE_HOME -g DATA 1 3 Date: Fri Feb 1 08:31:45 CST 2013 Interval: 1 secs Disk Group: DATA DiskPath - DiskName Gr Dsk Reads Writes AvRdTm AvWrTm KBRd KBWr AvRdSz AvWrSz RdEr WrEr /dev/sdb - DATA_0000 1 0 0 0 0.0 0.0 0 0 0 0 0 0 Date: Fri Feb 1 08:31:47 CST 2013 Interval: 1 secs Disk Group: DATA DiskPath - DiskName Gr Dsk Reads Writes AvRdTm AvWrTm KBRd KBWr AvRdSz AvWrSz RdEr WrEr /dev/sdb - DATA_0000 1 0 4 3 0.6 1006.1 0 0 0 0 0 0 Date: Fri Feb 1 08:31:49 CST 2013 Interval: 1 secs Disk Group: DATA DiskPath - DiskName Gr Dsk Reads Writes AvRdTm AvWrTm KBRd KBWr AvRdSz AvWrSz RdEr WrEr /dev/sdb - DATA_0000 1 0 8 2 1.3 1.5 0 0 0 0 0 0
发表在 Oracle ASM
4 条评论
批量kill session实现脚本
在很多使用,因为各种原因,我们需要定时批量的kill一部分session,用来释放数据库部分资源,这里是因为bug导致temp不能正常释放,也可能是因为bug导致pga不释放,还有可能是因为太多inactive占用资源等等.我这里提供了两种方法来实现该功能
存储过程实现kill session
--创建记录表 CREATE TABLE kill_session_record ( kill_time DATE, kill_statement VARCHAR2 (1000) ) / --创建kill session存储过程 CREATE OR REPLACE PROCEDURE kill_inactive_session IS CURSOR c IS SELECT sid, serial# FROM v$session s WHERE s.status = 'INACTIVE' AND s.username = 'XIFENFEI'; k_sid NUMBER; k_serial NUMBER; BEGIN OPEN c; FETCH c INTO k_sid, k_serial; WHILE c%FOUND LOOP BEGIN EXECUTE IMMEDIATE 'ALTER SYSTEM DISCONNECT SESSION ''' || k_sid || ',' || k_serial || ''' IMMEDIATE'; INSERT INTO kill_session_record (kill_time, kill_statement) VALUES ( SYSDATE, 'ALTER SYSTEM DISCONNECT SESSION ''' || k_sid || ',' || k_serial || ''' IMMEDIATE'); EXCEPTION WHEN OTHERS THEN INSERT INTO kill_session_record (kill_time, kill_statement) VALUES ( SYSDATE, 'Failure:ALTER SYSTEM DISCONNECT SESSION ''' || k_sid || ',' || k_serial || ''' IMMEDIATE'); COMMIT; END; FETCH c INTO k_sid, k_serial; END LOOP; COMMIT; CLOSE c; END; / --设置job定时运行 DECLARE job NUMBER; BEGIN sys.DBMS_JOB.submit (job, what => 'kill_inactive_session;', next_date => SYSDATE, interval => 'TRUNC(SYSDATE + 1) +7/24'); COMMIT; DBMS_OUTPUT.put_line (job); END; /
如果是10GR2之前版本,需要把ALTER SYSTEM DISCONNECT SESSION 换成ALTER SYSTEM KILL SESSION
shell kill session
--shell脚本 # more kill_inactive_session.sh #!/bin/sh tmpfile0=/tmp/.kill_inactive_0 tmpfile1=/tmp/.kill_inactive_1 tmpfile2=/tmp/.kill_inactive_2 sqlplus / as sysdba <<EOF spool $tmpfile1 select 'kill time:'||to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') execute_time from dual; select p.spid,s.sid,s.serial# from v\$process p,v\$session s where s.paddr=p.addr and username='XIFENFEI' and s.status='INACTIVE'; spool off EOF cat $tmpfile1>>$tmpfile0 grep "^[0123456789]" $tmpfile1 |awk '{print $1}'>$tmpfile2 for x in `cat $tmpfile2` do kill -9 $x done rm $tmpfile1 $tmpfile2 --contab 调度 00 07 * * * /u01/script/kill_inactive_session.sh
两个脚本都可以在where中加一些限制条件,来实现你需要kill的会话.数据库级别kill相对系统级别来说更加温和点,建议优先考虑数据库级别kill session.如果要求立即释放资源,可能需要考虑系统级别.两中kill方式对于未提交且是inactive session都会被kill掉,然后回滚事务.
ORACLE 12C SQL语句中通过with 定义PL/SQL 函数
在ORACLE 12C支持在sql语句中编写函数,用来实现sql语句操作需要使用函数的部分功能,该功能对于你不想在数据库中新建函数 or 你的库是read only模式下要使用新函数实现某种功能,可以通过这种方法实现,增加了ORACLE数据库灵活点
SQL> select * from v$version; BANNER CON_ID -------------------------------------------------------------------------------- ---------- Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production 0 PL/SQL Release 12.1.0.1.0 - Production 0 CORE 12.1.0.1.0 Production 0 TNS for Linux: Version 12.1.0.1.0 - Production 0 NLSRTL Version 12.1.0.1.0 - Production 0
测试过程创建一个简单函数,用来判断输入数据值是否是数字,如果是数字输出Y,如果不是输出N.
如果是12C以前的数据库,需要事先创建一个函数,然后通过select语句条用;但是在12C中直接通过一条select语句解决
SQL> with function Is_Number 2 (x in varchar2) return varchar2 is 3 Plsql_Num_Error exception; 4 pragma exception_init(Plsql_Num_Error, -06502); 5 begin 6 if (To_Number(x) is NOT null) then 7 return 'Y'; 8 else 9 return ''; 10 end if; 11 exception 12 when Plsql_Num_Error then 13 return 'N'; 14 end Is_Number; 15 select is_number('www.xifenfei.com') is_num from dual; 16 / IS_NUM -------------------------------------------------------------------------------- N
发表在 ORACLE 12C
评论关闭