Uploaded image for project: 'MariaDB Server'
  1. MariaDB Server
  2. MDEV-10104

Table lock race condition with replication

Details

    Description

      We have a MariaDB server that sometimes seems to get an indefinite table lock. The only way to solve it is to kill MariaDB and restart it. It "randomly happens", so I suspect it may be a race condition. The replication thread get's stuck in state "After opening tables". The lock seems to be caused by a query on an unrelated database with 3 million MyISAM tables (not receiving data via replication) in state "Opening tables". These databases are completely separated, so they shouldn't cause a lock between each other.

      Processlist shows:

      root@server ~ # mysql -e "show full processlist"
      +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
      | Id       | User                 | Host                  | db                   | Command | Time    | State                            | Info                                                  | Progress |
      +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
      |        2 | system user          |                       | NULL                 | Connect | 1116538 | Waiting for master to send event | NULL                                                  |    0.000 |
      |        3 | system user          |                       | replication_database               | Connect |  264121 | After opening tables             | COMMIT                                                |    0.000 |
      | 37332419 | user1                 | localhost             | large_database          | Killed  |  264121 | Opening tables                   | DELETE FROM `my_domain` WHERE date<'2016-04-29' |    0.000 |
      | 48692447 | root                 | localhost             | NULL                 | Query   |       0 | init                             | show full processlist                                 |    0.000 |
      +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
      root@server ~ # 
      

      Attachments

        1. global_status.txt
          26 kB
        2. patch
          6 kB
        3. strace_170419_1.txt
          71 kB
        4. strace_170419_2.txt
          68 kB
        5. strace_170425.txt
          605 kB
        6. strace.txt
          608 kB

        Activity

          dreas Dreas van Donselaar created issue -
          elenst Elena Stepanova made changes -
          Field Original Value New Value
          Description We have a MariaDB server that sometimes seems to get an indefinite table lock. The only way to solve it is to kill MariaDB and restart it. It "randomly happens", so I suspect it may be a race condition. The replication thread get's stuck in state "After opening tables". The lock seems to be caused by a query on an unrelated database with 3 million MyISAM tables (not receiving data via replication) in state "Opening tables". These databases are completely separated, so they shouldn't cause a lock between each other.

          Processlist shows:
          ===
          root@server ~ # mysql -e "show full processlist"
          +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
          | Id | User | Host | db | Command | Time | State | Info | Progress |
          +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
          | 2 | system user | | NULL | Connect | 1116538 | Waiting for master to send event | NULL | 0.000 |
          | 3 | system user | | replication_database | Connect | 264121 | After opening tables | COMMIT | 0.000 |
          | 37332419 | user1 | localhost | large_database | Killed | 264121 | Opening tables | DELETE FROM `my_domain` WHERE date<'2016-04-29' | 0.000 |
          | 48692447 | root | localhost | NULL | Query | 0 | init | show full processlist | 0.000 |
          +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
          root@server ~ #
          ===
          We have a MariaDB server that sometimes seems to get an indefinite table lock. The only way to solve it is to kill MariaDB and restart it. It "randomly happens", so I suspect it may be a race condition. The replication thread get's stuck in state "After opening tables". The lock seems to be caused by a query on an unrelated database with 3 million MyISAM tables (not receiving data via replication) in state "Opening tables". These databases are completely separated, so they shouldn't cause a lock between each other.

          Processlist shows:

          {code:sql}
          root@server ~ # mysql -e "show full processlist"
          +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
          | Id | User | Host | db | Command | Time | State | Info | Progress |
          +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
          | 2 | system user | | NULL | Connect | 1116538 | Waiting for master to send event | NULL | 0.000 |
          | 3 | system user | | replication_database | Connect | 264121 | After opening tables | COMMIT | 0.000 |
          | 37332419 | user1 | localhost | large_database | Killed | 264121 | Opening tables | DELETE FROM `my_domain` WHERE date<'2016-04-29' | 0.000 |
          | 48692447 | root | localhost | NULL | Query | 0 | init | show full processlist | 0.000 |
          +----------+----------------------+-----------------------+----------------------+---------+---------+----------------------------------+-------------------------------------------------------+----------+
          root@server ~ #
          {code}
          elenst Elena Stepanova made changes -
          Labels need_feedback
          elenst Elena Stepanova made changes -
          Labels need_feedback
          elenst Elena Stepanova made changes -
          Labels need_feedback
          elenst Elena Stepanova made changes -
          Fix Version/s N/A [ 14700 ]
          Resolution Incomplete [ 4 ]
          Status Open [ 1 ] Closed [ 6 ]
          dreas Dreas van Donselaar made changes -
          Attachment global_status.txt [ 42928 ]
          elenst Elena Stepanova made changes -
          Assignee Elena Stepanova [ elenst ]
          Resolution Incomplete [ 4 ]
          Status Closed [ 6 ] Stalled [ 10000 ]
          elenst Elena Stepanova made changes -
          Assignee Elena Stepanova [ elenst ]
          elenst Elena Stepanova made changes -
          Fix Version/s N/A [ 14700 ]
          elenst Elena Stepanova made changes -
          Labels need_feedback
          elenst Elena Stepanova made changes -
          Assignee Elena Stepanova [ elenst ]
          dreas Dreas van Donselaar made changes -
          Attachment strace.txt [ 43385 ]
          dreas Dreas van Donselaar made changes -
          Attachment strace_170419_2.txt [ 43561 ]
          Attachment strace_170419_1.txt [ 43562 ]
          elenst Elena Stepanova made changes -
          Labels need_feedback
          elenst Elena Stepanova made changes -
          Assignee Elena Stepanova [ elenst ] Michael Widenius [ monty ]
          dreas Dreas van Donselaar made changes -
          Attachment strace_170425.txt [ 43581 ]
          elenst Elena Stepanova made changes -
          Labels need_feedback
          monty Michael Widenius made changes -
          Attachment patch [ 43617 ]
          monty Michael Widenius made changes -
          Status Stalled [ 10000 ] In Progress [ 3 ]
          monty Michael Widenius made changes -
          issue.field.resolutiondate 2017-05-05 15:27:57.0 2017-05-05 15:27:57.607
          monty Michael Widenius made changes -
          Component/s Storage Engine - Aria [ 10126 ]
          Component/s Locking [ 10900 ]
          Fix Version/s 10.0.31 [ 22501 ]
          Resolution Fixed [ 1 ]
          Status In Progress [ 3 ] Closed [ 6 ]
          serg Sergei Golubchik made changes -
          Workflow MariaDB v3 [ 75740 ] MariaDB v4 [ 150447 ]

          People

            monty Michael Widenius
            dreas Dreas van Donselaar
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved:

              Git Integration

                Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.