diff options
author | Julius Goryavsky <julius.goryavsky@mariadb.com> | 2021-02-12 15:58:26 +0100 |
---|---|---|
committer | Julius Goryavsky <julius.goryavsky@mariadb.com> | 2021-02-12 15:58:26 +0100 |
commit | 1d27cb7393baf86c99bc0b7a37a80390a7d1c489 (patch) | |
tree | a76756082d391ce3b1338918d18e0bc75dbcdadf /sql/sql_plugin_services.ic | |
parent | da3211e48743d143224ddc2334ac8a01942ecae7 (diff) | |
download | mariadb-git-10.2-MDEV-24853.tar.gz |
MDEV-24853: Duplicate key generated during cluster configuration change10.2-MDEV-24853
Incorrect processing of an auto-incrementing field in the
WSREP-related code during applying transactions results in
a duplicate key being created. This is due to the fact that
at the beginning of the write_row() and update_row() functions,
the values of the auto-increment parameters are used, which
are read from the parameters of the current thread, but further
along the code other values are used, which are read from global
variables (when applying a transaction). This can happen when
the cluster configuration has changed while applying a transaction
(for example in the high_priority_service mode for Galera 4).
Further during IST processing duplicating key is detected, and
processing of the DB_DUPLICATE_KEY return code (inside innodb,
in the write_row() handler) results in a call to the
wsrep_thd_self_abort() function.
Diffstat (limited to 'sql/sql_plugin_services.ic')
-rw-r--r-- | sql/sql_plugin_services.ic | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/sql/sql_plugin_services.ic b/sql/sql_plugin_services.ic index 43fe540731e..358052132a0 100644 --- a/sql/sql_plugin_services.ic +++ b/sql/sql_plugin_services.ic @@ -177,7 +177,6 @@ static struct wsrep_service_st wsrep_handler = { wsrep_thd_ignore_table, wsrep_thd_trx_seqno, wsrep_thd_ws_handle, - wsrep_thd_auto_increment_variables, wsrep_set_load_multi_commit, wsrep_is_load_multi_commit, wsrep_trx_is_aborting, |