Type:
New Feature
Priority:
Major
Resolution:
Fixed
InnoDB adaptive indexes has performance problems when running queries in parallel that uses InnoDB hash indexes (at least on the same tables).
Here is an example of running the same SELECT query with 10-256 concurrent threads.
(The query normally takes about 0.36 seconds):
Total execution with 10 threads time: 1 seconds
Total execution with 32 threads time: 1 seconds
Total execution with 64 threads time: 3 seconds
Total execution with 128 threads time: 5 seconds
Total execution with 256 threads time: 9 seconds
When using --innodb-adaptive-hash-index=1 we get:
Total execution with 10 threads time: 1 seconds
Total execution with 32 threads time: 5 seconds
Total execution with 64 threads time: 9 seconds
Total execution with 128 threads time: 18 seconds
Total execution with 256 threads time: 50 seconds
MySQL 5.7 does not have this issue. It has roughly the same speed with and without the hash indexes.
In the above query, there was a driving table with a 400 rows doing lookups in a child table using 200 lookups on a secondary keys for every row from the driving table.
Using innodb-adaptive-hash-index=1 speeds up the query with 37% when running a query in one thread but it slows down drastically when running 32-256 concurrent threads.
causes
MDEV-35649
Crash on macOS on preview-11.8-preview branch
Closed
includes
MDEV-35312
page_cur_search_with_match() could avoid rec_get_offsets()
Closed
is caused by
MDEV-22456
Dropping the adaptive hash index may cause DDL to lock up InnoDB
Closed
MDEV-22646
Assertion `table2->cached' failed in dict_table_t::add_to_cache
Closed
relates to
MDEV-35189
Updating cache for INFORMATION_SCHEMA.INNODB_LOCKS et al is suboptimal
Closed
MDEV-35190
HASH_SEARCH() is duplicating effort before HASH_INSERT() or HASH_DELETE()
Closed
MDEV-35247
ut_fold_ull() and ut_hash_ulint() are a waste
Closed
MDEV-35485
The test innodb.innodb_buffer_pool_resize occasionally crashes
Closed
mentioned in
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Page Loading...
Show 18 more links (3 relates to, 15 mentioned in)
{"report":{"fcp":1559,"ttfb":724.7999999523163,"pageVisibility":"visible","entityId":130991,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"50415f51-170c-4388-a6ec-e751d3ddc93e","navigationType":0,"readyForUser":1668.5999999046326,"redirectCount":0,"resourceLoadedEnd":1965.3999998569489,"resourceLoadedStart":730.5,"resourceTiming":[{"duration":264.2999999523163,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":730.5,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":730.5,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":994.7999999523163,"responseStart":0,"secureConnectionStart":0},{"duration":264.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/css/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":730.7999999523163,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":730.7999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":995.2999999523163,"responseStart":0,"secureConnectionStart":0},{"duration":341.39999985694885,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":731,"connectEnd":731,"connectStart":731,"domainLookupEnd":731,"domainLookupStart":731,"fetchStart":731,"redirectEnd":0,"redirectStart":0,"requestStart":731,"responseEnd":1072.3999998569489,"responseStart":1072.3999998569489,"secureConnectionStart":731},{"duration":399.90000009536743,"initiatorType":"script","name":"https://jira.mariadb.org/s/2d8175ec2fa4c816e8023260bd8c1786-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/js/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":731.1999998092651,"connectEnd":731.1999998092651,"connectStart":731.1999998092651,"domainLookupEnd":731.1999998092651,"domainLookupStart":731.1999998092651,"fetchStart":731.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":731.1999998092651,"responseEnd":1131.0999999046326,"responseStart":1131.0999999046326,"secureConnectionStart":731.1999998092651},{"duration":403.59999990463257,"initiatorType":"script","name":"https://jira.mariadb.org/s/a9324d6758d385eb45c462685ad88f1d-CDN/lu2cib/820016/12ta74/c92c0caa9a024ae85b0ebdbed7fb4bd7/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en","startTime":731.5,"connectEnd":731.5,"connectStart":731.5,"domainLookupEnd":731.5,"domainLookupStart":731.5,"fetchStart":731.5,"redirectEnd":0,"redirectStart":0,"requestStart":731.5,"responseEnd":1135.0999999046326,"responseStart":1135.0999999046326,"secureConnectionStart":731.5},{"duration":403.80000019073486,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":731.6999998092651,"connectEnd":731.6999998092651,"connectStart":731.6999998092651,"domainLookupEnd":731.6999998092651,"domainLookupStart":731.6999998092651,"fetchStart":731.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":731.6999998092651,"responseEnd":1135.5,"responseStart":1135.5,"secureConnectionStart":731.6999998092651},{"duration":404.09999990463257,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":731.7999999523163,"connectEnd":731.7999999523163,"connectStart":731.7999999523163,"domainLookupEnd":731.7999999523163,"domainLookupStart":731.7999999523163,"fetchStart":731.7999999523163,"redirectEnd":0,"redirectStart":0,"requestStart":731.7999999523163,"responseEnd":1135.8999998569489,"responseStart":1135.8999998569489,"secureConnectionStart":731.7999999523163},{"duration":491.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/b04b06a02d1959df322d9cded3aeecc1-CDN/lu2cib/820016/12ta74/a2ff6aa845ffc9a1d22fe23d9ee791fc/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":732,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":732,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1223.5,"responseStart":0,"secureConnectionStart":0},{"duration":404.10000014305115,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":732.1999998092651,"connectEnd":732.1999998092651,"connectStart":732.1999998092651,"domainLookupEnd":732.1999998092651,"domainLookupStart":732.1999998092651,"fetchStart":732.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":732.1999998092651,"responseEnd":1136.2999999523163,"responseStart":1136.2999999523163,"secureConnectionStart":732.1999998092651},{"duration":491.2000000476837,"initiatorType":"link","name":"https://jira.mariadb.org/s/3ac36323ba5e4eb0af2aa7ac7211b4bb-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/css/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.css?jira.create.linked.issue=true","startTime":732.3999998569489,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":732.3999998569489,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1223.5999999046326,"responseStart":0,"secureConnectionStart":0},{"duration":404.7999999523163,"initiatorType":"script","name":"https://jira.mariadb.org/s/5d5e8fe91fbc506585e83ea3b62ccc4b-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/js/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.js?jira.create.linked.issue=true&locale=en","startTime":732.5,"connectEnd":732.5,"connectStart":732.5,"domainLookupEnd":732.5,"domainLookupStart":732.5,"fetchStart":732.5,"redirectEnd":0,"redirectStart":0,"requestStart":732.5,"responseEnd":1137.2999999523163,"responseStart":1137.2999999523163,"secureConnectionStart":732.5},{"duration":993.4000000953674,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":734.1999998092651,"connectEnd":734.1999998092651,"connectStart":734.1999998092651,"domainLookupEnd":734.1999998092651,"domainLookupStart":734.1999998092651,"fetchStart":734.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":734.1999998092651,"responseEnd":1727.5999999046326,"responseStart":1727.5,"secureConnectionStart":734.1999998092651},{"duration":1226.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-init/jira.webresources:bigpipe-init.js","startTime":738.8999998569489,"connectEnd":738.8999998569489,"connectStart":738.8999998569489,"domainLookupEnd":738.8999998569489,"domainLookupStart":738.8999998569489,"fetchStart":738.8999998569489,"redirectEnd":0,"redirectStart":0,"requestStart":738.8999998569489,"responseEnd":1965.3999998569489,"responseStart":1965.3999998569489,"secureConnectionStart":738.8999998569489},{"duration":492.59999990463257,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1237,"connectEnd":1237,"connectStart":1237,"domainLookupEnd":1237,"domainLookupStart":1237,"fetchStart":1237,"redirectEnd":0,"redirectStart":0,"requestStart":1237,"responseEnd":1729.5999999046326,"responseStart":1729.5999999046326,"secureConnectionStart":1237},{"duration":439.90000009536743,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1552.1999998092651,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1552.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1992.0999999046326,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":554,"responseStart":725,"responseEnd":730,"domLoading":728,"domInteractive":1996,"domContentLoadedEventStart":1996,"domContentLoadedEventEnd":2077,"domComplete":2752,"loadEventStart":2752,"loadEventEnd":2754,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1967.2999999523163},{"name":"bigPipe.sidebar-id.end","time":1968.0999999046326},{"name":"bigPipe.activity-panel-pipe-id.start","time":1968.2999999523163},{"name":"bigPipe.activity-panel-pipe-id.end","time":1970.5999999046326},{"name":"activityTabFullyLoaded","time":2102.199999809265}],"measures":[],"correlationId":"ac0e572583d8de","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":109,"dbReadsTimeInMs":19,"dbConnsTimeInMs":29,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}