[Oracle 故障处理]记一次undo表空间使用率99%的问题
时间:2022-07-23
本文章向大家介绍[Oracle 故障处理]记一次undo表空间使用率99%的问题,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
这个专题讲一些日常运维的异常处理
今天讲一次undo表空间使用率99%的问题处理
1. 现象
公司一套11g的RAC undo表空间使用率在99%,一直不会下降,由于我们用的是自动UNDO空间管理,可能的原因可能就是由于会话一直在利用UNDO里面的内容
2. 原因查找
2.1 查询undo空间使用率
SELECT round(((SELECT (NVL(SUM(bytes), 0))FROM dba_undo_extents
WHERE tablespace_name =
(select value from v$parameter
where lower(name) = 'undo_tablespace')
AND status IN ('ACTIVE', 'UNEXPIRED')) * 100) /
(SELECT SUM(bytes) FROM dba_data_files
WHERE tablespace_name =
(select value from v$parameter
where lower(name) = 'undo_tablespace')), 2) PCT_INUSE
FROM dual
2.2 查看当前事务占用的undo大小
SELECT s.sid, s.username, s.program, t.name,
t.used_ublk * (SELECT value/1024/1024 FROM v$system_parameter2 WHERE name='db_block_size') as "undoMB",
flag,space,recursive,noundo,ptx, t.start_time start_mmddyy, t.status
FROM vtransaction t, vsession s
WHERE t.addr=s.taddr(+)
ORDER BY t.used_ublk DESC;
从这里我们会看到START_MMODYY栏位有一些会话是很多天前
继而通过SID获取HASH_VALUE,然后查看具体的SQL语句
发现这些语句为通过DBLINK来获取数据的语句
联想到这个远程数据库前几天发生故障
这里可以肯定是由于分布式查询导致的问题
2.3查看undo表空间各个时间段retention大小
select to_char(begin_time, 'DD-MON-RR HH24:MI') begin_time,
to_char(end_time, 'DD-MON-RR HH24:MI') end_time,
tuned_undoretention
from v$undostat
order by end_time;
3.问题处理
3.1 查找SQL语句
找到了源头我们先看下这个会话对应的SQL语句
select sid,serial#, decode(sql_hash_value,0,prev_hash_value,sql_hash_value) from v$session where sid=277
这里我们可以间隔一段时间后查看 hash_value是否变化
最后我们查询其对应的语句
select sql_text from v$sqltext where hash_value=195271222 order by piece;
如果为空,表示可能这个会话处于假死状态
3.2 结束会话
首先我们采用常规的命令来杀死会话
alter system kill session '277,35'
发现杀不掉,那么我们采用杀死进程的方式
首先找到该会话对应的进程
select b.spid from vsession a,vprocess b where a.PADDR=b.addr and a.SID='277'
接下来查询该进程的开始时间
发现时间为10月24日,和故障发生的点契合
这时我们放心的杀死他
kill -9 25163
4. 处理完成
杀完之后我们等待一段时间后查询UNDO使用率,发现已经下去了
这时处理完成
5.横向展开
从这个异常我们看出一些分布式的查询可能导致会话异常hang住,从而有个各种问题,我们平时可以通过监控一些长时间运行的会话来确保这个问题不会发生
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Laravel5.0+框架邮件发送功能实现方法图文与实例详解
- Ajax+PHP实现的删除数据功能示例
- tensorflow下的图片标准化函数per_image_standardization用法
- 浅析Python面向对象编程
- Python单元测试及unittest框架用法实例解析
- Tensorflow中批量读取数据的案列分析及TFRecord文件的打包与读取
- YII框架实现自定义第三方扩展操作示例
- 在Tensorflow中实现leakyRelu操作详解(高效)
- Django def clean()函数对表单中的数据进行验证操作
- Python3爬虫中Splash的知识总结
- Laravel框架自定义公共函数的引入操作示例
- PHP PDOStatement::setFetchMode讲解
- Python QTimer实现多线程及QSS应用过程解析
- PHP count()函数讲解
- Laravel中9个不经常用的小技巧汇总