MySQL 8.0.40
Source Code Documentation
certifier.h
Go to the documentation of this file.
1/* Copyright (c) 2014, 2024, Oracle and/or its affiliates.
2
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License, version 2.0,
5 as published by the Free Software Foundation.
6
7 This program is designed to work with certain software (including
8 but not limited to OpenSSL) that is licensed under separate terms,
9 as designated in a particular file or component or in included license
10 documentation. The authors of MySQL hereby grant you an additional
11 permission to link the program and your derivative works with the
12 separately licensed software that they have either included with
13 the program or referenced in the documentation.
14
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License, version 2.0, for more details.
19
20 You should have received a copy of the GNU General Public License
21 along with this program; if not, write to the Free Software
22 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
23
24#ifndef CERTIFIER_INCLUDE
25#define CERTIFIER_INCLUDE
26
27#include <assert.h>
29#include <atomic>
30#include <list>
31#include <map>
32#include <string>
33#include <unordered_map>
34#include <vector>
35
36#include "my_inttypes.h"
44
45/**
46 This class extends Gtid_set to include a reference counter.
47
48 It is for Certifier only, so it is single-threaded and no locks
49 are needed since Certifier already ensures sequential use.
50
51 It is to be used to share by multiple entries in the
52 certification info and released when the last reference to it
53 needs to be freed.
54*/
55class Gtid_set_ref : public Gtid_set {
56 public:
61
62 virtual ~Gtid_set_ref() = default;
63
64 /**
65 Increment the number of references by one.
66
67 @return the number of references
68 */
69 size_t link() { return ++reference_counter; }
70
71 /**
72 Decrement the number of references by one.
73
74 @return the number of references
75 */
76 size_t unlink() {
77 assert(reference_counter > 0);
78 return --reference_counter;
79 }
80
83 }
84
85 private:
88};
89
90/**
91 This class is a core component of the database state machine
92 replication protocol. It implements conflict detection based
93 on a certification procedure.
94
95 Snapshot Isolation is based on assigning logical timestamp to optimistic
96 transactions, i.e. the ones which successfully meet certification and
97 are good to commit on all members in the group. This timestamp is a
98 monotonically increasing counter, and is same across all members in the group.
99
100 This timestamp, which in our algorithm is the snapshot version, is further
101 used to update the certification info.
102 The snapshot version maps the items in a transaction to the GTID_EXECUTED
103 that this transaction saw when it was executed, that is, on which version
104 the transaction was executed.
105
106 If the incoming transaction snapshot version is a subset of a
107 previous certified transaction for the same write set, the current
108 transaction was executed on top of outdated data, so it will be
109 negatively certified. Otherwise, this transaction is marked
110 certified and goes into applier.
111*/
113 public:
114 /**
115 Certifier_broadcast_thread constructor
116 */
119
120 /**
121 Initialize broadcast thread.
122
123 @return the operation status
124 @retval 0 OK
125 @retval !=0 Error
126 */
127 int initialize();
128
129 /**
130 Terminate broadcast thread.
131
132 @return the operation status
133 @retval 0 OK
134 @retval !=0 Error
135 */
136 int terminate();
137
138 /**
139 Broadcast thread worker method.
140 */
141 void dispatcher();
142
143 /**
144 Period (in seconds) between stable transactions set
145 broadcast.
146 */
147 static const int BROADCAST_GTID_EXECUTED_PERIOD = 60; // seconds
148
149 private:
150 /**
151 Thread control.
152 */
163
164 /**
165 Broadcast local GTID_EXECUTED to group.
166
167 @return the operation status
168 @retval 0 OK
169 @retval !=0 Error
170 */
172};
173
175 public:
176 ~Certifier_interface() override = default;
177 virtual void handle_view_change() = 0;
179 const uchar *data, ulong len,
180 const Gcs_member_identifier &gcs_member_id) = 0;
181
183 std::map<std::string, std::string> *cert_info) = 0;
185 std::map<std::string, std::string> *cert_info) = 0;
186 virtual int stable_set_handle() = 0;
188 Gtid_set *executed_gtid_set) = 0;
189 virtual void enable_conflict_detection() = 0;
190 virtual void disable_conflict_detection() = 0;
193};
194
196 public:
197 typedef std::unordered_map<
198 std::string, Gtid_set_ref *, std::hash<std::string>,
199 std::equal_to<std::string>,
202
203 Certifier();
204 ~Certifier() override;
205
206 /**
207 Key used to store errors in the certification info
208 on View_change_log_event.
209 */
210 static const std::string CERTIFICATION_INFO_ERROR_NAME;
211
212 /**
213 Initialize certifier.
214
215 @param gtid_assignment_block_size the group gtid assignment block size
216
217 @return the operation status
218 @retval 0 OK
219 @retval !=0 Error
220 */
222
223 /**
224 Terminate certifier.
225
226 @return the operation status
227 @retval 0 OK
228 @retval !=0 Error
229 */
230 int terminate();
231
232 /**
233 Handle view changes on certifier.
234 */
235 void handle_view_change() override;
236
237 /**
238 Queues the packet coming from the reader for future processing.
239
240 @param[in] data the packet data
241 @param[in] len the packet length
242 @param[in] gcs_member_id the member_id which sent the message
243
244 @return the operation status
245 @retval 0 OK
246 @retval !=0 Error on queue
247 */
249 const uchar *data, ulong len,
250 const Gcs_member_identifier &gcs_member_id) override;
251
252 /**
253 This member function SHALL certify the set of items against transactions
254 that have already passed the certification test.
255
256 @param snapshot_version The incoming transaction snapshot version.
257 @param write_set The incoming transaction write set.
258 @param generate_group_id Flag that indicates if transaction group id
259 must be generated.
260 @param member_uuid The UUID of the member from which this
261 transaction originates.
262 @param gle The incoming transaction global identifier
263 event.
264 @param local_transaction True if this transaction did originate from
265 this member, false otherwise.
266
267 @retval >0 transaction identifier (positively certified).
268 If generate_group_id is false and certification
269 positive a 1 is returned;
270 @retval 0 negatively certified;
271 @retval -1 error.
272 */
273 rpl_gno certify(Gtid_set *snapshot_version,
274 std::list<const char *> *write_set, bool generate_group_id,
275 const char *member_uuid, Gtid_log_event *gle,
276 bool local_transaction);
277
278 /**
279 Returns the transactions in stable set in text format, that is, the set of
280 transactions already applied on all group members.
281
282 @param[out] buffer Pointer to pointer to string. The method will set it to
283 point to the newly allocated buffer, or NULL on out of
284 memory.
285 Caller must free the allocated memory.
286 @param[out] length Length of the generated string.
287
288 @return the operation status
289 @retval 0 OK
290 @retval !=0 Out of memory error
291 */
293 size_t *length) override;
294
295 /**
296 Retrieves the current certification info.
297
298 @note if concurrent access is introduce to these variables,
299 locking is needed in this method
300
301 @param[out] cert_info a pointer to retrieve the certification info
302 */
304 std::map<std::string, std::string> *cert_info) override;
305
306 /**
307 Sets the certification info according to the given value.
308
309 @note if concurrent access is introduce to these variables,
310 locking is needed in this method
311
312 @param[in] cert_info certification info retrieved from recovery procedure
313
314 @retval > 0 Error during setting certification info.
315 @retval = 0 Everything went fine.
316 */
318 std::map<std::string, std::string> *cert_info) override;
319
320 /**
321 Get the number of postively certified transactions by the certifier
322 */
324
325 /**
326 Get method to retrieve the number of negatively certified transactions.
327 */
329
330 /**
331 Get method to retrieve the certification db size.
332 */
334
335 /**
336 Get method to retrieve the last conflict free transaction.
337
338 @param[out] value The last conflict free transaction
339 */
340 void get_last_conflict_free_transaction(std::string *value) override;
341
342 /**
343 Generate group GTID for a view change log event.
344
345 @retval >0 view change GTID
346 @retval otherwise Error on GTID generation
347 */
349
350 /**
351 Public method to add the given gno value to the group_gtid_executed set
352 which is used to support skip gtid functionality.
353
354 @param[in] gno The gno of the transaction which will be added to the
355 group_gtid executed GTID set. The sidno used for this
356 transaction will be the group_sidno. The gno here belongs specifically to
357 the group UUID.
358
359 @retval 1 error during addition.
360 @retval 0 success.
361 */
363
364 /**
365 Public method to add the given GTID value in the group_gtid_executed set
366 which is used to support skip gtid functionality.
367
368 @param[in] gle The gtid value that needs to the added in the
369 group_gtid_executed GTID set.
370
371 @retval 1 error during addition.
372 @retval 0 success.
373 */
375
376 /**
377 Computes intersection between all sets received, so that we
378 have the already applied transactions on all servers.
379
380 @return the operation status
381 @retval 0 OK
382 @retval !=0 Error
383 */
384 int stable_set_handle() override;
385
386 /**
387 This member function shall add transactions to the stable set
388
389 @param executed_gtid_set The GTID set of the transactions to be added
390 to the stable set.
391
392 @note when set, the stable set will cause the garbage collection
393 process to be invoked
394
395 @retval False if adds successfully,
396 @retval True otherwise.
397 */
398 bool set_group_stable_transactions_set(Gtid_set *executed_gtid_set) override;
399
400 /**
401 Enables conflict detection.
402 */
403 void enable_conflict_detection() override;
404
405 /**
406 Disables conflict detection.
407 */
408 void disable_conflict_detection() override;
409
410 /**
411 Check if conflict detection is enable.
412
413 @retval True conflict detection is enable
414 @retval False otherwise
415 */
416 bool is_conflict_detection_enable() override;
417
418 private:
419 /**
420 Key used to store group_gtid_executed on certification
421 info on View_change_log_event.
422 */
423 static const std::string GTID_EXTRACTED_NAME;
424
425 /**
426 Is certifier initialized.
427 */
428 std::atomic<bool> initialized{false};
429
430 /**
431 Variable to store the sidno used for transactions which will be logged
432 with the group_uuid.
433 */
435
436 /**
437 The sidno used for view log events as seen by the group sid map
438 */
440 /**
441 The sidno used for view log events as seen by the server sid map
442 */
444
445 /**
446 Method to initialize the group_gtid_executed gtid set with the server gtid
447 executed set and applier retrieved gtid set values.
448
449 @param get_server_gtid_retrieved add applier retrieved gtid set to
450 group_gtid_executed gtid set
451
452 @retval 1 error during initialization
453 @retval 0 success
454
455 */
456 int initialize_server_gtid_set(bool get_server_gtid_retrieved = false);
457
458 /**
459 This function computes the available GTID intervals from group
460 UUID and stores them on group_available_gtid_intervals.
461 */
463
464 /**
465 This function reserves a block of GTIDs from the
466 group_available_gtid_intervals list.
467
468 @retval Gtid_set::Interval which is the interval os GTIDs attributed
469 */
471
472 /**
473 This function updates parallel applier indexes.
474 It must be called for each remote transaction.
475
476 @param[in] update_parallel_applier_last_committed_global
477 If true parallel_applier_last_committed_global
478 is updated to the current sequence number
479 (before update sequence number).
480 @param[in] increment_parallel_applier_sequence_number
481 If false (during certification garbage collection)
482 parallel_applier_last_committed_global is set to
483 parallel_applier_last_sequence_number and
484 parallel_applier_last_sequence_number is not updated
485
486 Note: parallel_applier_last_committed_global should be updated
487 on the following situations:
488 1) Transaction without write set is certified, since it
489 represents the lowest last_committed for all future
490 transactions;
491 2) After certification info garbage collection, since we
492 do not know what write sets were purged, which may cause
493 transactions last committed to be incorrectly computed.
494 */
496 bool update_parallel_applier_last_committed_global,
497 bool increment_parallel_applier_sequence_number);
498
499 /**
500 Internal method to add the given gtid gno in the group_gtid_executed set.
501 This will be used in the skip gtid implementation.
502
503 @note this will update the last know local transaction GTID.
504
505 @param[in] sidno rpl_sidno part of the executing gtid of the ongoing
506 transaction.
507
508 @param[in] gno rpl_gno part of the executing gtid of the ongoing
509 transaction.
510 */
512
513 /**
514 This method is used to get the next valid GNO for the given sidno,
515 for the transaction that is being executed. It checks the already
516 used up GNOs and based on that chooses the next possible value.
517 This method will consult group_available_gtid_intervals to
518 assign GTIDs in blocks according to gtid_assignment_block_size
519 when `sidno` is the group sidno.
520
521 @param member_uuid The UUID of the member from which this
522 transaction originates. It will be NULL
523 on View_change_log_event.
524 @param sidno The sidno that will be used on GTID
525
526 @retval >0 The GNO to be used.
527 @retval -1 Error: GNOs exhausted for group UUID.
528 */
529 rpl_gno get_next_available_gtid(const char *member_uuid, rpl_sidno sidno);
530
531 /**
532 This method is used to get the next valid GNO for the
533 transaction that is being executed. It checks the already used
534 up GNOs and based on that chooses the next possible value.
535 This method will consult group_available_gtid_intervals to
536 assign GTIDs in blocks according to gtid_assignment_block_size.
537
538 @param member_uuid The UUID of the member from which this
539 transaction originates. It will be NULL
540 on View_change_log_event.
541
542 @retval >0 The GNO to be used.
543 @retval -1 Error: GNOs exhausted for group UUID.
544 */
545 rpl_gno get_group_next_available_gtid(const char *member_uuid);
546
547 /**
548 Generate the candidate GNO for the current transaction.
549 The candidate will be on the interval [start, end] or a error
550 be returned.
551 This method will consult group_gtid_executed to avoid generate
552 the same value twice.
553
554 @param sidno The sidno that will be used to retrieve GNO
555 @param start The first possible value for the GNO
556 @param end The last possible value for the GNO
557
558 @retval >0 The GNO to be used.
559 @retval -1 Error: GNOs exhausted for group UUID.
560 @retval -2 Error: generated GNO is bigger than end.
561 */
563 rpl_gno end) const;
564
565 bool inline is_initialized() { return initialized; }
566
568
569 /**
570 Method to clear the members.
571 */
572 void clear_members();
573
574 /**
575 Last conflict free transaction identification.
576 */
578
579 /**
580 Certification database.
581 */
584
590
591#if !defined(NDEBUG)
594#endif
595
597
598 /**
599 Stable set and garbage collector variables.
600 */
605
606 std::vector<std::string> members;
607
608 /*
609 Flag to indicate that certifier is handling already applied
610 transactions during distributed recovery procedure.
611
612 On donor we may have local transactions certified after
613 View_change_log_event (VCLE) logged into binary log before VCLE.
614 That is, these local transactions will be appear on recovery
615 and also on GCS messages. One can see on example scenario below:
616
617 GCS order | donor binary log order | joiner apply order
618 -----------+------------------------+--------------------
619 T1 | T1 | T1
620 T2 | T2 | T2
621 V1 | T3 | T3 (recovery)
622 T3 | V1 | V1
623 | | T3 (GCS)
624 -----------+------------------------+--------------------
625
626 T3 is delivered to donor by both recovery and GCS, so joiner needs
627 to ensure that T3 has the same global identifier on both cases, so
628 that it is correctly skipped on the second time it is applied.
629
630 We ensure that T3 (and other transactions on that situation) have
631 the same global identifiers on joiner by:
632 1) When the VCLE is applied, we set on joiner certification info
633 the same exact certification that was on donor, including the
634 set of certified transactions before the joiner joined:
635 group_gtid_extracted.
636 2) We compare group_gtid_extracted and group_gtid_executed:
637 If group_gtid_extracted is a non equal subset of
638 group_gtid_executed, it means that we are on the above
639 scenario, that is, when applying the last transaction from
640 the distributed recovery process we have more transactions
641 than the ones certified before the view on which joiner joined.
642 So until group_gtid_extracted is a non equal subset of
643 group_gtid_executed certifier will generate transactions ids
644 following group_gtid_extracted so that we have the same exact
645 ids that donor has.
646 3) When joiner group_gtid_extracted and group_gtid_executed are
647 equal, joiner switches to its regular ids generation mode,
648 generating ids from group_gtid_executed.
649 */
651
652 /*
653 Sid map to store the GTIDs that are executed in the group.
654 */
656
657 /*
658 A Gtid_set containing the already executed for the group.
659 This is used to support skip_gtid.
660 */
662
663 /**
664 A Gtid_set which contains the gtid extracted from the certification info
665 map of the donor. It is the set of transactions that is executed at the
666 time of View_change_log_event at donor.
667 */
669
670 /**
671 The group GTID assignment block size.
672 */
674
675 /**
676 List of free GTID intervals in group
677 */
678 std::list<Gtid_set::Interval> group_available_gtid_intervals;
679
680 /**
681 Extends the above to allow GTIDs to be assigned in blocks per member.
682 */
683 std::map<std::string, Gtid_set::Interval> member_gtids;
685
686 /**
687 Conflict detection is performed when:
688 1) group is on multi-master mode;
689 2) group is on single-primary mode and primary is applying
690 relay logs with transactions from a previous primary.
691 */
693
695
696 /**
697 Broadcast thread.
698 */
700
701 /**
702 Adds an item from transaction writeset to the certification DB.
703 @param[in] item item in the writeset to be added to the
704 Certification DB.
705 @param[in] snapshot_version Snapshot version of the incoming transaction
706 which modified the above mentioned item.
707 @param[out] item_previous_sequence_number
708 The previous parallel applier sequence number
709 for this item.
710
711 @retval False successfully added to the map.
712 True otherwise.
713 */
714 bool add_item(const char *item, Gtid_set_ref *snapshot_version,
715 int64 *item_previous_sequence_number);
716
717 /**
718 Find the snapshot_version corresponding to an item. Return if
719 it exists, other wise return NULL;
720
721 @param[in] item item for the snapshot version.
722 @retval Gtid_set pointer if exists in the map.
723 Otherwise 0;
724 */
726
727 /**
728 Removes the intersection of the received transactions stable
729 sets from certification database.
730 */
731 void garbage_collect();
732
733 /**
734 Clear incoming queue.
735 */
736 void clear_incoming();
737
738 /*
739 Update method to store the count of the positively and negatively
740 certified transaction on a particular group member.
741 */
742 void update_certified_transaction_count(bool result, bool local_transaction);
743};
744
745/*
746 @class Gtid_Executed_Message
747
748 Class to convey the serialized contents of the previously executed GTIDs
749 */
751 public:
753 // This type should not be used anywhere.
755
756 // Length of the payload item: variable
758
759 // No valid type codes can appear after this one.
760 PIT_MAX = 2
761 };
762
763 /**
764 Gtid_Executed_Message constructor
765 */
768
769 /**
770 Appends Gtid executed information in a raw format
771
772 * @param[in] gtid_data encoded GTID data
773 * @param[in] len GTID data length
774 */
775 void append_gtid_executed(uchar *gtid_data, size_t len);
776
777 protected:
778 /*
779 Implementation of the template methods of Gcs_plugin_message
780 */
781 void encode_payload(std::vector<unsigned char> *buffer) const override;
782 void decode_payload(const unsigned char *buffer,
783 const unsigned char *) override;
784
785 private:
786 std::vector<uchar> data;
787};
788
789#endif /* CERTIFIER_INCLUDE */
This class is a core component of the database state machine replication protocol.
Definition: certifier.h:112
mysql_cond_t broadcast_dispatcher_cond
Definition: certifier.h:159
mysql_mutex_t broadcast_dispatcher_lock
Definition: certifier.h:158
Certifier_broadcast_thread()
Certifier_broadcast_thread constructor.
Definition: certifier.cc:47
THD * broadcast_thd
Definition: certifier.h:154
int initialize()
Initialize broadcast thread.
Definition: certifier.cc:73
int terminate()
Terminate broadcast thread.
Definition: certifier.cc:101
mysql_mutex_t broadcast_run_lock
Definition: certifier.h:156
static const int BROADCAST_GTID_EXECUTED_PERIOD
Period (in seconds) between stable transactions set broadcast.
Definition: certifier.h:147
int broadcast_gtid_executed()
Broadcast local GTID_EXECUTED to group.
Definition: certifier.cc:202
size_t broadcast_counter
Definition: certifier.h:161
int broadcast_gtid_executed_period
Definition: certifier.h:162
bool aborted
Thread control.
Definition: certifier.h:153
void dispatcher()
Broadcast thread worker method.
Definition: certifier.cc:129
my_thread_handle broadcast_pthd
Definition: certifier.h:155
virtual ~Certifier_broadcast_thread()
Definition: certifier.cc:66
thread_state broadcast_thd_state
Definition: certifier.h:160
mysql_cond_t broadcast_run_cond
Definition: certifier.h:157
Definition: certifier.h:174
virtual bool set_group_stable_transactions_set(Gtid_set *executed_gtid_set)=0
virtual void handle_view_change()=0
virtual ulonglong get_certification_info_size() override=0
virtual bool is_conflict_detection_enable()=0
~Certifier_interface() override=default
virtual void get_certification_info(std::map< std::string, std::string > *cert_info)=0
virtual int handle_certifier_data(const uchar *data, ulong len, const Gcs_member_identifier &gcs_member_id)=0
virtual int set_certification_info(std::map< std::string, std::string > *cert_info)=0
virtual void disable_conflict_detection()=0
virtual void enable_conflict_detection()=0
virtual int stable_set_handle()=0
Definition: certifier_stats_interface.h:29
Definition: certifier.h:195
static const std::string GTID_EXTRACTED_NAME
Key used to store group_gtid_executed on certification info on View_change_log_event.
Definition: certifier.h:423
int get_group_stable_transactions_set_string(char **buffer, size_t *length) override
Returns the transactions in stable set in text format, that is, the set of transactions already appli...
Definition: certifier.cc:1217
rpl_sidno group_gtid_sid_map_group_sidno
Variable to store the sidno used for transactions which will be logged with the group_uuid.
Definition: certifier.h:434
Certification_info certification_info
Certification database.
Definition: certifier.h:582
int set_certification_info(std::map< std::string, std::string > *cert_info) override
Sets the certification info according to the given value.
Definition: certifier.cc:1640
bool conflict_detection_enable
Conflict detection is performed when: 1) group is on multi-master mode; 2) group is on single-primary...
Definition: certifier.h:692
bool is_conflict_detection_enable() override
Check if conflict detection is enable.
Definition: certifier.cc:1830
void compute_group_available_gtid_intervals()
This function computes the available GTID intervals from group UUID and stores them on group_availabl...
Definition: certifier.cc:467
int handle_certifier_data(const uchar *data, ulong len, const Gcs_member_identifier &gcs_member_id) override
Queues the packet coming from the reader for future processing.
Definition: certifier.cc:1365
int64 parallel_applier_sequence_number
Definition: certifier.h:589
int add_specified_gtid_to_group_gtid_executed(Gtid_log_event *gle)
Public method to add the given GTID value in the group_gtid_executed set which is used to support ski...
Definition: certifier.cc:969
void clear_certification_info()
Definition: certifier.cc:575
Gtid_set * stable_gtid_set
Definition: certifier.h:603
int initialize(ulonglong gtid_assignment_block_size)
Initialize certifier.
Definition: certifier.cc:610
bool add_item(const char *item, Gtid_set_ref *snapshot_version, int64 *item_previous_sequence_number)
Adds an item from transaction writeset to the certification DB.
Definition: certifier.cc:1155
void clear_members()
Method to clear the members.
Definition: certifier.cc:604
rpl_gno get_group_next_available_gtid(const char *member_uuid)
This method is used to get the next valid GNO for the transaction that is being executed.
Definition: certifier.cc:1038
Gtid_set * group_gtid_extracted
A Gtid_set which contains the gtid extracted from the certification info map of the donor.
Definition: certifier.h:668
std::atomic< bool > initialized
Is certifier initialized.
Definition: certifier.h:428
void disable_conflict_detection() override
Disables conflict detection.
Definition: certifier.cc:1814
Synchronized_queue< Data_packet * > * incoming
Definition: certifier.h:604
std::unordered_map< std::string, Gtid_set_ref *, std::hash< std::string >, std::equal_to< std::string >, Malloc_allocator< std::pair< const std::string, Gtid_set_ref * > > > Certification_info
Definition: certifier.h:201
void update_certified_transaction_count(bool result, bool local_transaction)
Definition: certifier.cc:1738
void clear_incoming()
Clear incoming queue.
Definition: certifier.cc:594
Certifier()
Definition: certifier.cc:252
Gtid_set::Interval reserve_gtid_block(longlong block_size)
This function reserves a block of GTIDs from the group_available_gtid_intervals list.
Definition: certifier.cc:522
int64 parallel_applier_last_sequence_number
Definition: certifier.h:588
std::vector< std::string > members
Definition: certifier.h:606
std::list< Gtid_set::Interval > group_available_gtid_intervals
List of free GTID intervals in group.
Definition: certifier.h:678
~Certifier() override
Definition: certifier.cc:306
rpl_sidno views_sidno_group_representation
The sidno used for view log events as seen by the group sid map.
Definition: certifier.h:439
void get_last_conflict_free_transaction(std::string *value) override
Get method to retrieve the last conflict free transaction.
Definition: certifier.cc:1783
rpl_sidno views_sidno_server_representation
The sidno used for view log events as seen by the server sid map.
Definition: certifier.h:443
Gtid generate_view_change_group_gtid()
Generate group GTID for a view change log event.
Definition: certifier.cc:1618
rpl_gno certify(Gtid_set *snapshot_version, std::list< const char * > *write_set, bool generate_group_id, const char *member_uuid, Gtid_log_event *gle, bool local_transaction)
This member function SHALL certify the set of items against transactions that have already passed the...
Definition: certifier.cc:684
ulonglong get_certification_info_size() override
Get method to retrieve the certification db size.
Definition: certifier.cc:1779
void update_parallel_applier_indexes(bool update_parallel_applier_last_committed_global, bool increment_parallel_applier_sequence_number)
This function updates parallel applier indexes.
Definition: certifier.cc:652
void get_certification_info(std::map< std::string, std::string > *cert_info) override
Retrieves the current certification info.
Definition: certifier.cc:1582
bool certifying_already_applied_transactions
Definition: certifier.h:650
ulonglong gtids_assigned_in_blocks_counter
Definition: certifier.h:684
Checkable_rwlock * stable_gtid_set_lock
Stable set and garbage collector variables.
Definition: certifier.h:601
bool same_member_message_discarded
Definition: certifier.h:593
ulonglong positive_cert
Definition: certifier.h:585
rpl_gno get_next_available_gtid_candidate(rpl_sidno sidno, rpl_gno start, rpl_gno end) const
Generate the candidate GNO for the current transaction.
Definition: certifier.cc:1109
ulonglong get_negative_certified() override
Get method to retrieve the number of negatively certified transactions.
Definition: certifier.cc:1777
ulonglong negative_cert
Definition: certifier.h:586
bool set_group_stable_transactions_set(Gtid_set *executed_gtid_set) override
This member function shall add transactions to the stable set.
Definition: certifier.cc:1248
mysql_mutex_t LOCK_certification_info
Definition: certifier.h:596
ulonglong get_positive_certified() override
Get the number of postively certified transactions by the certifier.
Definition: certifier.cc:1775
int initialize_server_gtid_set(bool get_server_gtid_retrieved=false)
Method to initialize the group_gtid_executed gtid set with the server gtid executed set and applier r...
Definition: certifier.cc:331
void add_to_group_gtid_executed_internal(rpl_sidno sidno, rpl_gno gno)
Internal method to add the given gtid gno in the group_gtid_executed set.
Definition: certifier.cc:556
Sid_map * group_gtid_sid_map
Definition: certifier.h:655
int64 parallel_applier_last_committed_global
Definition: certifier.h:587
void handle_view_change() override
Handle view changes on certifier.
Definition: certifier.cc:1569
Gtid_set * get_certified_write_set_snapshot_version(const char *item)
Find the snapshot_version corresponding to an item.
Definition: certifier.cc:1199
bool is_initialized()
Definition: certifier.h:565
Sid_map * stable_sid_map
Definition: certifier.h:602
uint64 gtid_assignment_block_size
The group GTID assignment block size.
Definition: certifier.h:673
std::map< std::string, Gtid_set::Interval > member_gtids
Extends the above to allow GTIDs to be assigned in blocks per member.
Definition: certifier.h:683
int add_group_gtid_to_group_gtid_executed(rpl_gno gno)
Public method to add the given gno value to the group_gtid_executed set which is used to support skip...
Definition: certifier.cc:999
void enable_conflict_detection() override
Enables conflict detection.
Definition: certifier.cc:1801
bool certifier_garbage_collection_block
Definition: certifier.h:592
Gtid_set * group_gtid_executed
Definition: certifier.h:661
static const std::string CERTIFICATION_INFO_ERROR_NAME
Key used to store errors in the certification info on View_change_log_event.
Definition: certifier.h:210
Gtid last_conflict_free_transaction
Last conflict free transaction identification.
Definition: certifier.h:577
rpl_gno get_next_available_gtid(const char *member_uuid, rpl_sidno sidno)
This method is used to get the next valid GNO for the given sidno, for the transaction that is being ...
Definition: certifier.cc:1042
int stable_set_handle() override
Computes intersection between all sets received, so that we have the already applied transactions on ...
Definition: certifier.cc:1442
mysql_mutex_t LOCK_members
Definition: certifier.h:694
int terminate()
Terminate certifier.
Definition: certifier.cc:643
void garbage_collect()
Removes the intersection of the received transactions stable sets from certification database.
Definition: certifier.cc:1273
Sid_map * certification_info_sid_map
Definition: certifier.h:583
Certifier_broadcast_thread * broadcast_thread
Broadcast thread.
Definition: certifier.h:699
This has the functionality of mysql_rwlock_t, with two differences:
Definition: rpl_gtid.h:309
It represents the identity of a group member within a certain group.
Definition: gcs_member_identifier.h:40
Definition: certifier.h:750
enum_payload_item_type
Definition: certifier.h:752
@ PIT_MAX
Definition: certifier.h:760
@ PIT_GTID_EXECUTED
Definition: certifier.h:757
@ PIT_UNKNOWN
Definition: certifier.h:754
Gtid_Executed_Message()
Gtid_Executed_Message constructor.
Definition: certifier.cc:1848
std::vector< uchar > data
Definition: certifier.h:786
~Gtid_Executed_Message() override
void append_gtid_executed(uchar *gtid_data, size_t len)
Appends Gtid executed information in a raw format.
Definition: certifier.cc:1853
void encode_payload(std::vector< unsigned char > *buffer) const override
Encodes the contents of this instance payload into the buffer.
Definition: certifier.cc:1857
void decode_payload(const unsigned char *buffer, const unsigned char *) override
Decodes the contents of the buffer and sets the payload field values according to the values decoded.
Definition: certifier.cc:1865
This is a subclass if Gtid_event and Log_event.
Definition: log_event.h:3790
This class extends Gtid_set to include a reference counter.
Definition: certifier.h:55
Gtid_set_ref(Sid_map *sid_map, int64 parallel_applier_sequence_number)
Definition: certifier.h:57
int64 parallel_applier_sequence_number
Definition: certifier.h:87
virtual ~Gtid_set_ref()=default
size_t link()
Increment the number of references by one.
Definition: certifier.h:69
size_t unlink()
Decrement the number of references by one.
Definition: certifier.h:76
int64 get_parallel_applier_sequence_number() const
Definition: certifier.h:81
size_t reference_counter
Definition: certifier.h:86
Represents a set of GTIDs.
Definition: rpl_gtid.h:1455
Sid_map * sid_map
Sid_map associated with this Gtid_set.
Definition: rpl_gtid.h:2327
Malloc_allocator is a C++ STL memory allocator based on my_malloc/my_free.
Definition: malloc_allocator.h:63
This is the base GCS plugin message.
Definition: gcs_plugin_messages.h:64
Represents a bidirectional map between SID and SIDNO.
Definition: rpl_gtid.h:724
Definition: plugin_utils.h:181
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:34
static void start(mysql_harness::PluginFuncEnv *env)
Definition: http_auth_backend_plugin.cc:177
Some integer typedefs for easier portability.
unsigned long long int ulonglong
Definition: my_inttypes.h:56
unsigned char uchar
Definition: my_inttypes.h:52
int64_t int64
Definition: my_inttypes.h:68
long long int longlong
Definition: my_inttypes.h:55
uint64_t uint64
Definition: my_inttypes.h:69
bool length(const dd::Spatial_reference_system *srs, const Geometry *g1, double *length, bool *null) noexcept
Computes the length of linestrings and multilinestrings.
Definition: length.cc:76
mutable_buffer buffer(void *p, size_t n) noexcept
Definition: buffer.h:420
Cursor end()
A past-the-end Cursor.
Definition: rules_table_service.cc:192
std::unordered_map< Key, Value, Hash, Key_equal, ut::allocator< std::pair< const Key, Value > > > unordered_map
Definition: ut0new.h:2899
int rpl_sidno
Type of SIDNO (source ID number, first component of GTID)
Definition: rpl_gtid.h:96
binary_log::gtids::gno_t rpl_gno
GNO, the second (numeric) component of a GTID, is an alias of binary_log::gtids::gno_t.
Definition: rpl_gtid.h:103
Represents one element in the linked list of intervals associated with a SIDNO.
Definition: rpl_gtid.h:1901
TODO: Move this structure to libbinlogevents/include/control_events.h when we start using C++11.
Definition: rpl_gtid.h:1066
Definition: my_thread_bits.h:52
An instrumented cond structure.
Definition: mysql_cond_bits.h:50
An instrumented mutex structure.
Definition: mysql_mutex_bits.h:50
Definition: result.h:30
Definition: plugin_utils.h:47