长事务对rman备份undo表空间的影响:长事务会导致undo段无法释放,undo表空间使用量增加
1.dbm01通过zdlra备份undo,大小512g,备份耗时10个小时
UNDOTBS1 | 524288 | 54.29G | 10:33:50 |
2.查询活跃的长事务(事务持续时间超过1小时)
长事务会导致undo表空间的回滚段持续被占用,undo块频繁修改,rman增量备份时需要扫描更多变化的块。
SELECT s.sid, s.serial#, s.username, s.status,
t.start_time, t.used_ublk, t.used_urec,
(SYSDATE - t.start_date) * 24 * 60 AS duration_minutes
FROM v$transaction t
JOIN v$session s ON t.ses_addr = s.saddr
WHERE (SYSDATE - t.start_date) * 24 * 60 > 60
复制
3.确定事务的会话id和sql
SELECT
t.addr AS trans_addr,
t.start_time,
t.status,
t.used_ublk AS undo_blocks,
t.used_urec AS undo_records,
s.sid,
s.serial#,
s.username,
s.osuser,
s.machine,
s.program,
s.sql_id,
sq.sql_text
FROM
v$transaction t
JOIN
v$session s ON t.ses_addr = s.saddr
LEFT JOIN
v$sql sq ON s.sql_id = sq.sql_id
WHERE
to_date(t.start_time,'yyyy-mm-dd hh24:mi:ss') < SYSDATE - INTERVAL '1' HOUR;
复制
4.sql对应的表查询已经不存在了
5.查询undo表空间实时使用情况,状态等于active表示正在被事务占用。
SELECT tablespace_name, status, SUM(bytes)/1024/1024 AS used_mb
FROM dba_undo_extents
WHERE tablespace_name IN ('UNDOTBS1', 'UNDOTBS2')
GROUP BY tablespace_name, status;
复制
6.查看事务关联的undo段
SELECT
s.username,
t.xidusn AS undo_segment_number,
t.status,
t.start_time
FROM
v$transaction t
JOIN
v$session s ON t.ses_addr = s.saddr;
复制
7.终止事务
ALTER SYSTEM KILL SESSION '4126,63655' immediate;
active状态的被事务占用的已经消失。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1222次阅读
2025-03-13 11:40:53
Oracle RAC ASM 磁盘组满了,无法扩容怎么在线处理?
Lucifer三思而后行
739次阅读
2025-03-17 11:33:53
Oracle+Deepseek+Dify 实现数据库数据实时分析
bicewow
653次阅读
2025-03-06 09:41:49
【ORACLE】ORACLE19C在19.13版本前的一个严重BUG-24761824
DarkAthena
544次阅读
2025-03-04 14:33:31
Oracle避坑指南|同名表导出难题:如何精准排除指定用户下的表?
szrsu
503次阅读
2025-03-05 00:42:34
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
440次阅读
2025-03-13 14:38:19
Ogg23ai高手必看-MySQL Innodb Cluster跟oracle的亲密接触
曹海峰
437次阅读
2025-03-04 21:56:13
【ORACLE】char类型和sql优化器发生的“错误”反应
DarkAthena
399次阅读
2025-03-04 23:05:01
什么,oracle 主机用户被删了?原来是虚惊一场!
Lucifer三思而后行
394次阅读
2025-03-03 21:12:09
Oracle 如何修改 db_unique_name?强迫症福音!
Lucifer三思而后行
326次阅读
2025-03-12 21:27:56