We have been trying to test the critical reads that are enabled by 'wsrep_sync_wait' parameter but seems like the results are not deterministic.
Here is the test script:
https://github.com/sjangra-git/galera-tests/blob/master/scripts/test.sh
This test script based out of the following test-case:
https://github.com/MariaDB/server/blob/2783fc7d14bc8ad16acfeb509d3b19615023f47a/mysql-test/suite/galera/t/mysql-wsrep%23201.test#L5
Here is the version info:
MariaDB [(none)]> show variables like 'version%';
|
+-------------------------+---------------------------------+
|
| Variable_name | Value |
|
+-------------------------+---------------------------------+
|
| version | 10.1.12-MariaDB |
|
| version_comment | MariaDB Server |
|
| version_compile_machine | x86_64 |
|
| version_compile_os | Linux |
|
| version_malloc_library | system jemalloc |
|
| version_ssl_library | OpenSSL 1.0.1e-fips 11 Feb 2013 |
|
+-------------------------+---------------------------------+
|
The errors are more prominent when we run the following java test where the connection is persisted, so the queries are being attempted faster:
https://github.com/sjangra-git/galera-tests
Auto-commit is OFF on the servers in the cluster:
MariaDB [(none)]> show global variables like 'autocommit';
|
+---------------+-------+
|
| Variable_name | Value |
|
+---------------+-------+
|
| autocommit | OFF |
|
+---------------+-------+
|
Few runs failed, few passed for the same test:
-bash-4.1$ ./test.sh 10.226.76.38 10.226.76.32
|
val1=5735 val2=5732
|
syn_wait FAILED
|
-bash-4.1$ ./test.sh 10.226.76.38 10.226.76.32
|
-bash-4.1$ ./test.sh 10.226.76.38 10.226.76.32
|
-bash-4.1$ ./test.sh 10.226.76.38 10.226.76.32
|
-bash-4.1$ ./test.sh 10.226.76.38 10.226.76.32
|
-bash-4.1$ ./test.sh 10.226.76.38 10.226.76.32
|
{"report":{"fcp":1429.8000001907349,"ttfb":687.8999996185303,"pageVisibility":"visible","entityId":57299,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":32,"apdex":0.5,"journeyId":"a0a24358-ed70-48a7-aa43-b0c5e760d80c","navigationType":0,"readyForUser":1512.3999996185303,"redirectCount":0,"resourceLoadedEnd":1101.6999998092651,"resourceLoadedStart":692.8000001907349,"resourceTiming":[{"duration":83.59999942779541,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":692.8000001907349,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":692.8000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":776.3999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":83.80000019073486,"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":693,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":693,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":776.8000001907349,"responseStart":0,"secureConnectionStart":0},{"duration":295.5999994277954,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":693.1000003814697,"connectEnd":779.5,"connectStart":779.5,"domainLookupEnd":779.5,"domainLookupStart":779.5,"fetchStart":693.1000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":781.1999998092651,"responseEnd":988.6999998092651,"responseStart":793.5,"secureConnectionStart":779.5},{"duration":408.3999996185303,"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":693.3000001907349,"connectEnd":693.3000001907349,"connectStart":693.3000001907349,"domainLookupEnd":693.3000001907349,"domainLookupStart":693.3000001907349,"fetchStart":693.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":781.8999996185303,"responseEnd":1101.6999998092651,"responseStart":799.3999996185303,"secureConnectionStart":693.3000001907349},{"duration":120.39999961853027,"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":693.6000003814697,"connectEnd":693.6000003814697,"connectStart":693.6000003814697,"domainLookupEnd":693.6000003814697,"domainLookupStart":693.6000003814697,"fetchStart":693.6000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":782.6000003814697,"responseEnd":814,"responseStart":809.1999998092651,"secureConnectionStart":693.6000003814697},{"duration":103.40000057220459,"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":693.6999998092651,"connectEnd":693.6999998092651,"connectStart":693.6999998092651,"domainLookupEnd":693.6999998092651,"domainLookupStart":693.6999998092651,"fetchStart":693.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":782.8000001907349,"responseEnd":797.1000003814697,"responseStart":795,"secureConnectionStart":693.6999998092651},{"duration":103.70000076293945,"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":693.8999996185303,"connectEnd":693.8999996185303,"connectStart":693.8999996185303,"domainLookupEnd":693.8999996185303,"domainLookupStart":693.8999996185303,"fetchStart":693.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":782.8999996185303,"responseEnd":797.6000003814697,"responseStart":796.1000003814697,"secureConnectionStart":693.8999996185303},{"duration":88,"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":694.1000003814697,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":694.1000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":782.1000003814697,"responseStart":0,"secureConnectionStart":0},{"duration":120.5,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":694.1999998092651,"connectEnd":694.1999998092651,"connectStart":694.1999998092651,"domainLookupEnd":694.1999998092651,"domainLookupStart":694.1999998092651,"fetchStart":694.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":789.6000003814697,"responseEnd":814.6999998092651,"responseStart":811.6999998092651,"secureConnectionStart":694.1999998092651},{"duration":90.5,"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":694.3999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":694.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":784.8999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":120.5,"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":694.6000003814697,"connectEnd":694.6000003814697,"connectStart":694.6000003814697,"domainLookupEnd":694.6000003814697,"domainLookupStart":694.6000003814697,"fetchStart":694.6000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":789.8000001907349,"responseEnd":815.1000003814697,"responseStart":812.8999996185303,"secureConnectionStart":694.6000003814697},{"duration":375.4000005722046,"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":701.1999998092651,"connectEnd":701.1999998092651,"connectStart":701.1999998092651,"domainLookupEnd":701.1999998092651,"domainLookupStart":701.1999998092651,"fetchStart":701.1999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":887.8000001907349,"responseEnd":1076.6000003814697,"responseStart":1074.3999996185303,"secureConnectionStart":701.1999998092651},{"duration":382.8999996185303,"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":701.3000001907349,"connectEnd":701.3000001907349,"connectStart":701.3000001907349,"domainLookupEnd":701.3000001907349,"domainLookupStart":701.3000001907349,"fetchStart":701.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":941.6999998092651,"responseEnd":1084.1999998092651,"responseStart":1077.8000001907349,"secureConnectionStart":701.3000001907349},{"duration":71.5,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1121.6999998092651,"connectEnd":1121.6999998092651,"connectStart":1121.6999998092651,"domainLookupEnd":1121.6999998092651,"domainLookupStart":1121.6999998092651,"fetchStart":1121.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":1157.6999998092651,"responseEnd":1193.1999998092651,"responseStart":1191.8000001907349,"secureConnectionStart":1121.6999998092651},{"duration":94,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1346.1000003814697,"connectEnd":1346.1000003814697,"connectStart":1346.1000003814697,"domainLookupEnd":1346.1000003814697,"domainLookupStart":1346.1000003814697,"fetchStart":1346.1000003814697,"redirectEnd":0,"redirectStart":0,"requestStart":1407.6000003814697,"responseEnd":1440.1000003814697,"responseStart":1439.3999996185303,"secureConnectionStart":1346.1000003814697}],"fetchStart":0,"domainLookupStart":386,"domainLookupEnd":394,"connectStart":394,"connectEnd":415,"secureConnectionStart":403,"requestStart":415,"responseStart":688,"responseEnd":696,"domLoading":691,"domInteractive":1603,"domContentLoadedEventStart":1603,"domContentLoadedEventEnd":1668,"domComplete":2191,"loadEventStart":2191,"loadEventEnd":2191,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1558.3999996185303},{"name":"bigPipe.sidebar-id.end","time":1559},{"name":"bigPipe.activity-panel-pipe-id.start","time":1559.1999998092651},{"name":"bigPipe.activity-panel-pipe-id.end","time":1564.1000003814697},{"name":"activityTabFullyLoaded","time":1690.6000003814697}],"measures":[],"correlationId":"de3d139b529ca9","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":168,"dbReadsTimeInMs":17,"dbConnsTimeInMs":28,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Failures are easily reproducible when I have two instances of mariadb server running locally in VMs.
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
val1=8791 val2=8789
syn_wait FAILED
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
val1=2917 val2=2915
syn_wait FAILED
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
val1=1087 val2=1085
syn_wait FAILED
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
val1=2371 val2=2369
syn_wait FAILED
[app@cb-node2 ~]$ ./test.sh 192.168.42.102 192.168.42.101
val1=6287 val2=6285
syn_wait FAILED