mysql锁和死锁
来源:互联网 发布:virtualbox mac怎么用 编辑:程序博客网 时间:2024/04/27 19:56
MyISAM和MEMORY存储引擎采用的是表级锁table-level locking
BDB存储引擎采用的是页面锁page-level locking,但也支持表级锁
InnoDB存储引擎既支持行级锁row-level locking,也支持表级锁,但默认情况下是采用行级锁
表级锁 开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低
行级锁 开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高
页面锁 开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般
仅从锁的角度来说:
表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用
行级锁则更适合于有大量按索引条件并发更新少量不同数据,同时又有并发查询的应用,如一些在线事务处理系统
死锁
所谓死锁<DeadLock>: 是指两个或两个以上的进程在执行过程中,
因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.
此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等竺的进程称为死锁进程.
表级锁不会产生死锁.所以解决死锁主要还是真对于最常用的InnoDB.
在遇到问题时
先执行show processlist找到死锁线程号.然后Kill processNo
当然主要解决还是需要去看一下具体的操作.可能产生死锁
show engine innodb status检查引擎状态 ,可以看到哪些语句产生死锁
然后就是解决了.
怎么解决还是要看具体什么问题.
0 0
- mysql锁和死锁
- mysql锁和死锁
- mysql锁和死锁
- mysql 如何预防死锁和处理死锁
- mysql查询表死锁和结束死锁
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- mysql 查询表死锁 和结束死锁的表步骤
- 活锁和死锁
- 死锁和活锁
- 死锁和活锁
- mysql:innodb锁与死锁
- MySQL锁系列 之 死锁
- MFC 串口通讯程序
- finally一定会执行吗?
- 蓝桥杯试题集 算法训练 区间k大数查询
- 子网划分全面学习
- [Java、Php、Python、Flash、C++、Go、Flash开发工具大集合!!!][ide/最全]
- mysql锁和死锁
- Let the Balloon Rise
- MindManger快捷键
- FTP协议
- Android 聊天软件开发
- Python菜鸟学习手册05----控制流
- VC连接mysql数据库开发的与64位win7不兼容解决方案
- 浅析WebMail安全
- Leetcode - Longest Palindromic Substring