0

0

如何解决RAC环境中全局锁争用_实例间行锁与HW高水位线竞争优化

P粉602998670

P粉602998670

发布时间:2026-03-15 14:42:32

|

875人浏览过

|

来源于php中文网

原创

RAC全局锁争用90%以上源于数据分布与业务访问模式不匹配共享缓存架构,需优先检查v$ges_enqueue定位HW/TX锁阻塞链,控制段扩展节奏、合理分区、统一UNDO及私网配置。

ORA-600 [kjbmprlst:shadow] 或大量 gc buffer busy acquire 等待?先查锁类型和持有者

rac 中的全局锁争用,90% 以上不是应用层死锁,而是底层资源同步机制暴露了设计或负载问题。直接看 v$ges_enqueuev$lock 混合视图比猜更有效。

  • v$ges_enqueue 显示跨实例持有的全局队列(如 TXHWUS),重点关注 REQUESTEDGRANT_LEVEL 不一致的行
  • 别只盯着 TX 行锁——HW 队列争用常被误判为“慢 SQL”,实际是并发 insert 触发高水位线推进冲突
  • select * from v$ges_blocking_enqueue 快速定位阻塞链起点,它比 gv$sessionblocking_session 更准,尤其对瞬时 GC 等待

INSERT 高并发下 HW 锁飙升?控制段扩展节奏比加 freelist 有用

Oracle 11gR2+ 默认启用 ASSM 后,HW 队列争用本质是多个实例同时申请新区(extent)或推进段高水位线(HWM)导致的跨节点协调开销。freelist 在 RAC 下几乎无效,反会放大争用。

  • 优先用 ALTER TABLE ... STORAGE (INITIAL 8M NEXT 8M) 避免频繁 extent 分配;小表可预分配 10–20 个 extent
  • 对日志表、流水表等纯追加场景,启用 NOLOGGING + APPEND 并配合分区(按天/按月),把 HWM 推进限制在单个子分区内部
  • 禁用 ALTER TABLE ... SHRINK SPACE —— 它会强制重置 HWM 并触发全表范围的全局锁同步,RAC 下极易卡住

TX 行锁跨实例传播慢?检查 undo 表空间和 _gc_read_mostly_locking 隐含参数

当事务在实例 A 修改某行、实例 B 同时查询该行(且未提交),B 实例需从 A 获取一致性读镜像,这依赖 undo 数据的远程访问路径。延迟或失败会表现为 gc cr block busy 或长时间 enq: TX - row lock contention

  • 确认所有实例使用同一共享 UNDO 表空间(非 local undo),且 undo_retention 设置合理(至少 > 最长查询预计运行时间)
  • 若业务以只读为主、写入集中,可尝试开启 _gc_read_mostly_locking=TRUE(需 Oracle 12.1.0.2+),它让读多写少对象的块在本地缓存中降级为“只读锁定模式”,减少 TX 全局锁升级频率
  • 避免在 RAC 中使用 SELECT FOR UPDATE NOWAIT 做乐观锁兜底——NOWAIT 不会跳过全局锁协商,反而因快速失败重试加剧 GC 流量

AWR 报告里 gc current/cr block 2-way 时间异常高?先隔离网络与存储路径

GC 等待时间高,不等于数据库配置有问题。RAC 节点间通信走私网(通常是万兆 IB 或高速以太),一旦交换机丢包、MTU 不匹配或存储响应抖动,gc current block 2-way 就会暴涨,掩盖真实锁逻辑问题。

灵机语音
灵机语音

灵机语音

下载
  • oifcfg getif 确认私网接口绑定正确,再用 ping -M do -s 8972 <peer_ip> 测试 jumbo frame 是否通(Oracle 默认 GC 包大小约 9KB)
  • GV$CLUSTER_INTERCONNECTS 确认 interconnect 使用的是专用网卡,而非混用 public 网络
  • 对比 DBA_HIST_SYSSTATgc cr blocks receivedgc current blocks served 的比率:若远高于 1.5,说明大量块在节点间反复传递,大概率是应用未合理分区数据(如所有实例都在更新同一张维度表主键区间)

HW 和 TX 锁背后真正难调的,从来不是参数,而是数据分布与业务访问模式是否天然适配 RAC 的共享缓存架构。一个没做 range 分区的订单表,在 4 节点 RAC 上跑 OLTP,再怎么调 _gc_policy_time 都是掩耳盗铃。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1135

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2214

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1723

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

586

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

441

2024.04.29

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号