MYSQL死锁问题java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction
数据库死锁分类
MySQL有三种锁的级别:页级、表级、行级。
表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般算法:
而产生死锁的原因/场景如下:
原理:就像多线程死锁一样,比如线程ab都想写文件t,a操作完T后没有释放锁,b就没法读T了,而且a自己也没法继续
原创
2021-05-25 09:22:45 ·
791 阅读 ·
0 评论