云数据库 GAUSSDB(FOR MYSQL)-持锁长事务导致后续业务报等锁超时的解决办法:原因分析

时间:2024-09-11 14:21:52

原因分析

  1. 查看监控指标“行锁花费时间”,监控到行锁等待时间较长,说明该系统出现过锁冲突的现象。

    监控指标详细内容请参考查看监控指标

  2. 登录实例,执行如下SQL,查看系统当前存在的长事务,以及事务持有的行锁信息。
    select trx_mysql_thread_id, trx_id, trx_state, trx_started, trx_tables_locked, trx_rows_locked, trx_isolation_level, trx_query, trx_operation_state from information_schema.innodb_trx order by trx_started;

    • information_schema.innodb_trx表包含了当前innodb内部正在运行的事务信息。
    • trx_started:表示事务的开始时间,用来判断当前事务是否是长事务,当前时间减去开始时间就是事务的执行时间。
    • trx_state :表示当前事务的状态,取值如下:
      • RUNNING:运行。
      • LOCK WAIT:等待锁。

        如果事务当前的状态是LOCK WAIT,即表示事务持有行锁。

      • ROLLING BACK:正在回滚。
      • COMMITTING:正在提交。
support.huaweicloud.com/gaussdbformysql_faq/gaussdbformysql_faq_0096.html