> Wasn't sure if I needed a mutex around this to account for potential
> parallel replication error faults occurring at the same time (probably yes).
Yes, you will need a mutex when setting and reading. Or you can use an atomic
increment and corresponding atomic read.
It's not just for parallel replication, also for multi-source.
Kristian Nielsen
added a comment - > Wasn't sure if I needed a mutex around this to account for potential
> parallel replication error faults occurring at the same time (probably yes).
Yes, you will need a mutex when setting and reading. Or you can use an atomic
increment and corresponding atomic read.
It's not just for parallel replication, also for multi-source.
The patch changes file mysql-test/suite/engines/funcs/t/rpl_variables.test,
but not mysql-test/suite/engines/funcs/t/rpl_variables.result. Sounds like you
never actually ran this test?
(I'm not sure what the engines/funcs/ suite is actually used for, you should
double-check that or maybe better make the test in another place, like
mysql-test/suite/rpl/ for example).
Please also make sure that the tests actually fail with the code part of the
patch missing, and that it tests most important part of the functionality.
Also, please write up some text suitable for documentation in the
knowledge base.
The code part of the patch looks good now, I think, using statistic_increment
seems appropriate.
Kristian Nielsen
added a comment - The patch changes file mysql-test/suite/engines/funcs/t/rpl_variables.test,
but not mysql-test/suite/engines/funcs/t/rpl_variables.result. Sounds like you
never actually ran this test?
(I'm not sure what the engines/funcs/ suite is actually used for, you should
double-check that or maybe better make the test in another place, like
mysql-test/suite/rpl/ for example).
Please also make sure that the tests actually fail with the code part of the
patch missing, and that it tests most important part of the functionality.
Also, please write up some text suitable for documentation in the
knowledge base.
The code part of the patch looks good now, I think, using statistic_increment
seems appropriate.
I've merged it into 10.1 and pushed to bb-10.1-knielsen for a buidbot run.
If everything looks ok, I'll push to main 10.1 tomorrow.
Kristian Nielsen
added a comment - I've merged it into 10.1 and pushed to bb-10.1-knielsen for a buidbot run.
If everything looks ok, I'll push to main 10.1 tomorrow.
I wonder if it's been done on purpose that FLUSH STATUS does not reset the value. Either way is reasonable, so I don't have a strong opinion about it, just something to note.
Elena Stepanova
added a comment - I wonder if it's been done on purpose that FLUSH STATUS does not reset the value. Either way is reasonable, so I don't have a strong opinion about it, just something to note.
really? it isn't of type SHOW_LONG_NOFLUSH so it looks like sql_show.cc:reset_status_vars would reset this like other LONG global status variables.
Daniel Black
added a comment - really? it isn't of type SHOW_LONG_NOFLUSH so it looks like sql_show.cc:reset_status_vars would reset this like other LONG global status variables.
############### Locks are flushed, but the skipped error isn't
show global status like 'Slave_skipped_errors';
Variable_name Value
Slave_skipped_errors 1
show global status like 'Table_locks_immediate';
Variable_name Value
Table_locks_immediate 0
###############
connection master;
drop table t1;
connection slave;
connection master;
Elena Stepanova
added a comment - And yet..
[connection master]
create table t1 (pk int primary key);
connection slave;
############### Initial status
show global status like 'Slave_skipped_errors';
Variable_name Value
Slave_skipped_errors 0
show global status like 'Table_locks_immediate';
Variable_name Value
Table_locks_immediate 44
###############
insert into t1 values (1);
connection master;
insert into t1 values (1);
connection slave;
############### After one skipped error
show global status like 'Slave_skipped_errors';
Variable_name Value
Slave_skipped_errors 1
show global status like 'Table_locks_immediate';
Variable_name Value
Table_locks_immediate 47
###############
flush status;
############### Locks are flushed, but the skipped error isn't
show global status like 'Slave_skipped_errors';
Variable_name Value
Slave_skipped_errors 1
show global status like 'Table_locks_immediate';
Variable_name Value
Table_locks_immediate 0
###############
connection master;
drop table t1;
connection slave;
connection master;
ah type SHOW_LONGLONG for Slave_skipped_errors and only SHOW_LONG get reset.
I guess someone made a decision a while ago that big vars weren't to be reset.
well noted.
Daniel Black
added a comment - ah type SHOW_LONGLONG for Slave_skipped_errors and only SHOW_LONG get reset.
I guess someone made a decision a while ago that big vars weren't to be reset.
well noted.
People
Kristian Nielsen
Daniel Black
Votes:
0Vote for this issue
Watchers:
4Start 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.
{"report":{"fcp":1629.8000001907349,"ttfb":369.69999980926514,"pageVisibility":"visible","entityId":49118,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"6a39a7fc-587d-4a00-a3b8-fa3b4c890afb","navigationType":0,"readyForUser":1698.0999999046326,"redirectCount":0,"resourceLoadedEnd":1616.3000001907349,"resourceLoadedStart":375.30000019073486,"resourceTiming":[{"duration":450.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":375.30000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":375.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":825.8000001907349,"responseStart":0,"secureConnectionStart":0},{"duration":450.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":375.69999980926514,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":375.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":826.1999998092651,"responseStart":0,"secureConnectionStart":0},{"duration":459,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":375.80000019073486,"connectEnd":375.80000019073486,"connectStart":375.80000019073486,"domainLookupEnd":375.80000019073486,"domainLookupStart":375.80000019073486,"fetchStart":375.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":375.80000019073486,"responseEnd":834.8000001907349,"responseStart":834.8000001907349,"secureConnectionStart":375.80000019073486},{"duration":527.6999998092651,"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":376,"connectEnd":376,"connectStart":376,"domainLookupEnd":376,"domainLookupStart":376,"fetchStart":376,"redirectEnd":0,"redirectStart":0,"requestStart":376,"responseEnd":903.6999998092651,"responseStart":903.6999998092651,"secureConnectionStart":376},{"duration":531.8999996185303,"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":376.30000019073486,"connectEnd":376.30000019073486,"connectStart":376.30000019073486,"domainLookupEnd":376.30000019073486,"domainLookupStart":376.30000019073486,"fetchStart":376.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":376.30000019073486,"responseEnd":908.1999998092651,"responseStart":908.1999998092651,"secureConnectionStart":376.30000019073486},{"duration":532.1999998092651,"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":376.40000009536743,"connectEnd":376.40000009536743,"connectStart":376.40000009536743,"domainLookupEnd":376.40000009536743,"domainLookupStart":376.40000009536743,"fetchStart":376.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":376.40000009536743,"responseEnd":908.5999999046326,"responseStart":908.5999999046326,"secureConnectionStart":376.40000009536743},{"duration":539.5999999046326,"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":376.59999990463257,"connectEnd":376.59999990463257,"connectStart":376.59999990463257,"domainLookupEnd":376.59999990463257,"domainLookupStart":376.59999990463257,"fetchStart":376.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":376.59999990463257,"responseEnd":916.1999998092651,"responseStart":916.1999998092651,"secureConnectionStart":376.59999990463257},{"duration":736.6999998092651,"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":376.80000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":376.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1113.5,"responseStart":0,"secureConnectionStart":0},{"duration":542.6999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":376.90000009536743,"connectEnd":376.90000009536743,"connectStart":376.90000009536743,"domainLookupEnd":376.90000009536743,"domainLookupStart":376.90000009536743,"fetchStart":376.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":376.90000009536743,"responseEnd":919.5999999046326,"responseStart":919.5999999046326,"secureConnectionStart":376.90000009536743},{"duration":737.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":377,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":377,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1114.5,"responseStart":0,"secureConnectionStart":0},{"duration":543.0999999046326,"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":378,"connectEnd":378,"connectStart":378,"domainLookupEnd":378,"domainLookupStart":378,"fetchStart":378,"redirectEnd":0,"redirectStart":0,"requestStart":378,"responseEnd":921.0999999046326,"responseStart":921.0999999046326,"secureConnectionStart":378},{"duration":1153.0999999046326,"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":379,"connectEnd":379,"connectStart":379,"domainLookupEnd":379,"domainLookupStart":379,"fetchStart":379,"redirectEnd":0,"redirectStart":0,"requestStart":379,"responseEnd":1532.0999999046326,"responseStart":1532.0999999046326,"secureConnectionStart":379},{"duration":1148.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":384.09999990463257,"connectEnd":384.09999990463257,"connectStart":384.09999990463257,"domainLookupEnd":384.09999990463257,"domainLookupStart":384.09999990463257,"fetchStart":384.09999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":384.09999990463257,"responseEnd":1532.5999999046326,"responseStart":1532.5999999046326,"secureConnectionStart":384.09999990463257},{"duration":102.7999997138977,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1162.3000001907349,"connectEnd":1162.3000001907349,"connectStart":1162.3000001907349,"domainLookupEnd":1162.3000001907349,"domainLookupStart":1162.3000001907349,"fetchStart":1162.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":1162.3000001907349,"responseEnd":1265.0999999046326,"responseStart":1265.0999999046326,"secureConnectionStart":1162.3000001907349},{"duration":347.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/d5715adaadd168a9002b108b2b039b50-CDN/lu2cib/820016/12ta74/be4b45e9cec53099498fa61c8b7acba4/_/download/contextbatch/css/jira.project.sidebar,-_super,-project.issue.navigator,-jira.general,-jira.browse.project,-jira.view.issue,-jira.global,-atl.general,-com.atlassian.jira.projects.sidebar.init/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":1268.8000001907349,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1268.8000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1616.3000001907349,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":204,"responseStart":370,"responseEnd":377,"domLoading":373,"domInteractive":1779,"domContentLoadedEventStart":1779,"domContentLoadedEventEnd":1838,"domComplete":2399,"loadEventStart":2399,"loadEventEnd":2400,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1738.5},{"name":"bigPipe.sidebar-id.end","time":1739.3000001907349},{"name":"bigPipe.activity-panel-pipe-id.start","time":1739.4000000953674},{"name":"bigPipe.activity-panel-pipe-id.end","time":1742.5999999046326},{"name":"activityTabFullyLoaded","time":1857.6999998092651}],"measures":[],"correlationId":"83e9af6062b8cb","effectiveType":"4g","downlink":9.7,"rtt":0,"serverDuration":109,"dbReadsTimeInMs":12,"dbConnsTimeInMs":21,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
> Wasn't sure if I needed a mutex around this to account for potential
> parallel replication error faults occurring at the same time (probably yes).
Yes, you will need a mutex when setting and reading. Or you can use an atomic
increment and corresponding atomic read.
It's not just for parallel replication, also for multi-source.