当前位置: 首页 > news >正文

【DB2】Maxlocks和防止锁升级

数据库在对行操作的时候,为了避免多个作业互相覆盖影响数据准确性,在进行操作(尤其是写操作)的时候会上锁,同一时间只有一个作业可以修改数值

对行上锁,为了记录锁的信息,所以会占用一定的内存空间,一旦行锁太多的话不仅占用巨大内存空间,还会反复对行上锁,如果一个事务要同时修改10万行的话,就要执行十万次次行上锁,所以这时候我们希望能够升级成表锁,让他操作完之后再释放给其他应用使用,同样的表锁也会升级为数据库锁。

但是如果很快就锁升级的话,明明可以几个应用同时操作,却硬让别人等待,这也是不优雅的,所以需要考虑如何设置locklist和maxlocks

参考

maxlocks IBM Documentation

locklist IBM Documentation

db2pd IBM Documentation

self_tuning_mem 为ON的时候会自动对locklist和maxlocks进行调整

锁升级发生的条件

1 所有的应用加起来达到了locklist上限

2 单一应用的锁达到了maxlocks限制

那也就是取反的事情,当这两个条件都不达到的时候,就可以避免发生锁升级

计算


所有应用的锁总数 小于        locklist * 4096 / locksize
并且锁数最多的应用的锁数 小于  ( maxlocks * locklist * 4096 ) / (100 * locksize)

同时满足的话就不会发生锁升级

假设

最大的应用会同时持有的锁数  = 10 0000

设置

maxlocks = 10

令不等式
10 0000  小于   ( 10 * locklist * 4096)/ (100 * 128) 

成立,就可以反过来算出locklist的最小值为 31250

所以locklist就可以设置为稍微高于31250的值

http://www.lryc.cn/news/268685.html

相关文章:

  • 网工内推 | 网络服务工程师,HCIE认证优先,带薪年假,年终奖
  • ​TrustZone之可信固件
  • Visual Studio 2013 中创建一个基于 Qt 的动态链接库:并在MFC DLL程序中使用
  • 云计算:OpenStack 配置云主机实例的资源实现内网互通
  • Android原生实现单选
  • 为什么需要对数值类型的特征做归一化?
  • ARM 点灯
  • CamSim相机模拟器:极大加速图像处理开发与验证过程
  • Google Ad帐号被封?代理IP和电子邮件可能是原因
  • EfficientNet
  • 百度每天20%新增代码由AI生成,Comate SaaS服务8000家客户 采纳率超40%
  • 产品管理-学习笔记-版本的划分
  • 编程笔记 html5cssjs 004 我的第一个页面
  • 为实体服务器配置Ubuntu
  • 单例模式的双重检查锁定是什么?
  • hyper-v ubuntu 3节点 k8s集群搭建
  • postman进阶使用
  • errors包返回堆栈信息的性能测试
  • 力扣热题100道-哈希篇
  • YOLOv7+Pose姿态估计+tensort部署加速
  • gitee+picgo+typora图床搭建
  • Flink项目实战篇 基于Flink的城市交通监控平台(上)
  • thinkcmf 文件包含 x1.6.0-x2.2.3 已亲自复现
  • 本地部署 text-generation-webui
  • C语言实验1:C程序的运行环境和运行C程序的方法
  • 「微服务」微服务架构中的数据一致性
  • ARCGIS PRO SDK 要素空间关系
  • Python面向对象高级与Python的异常、模块以及包管理
  • Python 爬取 哔站视频弹幕 并实现词云图可视化
  • BP神经网络详细原理,BP神经网络训练界面详解,基于BP神经网络的公司财务风险分类