Mysql(1)并发控制
来源:互联网 发布:电脑编程 编辑:程序博客网 时间:2024/06/05 04:13
1、读写锁
读锁是共享锁,相互不阻塞的。
写锁是排他锁,一个写锁会阻塞其他的写锁和读锁。
2、锁粒度
所谓的锁策略,就是在锁的开销和数据的安全性之间寻求平衡,这种平衡当然也会影响到性能。大多数商用数据库系统没有提供更多的选择,一般都是在表上施加行级锁,并加以各种复杂的方式来实现,以便在锁比较多的情况下尽可能地提供更好的性能。
Mysql每种存储引擎都可以实现自己的锁策略和锁粒度。
锁策略一:表锁
表锁是Mysql中最基本的锁策略,并且开销是最小的。一个用户对表进行写操作前,需要先获取写锁,这会阻塞其他用户对表的写和读操作。
写锁也比读锁有更高的优先级,因此一个写锁请求可能会被插入到读锁队列的前面
尽管存储引擎可以管理自己的锁,mysql本身还是会使用各种有效的表锁来实现不同的目的。例如,服务器会为诸如alter table之类的语句使用表锁,而忽略存储引擎的锁机制。
锁策略二:行级锁
行级锁可以最大程度地支持并发处理,同时也带来 最大的锁开销。行级锁只在存储引擎层实现,而mysql服务器层没有实现。服务器层完全不了解存储引擎的锁实现。
阅读全文
0 0
- Mysql(1)并发控制
- Mysql并发控制
- Mysql并发控制
- Mysql并发控制
- MySQL并发控制
- 【MySQL】并发控制
- 【MySQL】并发控制
- MySQL并发控制
- 并发控制 mysql InnoDB表锁
- 并发控制 mysql MyISAM表锁
- 并发控制 mysql MyISAM表锁
- 并发控制 mysql InnoDB表锁
- mysql多版本并发控制
- MySQL读书笔记-并发控制
- 并发控制 mysql MyISAM表锁
- MySQL读书笔记-并发控制
- 【MySQL】多版本并发控制
- MySQL 引擎 和 InnoDB并发控制 简介
- 关于java中创建对象的5中方式
- kotlin学习记录以及一些疑问
- json格式
- 64位Ubuntu14.04+GTX960安装CUDA8.0及cudnn
- Kotlin 博客 companion object 伴生对象,getter,setter,内部,局部,匿名类,可变参数
- Mysql(1)并发控制
- Failed to load ApplicationContext
- git
- [HDU-5972] [Problem B](16亚洲区域赛大连站)bitset优化(shiftand算法)
- django rest framework 外键序列化方法与问题总结
- java虚拟机---垃圾收集器
- 可分离变量的微分方程
- 网易雷火盘古实习2018编程题
- android am命令用法