MySQL 9.1.0
Source Code Documentation
table_replication_applier_configuration.h
Go to the documentation of this file.
1/*
2 Copyright (c) 2013, 2024, Oracle and/or its affiliates.
3
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License, version 2.0,
6 as published by the Free Software Foundation.
7
8 This program is designed to work with certain software (including
9 but not limited to OpenSSL) that is licensed under separate terms,
10 as designated in a particular file or component or in included license
11 documentation. The authors of MySQL hereby grant you an additional
12 permission to link the program and your derivative works with the
13 separately licensed software that they have either included with
14 the program or referenced in the documentation.
15
16 This program is distributed in the hope that it will be useful,
17 but WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 GNU General Public License, version 2.0, for more details.
20
21 You should have received a copy of the GNU General Public License
22 along with this program; if not, write to the Free Software
23 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
24
25#ifndef TABLE_REPLICATION_APPLIER_CONFIGURATION_H
26#define TABLE_REPLICATION_APPLIER_CONFIGURATION_H
27
28/**
29 @file storage/perfschema/table_replication_applier_configuration.h
30 Table replication_applier_configuration (declarations).
31*/
32
33#include <sys/types.h>
34#include <time.h>
35
36#include "my_base.h"
37#include "sql/rpl_info.h" /*CHANNEL_NAME_LENGTH*/
38#include "sql/rpl_rli.h" /*enum_require_table_primary_key*/
41
42class Field;
43class Master_info;
44class Plugin_table;
45struct TABLE;
46struct THR_LOCK;
47
48#ifndef ENUM_RPL_YES_NO
49#define ENUM_RPL_YES_NO
51#endif
52
53/**
54 @addtogroup performance_schema_tables
55 @{
56*/
57
58/** A row in the table*/
62 time_t desired_delay{0};
68 Relay_log_info::enum_require_table_primary_key::PK_CHECK_NONE};
73};
74
76 public:
78 : PFS_engine_index(&m_key), m_key("CHANNEL_NAME") {}
79
80 ~PFS_index_rpl_applier_config() override = default;
81
82 virtual bool match(Master_info *mi);
83
84 private:
86};
87
88/** Table PERFORMANCE_SCHEMA.replication_applier_configuration */
91
92 private:
93 int make_row(Master_info *mi);
94
95 /** Table share lock. */
97 /** Table definition. */
99
100 /** Current row */
102 /** Current position. */
104 /** Next position. */
106
107 protected:
108 /**
109 Read the current row values.
110 @param table Table handle
111 @param buf row buffer
112 @param fields Table fields
113 @param read_all true if all columns are read.
114 */
115
116 int read_row_values(TABLE *table, unsigned char *buf, Field **fields,
117 bool read_all) override;
118
120
121 public:
123
124 /** Table share. */
127 static ha_rows get_row_count();
128
129 void reset_position() override;
130
131 int rnd_next() override;
132 int rnd_pos(const void *pos) override;
133
134 int index_init(uint idx, bool sorted) override;
135 int index_next() override;
136
137 private:
139};
140
141/** @} */
142#endif
enum_type
This accepted value of the type of the Assign_gtids_to_anonymous_transactions info OFF : Anonymous gt...
Definition: rpl_rli.h:109
Definition: field.h:577
Definition: rpl_mi.h:87
Definition: pfs_engine_table.h:301
An abstract PERFORMANCE_SCHEMA table.
Definition: pfs_engine_table.h:70
Definition: table_replication_applier_configuration.h:75
PFS_key_name m_key
Definition: table_replication_applier_configuration.h:85
~PFS_index_rpl_applier_config() override=default
virtual bool match(Master_info *mi)
Definition: table_replication_applier_configuration.cc:101
PFS_index_rpl_applier_config()
Definition: table_replication_applier_configuration.h:77
Definition: table_helper.h:1569
Class to hold information regarding a table to be created on behalf of a plugin.
Definition: plugin_table.h:40
enum_require_table_primary_key
Identifies what is the replica policy on primary keys in tables.
Definition: rpl_rli.h:273
Table PERFORMANCE_SCHEMA.replication_applier_configuration.
Definition: table_replication_applier_configuration.h:89
void reset_position() override
Reset the cursor position to the beginning of the table.
Definition: table_replication_applier_configuration.cc:133
PFS_simple_index pos_t
Definition: table_replication_applier_configuration.h:90
int index_init(uint idx, bool sorted) override
Definition: table_replication_applier_configuration.cc:180
table_replication_applier_configuration()
Definition: table_replication_applier_configuration.cc:124
static Plugin_table m_table_def
Table definition.
Definition: table_replication_applier_configuration.h:98
pos_t m_pos
Current position.
Definition: table_replication_applier_configuration.h:103
int read_row_values(TABLE *table, unsigned char *buf, Field **fields, bool read_all) override
Read the current row values.
Definition: table_replication_applier_configuration.cc:265
static ha_rows get_row_count()
Definition: table_replication_applier_configuration.cc:138
int make_row(Master_info *mi)
Definition: table_replication_applier_configuration.cc:215
int rnd_next() override
Fetch the next row in this cursor.
Definition: table_replication_applier_configuration.cc:142
PFS_index_rpl_applier_config * m_opened_index
Definition: table_replication_applier_configuration.h:138
static THR_LOCK m_table_lock
Table share lock.
Definition: table_replication_applier_configuration.h:96
pos_t m_next_pos
Next position.
Definition: table_replication_applier_configuration.h:105
int rnd_pos(const void *pos) override
Fetch a row by position.
Definition: table_replication_applier_configuration.cc:161
int index_next() override
Find key in index, read record.
Definition: table_replication_applier_configuration.cc:190
static PFS_engine_table_share m_share
Table share.
Definition: table_replication_applier_configuration.h:125
static PFS_engine_table * create(PFS_engine_table_share *)
Definition: table_replication_applier_configuration.cc:118
st_row_applier_config m_row
Current row.
Definition: table_replication_applier_configuration.h:101
@ PS_RPL_NO
Definition: table_replication_applier_configuration.h:50
@ PS_RPL_YES
Definition: table_replication_applier_configuration.h:50
This file includes constants used by all storage engines.
my_off_t ha_rows
Definition: my_base.h:1141
static PFS_engine_table_share_proxy table
Definition: pfs.cc:61
Definition: buf0block_hint.cc:30
Performance schema tables (declarations).
#define CHANNEL_NAME_LENGTH
Definition: rpl_info.h:41
A PERFORMANCE_SCHEMA table share.
Definition: pfs_engine_table.h:359
Position of a cursor, for simple iterations.
Definition: pfs_engine_table.h:567
Definition: table.h:1421
Definition: thr_lock.h:139
A row in the table.
Definition: table_replication_applier_configuration.h:59
enum_rpl_yes_no requires_row_format
Definition: table_replication_applier_configuration.h:65
time_t desired_delay
Definition: table_replication_applier_configuration.h:62
std::string assign_gtids_to_anonymous_transactions_value
Definition: table_replication_applier_configuration.h:72
bool desired_delay_is_set
Definition: table_replication_applier_configuration.h:63
Relay_log_info::enum_require_table_primary_key require_table_primary_key_check
Definition: table_replication_applier_configuration.h:67
char channel_name[CHANNEL_NAME_LENGTH]
Definition: table_replication_applier_configuration.h:60
std::string privilege_checks_user
Definition: table_replication_applier_configuration.h:64
uint channel_name_length
Definition: table_replication_applier_configuration.h:61
Assign_gtids_to_anonymous_transactions_info::enum_type assign_gtids_to_anonymous_transactions_type
Definition: table_replication_applier_configuration.h:70
Helpers to implement a performance schema table.
enum_rpl_yes_no
Definition: table_replication_applier_configuration.h:50
Include file for Sun RPC to compile out of the box.