Mysql有多少种锁,怎么写加锁的SQL语句( 六 )


如果发现锁争用比较严重,如InnoDB_row_lock_waits和InnoDB_row_lock_time_avg的值比较高,还可以通过设置InnoDB Monitors 来进一步观察发生锁冲突的表、数据行等,并分析锁争用的原因 。
锁冲突的表、数据行等,并分析锁争用的原因 。具体方法如下:
mysql> create table InnoDB_monitor(a INT) engine=InnoDB;然后就可以用下面的语句来进行查看:
mysql> show engine InnoDB status;监视器可以通过发出下列语句来停止查看:
mysql> drop table InnoDB_monitor;设置监视器后,会有详细的当前锁等待的信息,包括表名、锁类型、锁定记录的情况等,便于进行进一步的分析和问题的确定 。可能会有读者朋友问为什么要先创建一个叫InnoDB_monitor的表呢?因为创建该表实际上就是告诉InnoDB我们开始要监控他的细节状态了,然后InnoDB就会将比较详细的事务以及锁定信息记录进入MySQL的errorlog中,以便我们后面做进一步分析使用 。打开监视器以后,默认情况下每15秒会向日志中记录监控的内容,如果长时间打开会导致.err文件变得非常的巨大,所以用户在确认问题原因之后,要记得删除监控表以关闭监视器,或者通过使用“--console”选项来启动服务器以关闭写日志文件 。




推荐阅读