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

Magento randomly crashes MariaDB 10.2 on ADD CONSTRAINT

    XMLWordPrintable

Details

    Description

      I've seen many similar random crashes from different servers, but I am not able to reproduce this. I understand that this is impossible to debug, but maybe someone other has similar problem as magento is pretty popular software.

      Query that causes crash is always the same (Number in table name differs):

      ALTER TABLE `catalog_product_flat_1` ADD CONSTRAINT `FK_CAT_PRD_FLAT_1_ENTT_ID_CAT_PRD_ENTT_ENTT_ID` FOREIGN KEY (`entity_id`) REFERENCES `catalog_product_entity` (`entity_id`) ON DELETE CASCADE ON UPDATE CASCADE
      

      Full log, while crash happens:

      2018-06-11 13:00:21 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      ...
      2018-06-11 13:00:22 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      2018-06-11 13:00:39 139771731450176 [ERROR] InnoDB:  Index for key no 1 mysql name IDX_CATALOG_PRODUCT_FLAT_18_TYPE_ID InnoDB name IDX_CATALOG_PRODUCT_FLAT_1_TYPE_ID for table replaced_databasename/#sql-369b_504e7
      2018-06-11 13:00:39 139771731450176 [Note] InnoDB:  Index for key no 1 mysql name IDX_CATALOG_PRODUCT_FLAT_18_TYPE_ID InnoDB name PRIMARY for table replaced_databasename/#sql-369b_504e7
      2018-06-11 13:00:39 139771731450176 [Note] InnoDB:  Index for key no 1 mysql name IDX_CATALOG_PRODUCT_FLAT_18_TYPE_ID InnoDB name IDX_CATALOG_PRODUCT_FLAT_1_TYPE_ID for table replaced_databasename/#sql-369b_504e7
      2018-06-11 13:00:39 139771731450176 [Note] InnoDB:  Index for key no 1 mysql name IDX_CATALOG_PRODUCT_FLAT_18_TYPE_ID InnoDB name IDX_CATALOG_PRODUCT_FLAT_1_ATTRIBUTE_SET_ID for table replaced_databasename/#sql-369b_504e7
      2018-06-11 13:00:39 139771731450176 [Note] InnoDB:  Index for key no 1 mysql name IDX_CATALOG_PRODUCT_FLAT_18_TYPE_ID InnoDB name IDX_CATALOG_PRODUCT_FLAT_1_NAME for table replaced_databasename/#sql-369b_504e7
      2018-06-11 13:00:39 139771731450176 [Note] InnoDB:  Index for key no 1 mysql name IDX_CATALOG_PRODUCT_FLAT_18_TYPE_ID InnoDB name IDX_CATALOG_PRODUCT_FLAT_1_PRICE for table replaced_databasename/#sql-369b_504e7
      2018-06-11 13:00:39 0x7f1f24671940  InnoDB: Assertion failure in file /usr/src/redhat/BUILD/zone_mariadb/mariadb-10.2.15/storage/innobase/handler/ha_innodb.cc line 9609
      InnoDB: Failing assertion: ut_strcmp(index->name, key->name) == 0
      InnoDB: We intentionally generate a memory trap.
      InnoDB: Submit a detailed bug report to https://jira.mariadb.org/
      InnoDB: If you get repeated assertion failures or crashes, even
      InnoDB: immediately after the mysqld startup, there may be
      InnoDB: corruption in the InnoDB tablespace. Please refer to
      InnoDB: https://mariadb.com/kb/en/library/xtradbinnodb-recovery-modes/
      InnoDB: about forcing recovery.
      180611 13:00:39 [ERROR] mysqld got signal 6 ;
      This could be because you hit a bug. It is also possible that this binary
      or one of the libraries it was linked against is corrupt, improperly built,
      or misconfigured. This error can also be caused by malfunctioning hardware.
       
      To report this bug, see https://mariadb.com/kb/en/reporting-bugs
       
      We will try our best to scrape up some info that will hopefully help
      diagnose the problem, but since we have already crashed, 
      something is definitely wrong and this may fail.
       
      Server version: 10.2.15-MariaDB-log
      key_buffer_size=4294967296
      2018-06-11 13:00:39 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      read_buffer_size=2097152
      max_used_connections=49
      max_threads=1502
      thread_count=56
      It is possible that mysqld could use up to 
      key_buffer_size + (read_buffer_size + sort_buffer_size)*max_threads = 19606762 K  bytes of memory
      Hope that's ok; if not, decrease some variables in the equation.
       
      Thread pointer: 0x14814c008
      Attempting backtrace. You can use the following information to find out
      where mysqld died. If you see no messages after this, something went
      terribly wrong...
      stack_bottom = 0x7f1f24671058 thread_stack 0x49000
      2018-06-11 13:00:39 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      ...
      /opt/zone/sbin/mysqld(my_print_stacktrace+0x24)[0xdc2414]
      2018-06-11 13:00:39 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      ...
      2018-06-11 13:00:39 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      /opt/zone/sbin/mysqld(handle_fatal_signal+0x513)[0x7c8ba3]
      2018-06-11 13:00:39 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      /lib64/libpthread.so.0[0x7f2144695ca0]
      /lib64/libc.so.6(gsignal+0x35)[0x7f21426c4fc5]
      /lib64/libc.so.6(abort+0x110)[0x7f21426c6a70]
      /opt/zone/sbin/mysqld[0xb3f328]
      /opt/zone/sbin/mysqld[0x9c1b2a]
      /opt/zone/sbin/mysqld[0x9cc419]
      /opt/zone/sbin/mysqld[0x9d0f30]
      /opt/zone/sbin/mysqld(_ZN7handler7ha_openEP5TABLEPKcij+0x3f)[0x7cc07f]
      /opt/zone/sbin/mysqld(_Z21open_table_from_shareP3THDP11TABLE_SHAREPKcjjjP5TABLEb+0xa29)[0x6b1ad9]
      /opt/zone/sbin/mysqld(_ZN3THD20open_temporary_tableEP15TMP_TABLE_SHAREPKcb+0x81)[0x763b31]
      2018-06-11 13:00:40 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      /opt/zone/sbin/mysqld(_ZN3THD25create_and_open_tmp_tableEP10handlertonP34st_mysql_const_unsigned_lex_stringPKcS5_S5_b+0x4a)[0x7642ea]
      2018-06-11 13:00:40 139771732965696 [ERROR] Invalid (old?) table or database name '#sql-369b_504e7'
      /opt/zone/sbin/mysqld(_Z17mysql_alter_tableP3THDPcS1_P14HA_CREATE_INFOP10TABLE_LISTP10Alter_infojP8st_orderb+0x44e3)[0x68b1d3]
      /opt/zone/sbin/mysqld(_ZN19Sql_cmd_alter_table7executeEP3THD+0x60d)[0x6dcf5d]
      /opt/zone/sbin/mysqld(_Z21mysql_execute_commandP3THD+0x111e)[0x5f168e]
      /opt/zone/sbin/mysqld(_Z11mysql_parseP3THDPcjP12Parser_statebb+0x3c0)[0x5fb1b0]
      /opt/zone/sbin/mysqld(_Z16dispatch_command19enum_server_commandP3THDPcjbb+0x2ccb)[0x5fe6db]
      /opt/zone/sbin/mysqld(_Z10do_commandP3THD+0x15b)[0x5feabb]
      /opt/zone/sbin/mysqld(_Z24do_handle_one_connectionP7CONNECT+0x205)[0x6d9585]
      /opt/zone/sbin/mysqld(handle_one_connection+0x41)[0x6d9721]
      /opt/zone/sbin/mysqld[0xd39c01]
      /lib64/libpthread.so.0[0x7f214468d83d]
      /lib64/libc.so.6(clone+0x6d)[0x7f2142769fdd]
       
      Trying to get some variables.
      Some pointers may be invalid and cause the dump to abort.
      Query (0x1483dc820): ALTER TABLE `catalog_product_flat_18` ADD CONSTRAINT `FK_CAT_PRD_FLAT_18_ENTT_ID_CAT_PRD_ENTT_ENTT_ID` FOREIGN KEY (`entity_id`) REFERENCES `catalog_product_entity` (`entity_id`) ON DELETE CASCADE ON UPDATE CASCADE
       
      Connection ID (thread ID): 328935
      Status: NOT_KILLED
       
      Optimizer switch: index_merge=on,index_merge_union=on,index_merge_sort_union=on,index_merge_intersection=on,index_merge_sort_intersection=off,engine_condition_pushdown=off,index_condition_pushdown=on,derived_merge=on,derived_with_keys=on,firstmatch=on,loosescan=on,materialization=on,in_to_exists=on,semijoin=on,partial_match_rowid_merge=on,partial_match_table_scan=on,subquery_cache=on,mrr=off,mrr_cost_based=off,mrr_sort_keys=off,outer_join_with_cache=on,semijoin_with_cache=on,join_cache_incremental=on,join_cache_hashed=on,join_cache_bka=on,optimize_join_buffer_size=off,table_elimination=on,extended_keys=on,exists_to_in=on,orderby_uses_equalities=on,condition_pushdown_for_derived=on
       
      The manual page at http://dev.mysql.com/doc/mysql/en/crashing.html contains
      information that should help you find out what is causing the crash.
      tcmalloc: large alloc 3511779328 bytes == 0x2b1a2000 @ 
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Mutexes and rw_locks use GCC atomic builtins
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Uses event mutexes
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Compressed tables use zlib 1.2.3
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Using Linux native AIO
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Number of pools: 1
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Using SSE2 crc32 instructions
      2018-06-11 13:00:43 140229241796416 [Note] InnoDB: Initializing buffer pool, total size = 8G, instances = 8, chunk size = 128M
      2018-06-11 13:00:44 140229241796416 [Note] InnoDB: Completed initialization of buffer pool
      2018-06-11 13:00:44 140220282665280 [Note] InnoDB: If the mysqld execution user is authorized, page cleaner thread priority can be changed. See the man page of setpriority().
      2018-06-11 13:00:44 140229241796416 [Note] InnoDB: Highest supported file format is Barracuda.
      2018-06-11 13:00:44 140229241796416 [Note] InnoDB: Starting crash recovery from checkpoint LSN=6532549241820
      2018-06-11 13:00:48 140229241796416 [Note] InnoDB: 1 transaction(s) which must be rolled back or cleaned up in total 1 row operations to undo
      2018-06-11 13:00:48 140229241796416 [Note] InnoDB: Trx id counter is 2081980672
      2018-06-11 13:00:48 140229241796416 [Note] InnoDB: Starting final batch to recover 2962 pages from redo log.
      2018-06-11 13:00:51 140229241796416 [Note] InnoDB: 128 out of 128 rollback segments are active.
      2018-06-11 13:00:51 140220249094464 [Note] InnoDB: Starting in background the rollback of recovered transactions
      2018-06-11 13:00:51 140220249094464 [Note] InnoDB: Rolled back recovered transaction 2081980352
      2018-06-11 13:00:51 140220249094464 [Note] InnoDB: Rollback of non-prepared transactions completed
      2018-06-11 13:00:51 140229241796416 [Note] InnoDB: Removed temporary tablespace data file: "ibtmp1"
      2018-06-11 13:00:51 140229241796416 [Note] InnoDB: Creating shared tablespace for temporary tables
      2018-06-11 13:00:51 140229241796416 [Note] InnoDB: Setting file './ibtmp1' size to 12 MB. Physically writing the file full; Please wait ...
      2018-06-11 13:00:51 140229241796416 [Note] InnoDB: File './ibtmp1' size is now 12 MB.
      2018-06-11 13:00:52 140229241796416 [Note] InnoDB: Waiting for purge to start
      2018-06-11 13:00:52 140229241796416 [Note] InnoDB: 5.7.22 started; log sequence number 6532549818501
      2018-06-11 13:00:52 140220165167424 [Note] InnoDB: Loading buffer pool(s) from /srvdata/mysql/ib_buffer_pool
      2018-06-11 13:00:52 140229241796416 [Note] Plugin 'FEEDBACK' is disabled.
      180611 13:00:52 server_audit: MariaDB Audit Plugin version 1.4.4 STARTED.
      2018-06-11 13:00:52 140229241796416 [Note] Recovering after a crash using tc.log
      2018-06-11 13:00:52 140229241796416 [Note] Starting crash recovery...
      2018-06-11 13:00:52 140229241796416 [Note] Crash recovery finished.
      2018-06-11 13:00:52 140229241796416 [Note] Server socket created on IP: '::'.
      

      Attachments

        Issue Links

          Activity

            People

              Unassigned Unassigned
              BB Silver Asu
              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.