MySQL 9.3.0
Source Code Documentation
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
query_retry_on_ro.h
Go to the documentation of this file.
1/*
2 Copyright (c) 2024, 2025, 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 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
26#ifndef ROUTER_SRC_MYSQL_REST_SERVICE_SRC_MRS_MONITORED_QUERY_RETRY_ON_RO_H_
27#define ROUTER_SRC_MYSQL_REST_SERVICE_SRC_MRS_MONITORED_QUERY_RETRY_ON_RO_H_
28
30
31namespace mrs {
32namespace monitored {
33
34/**
35 * This function is dedicated for monitoring of generated timeouts
36 *
37 * Function is extracted here, because it monitors usage
38 * count in concrete case.
39 */
42
43/**
44 * This function is dedicated for monitoring of generated timeouts
45 *
46 * Function is extracted here, because it monitors usage
47 * count in concrete case.
48 */
50
51/**
52 * This function is dedicated for monitoring "asof/wait for gtid" executions on
53 * RO connection
54 *
55 * Function is extracted here, because it monitors usage
56 * count in concrete case.
57 */
59
60/**
61 * This function is dedicated for monitoring "asof/wait for gtid" executions on
62 * RW connection
63 *
64 * Function is extracted here, because it monitors usage
65 * count in concrete case.
66 */
68
69/**
70 * This function is dedicated for monitoring "asof/wait for gtid" where MRS
71 * switched from RO to RW
72 *
73 * Function is extracted here, because it monitors usage
74 * count in concrete case.
75 */
77
78/**
79 * This class is dedicated for monitoring of generating timeouts
80 *
81 * Class is derived here, because it monitors usage
82 * count of `throw_asof_timeout`.
83 */
85 public:
87
88 protected:
89 void throw_timeout() const override;
90 void using_ro_connection() const override;
91 void using_rw_connection() const override;
92 void switch_ro_to_rw() const override;
93};
94
95} // namespace monitored
96} // namespace mrs
97
98#endif // ROUTER_SRC_MYSQL_REST_SERVICE_SRC_MRS_MONITORED_QUERY_RETRY_ON_RO_H_
Definition: query_retry_on_ro.h:37
QueryRetryOnRO(collector::MysqlCacheManager *cache, CachedSession &session, GtidManager *gtid_manager, FilterObjectGenerator &fog, uint64_t wait_gtid_timeout, bool query_has_gtid_check)
Definition: query_retry_on_ro.cc:45
This class is dedicated for monitoring of generating timeouts.
Definition: query_retry_on_ro.h:84
void using_rw_connection() const override
Definition: query_retry_on_ro.cc:68
void throw_timeout() const override
Definition: query_retry_on_ro.cc:60
void switch_ro_to_rw() const override
Definition: query_retry_on_ro.cc:72
void using_ro_connection() const override
Definition: query_retry_on_ro.cc:64
Definition: mysql_session.h:157
Definition: utils_sqlstring.h:67
void throw_rest_error_asof_timeout()
This function is dedicated for monitoring of generated timeouts.
Definition: query_retry_on_ro.cc:54
void count_using_wait_at_ro_connection()
This function is dedicated for monitoring "asof/wait for gtid" executions on RO connection.
Definition: query_retry_on_ro.cc:35
void count_using_wait_at_rw_connection()
This function is dedicated for monitoring "asof/wait for gtid" executions on RW connection.
Definition: query_retry_on_ro.cc:39
void count_after_wait_timeout_switch_ro_to_rw()
This function is dedicated for monitoring "asof/wait for gtid" where MRS switched from RO to RW.
Definition: query_retry_on_ro.cc:43
void throw_rest_error_asof_timeout_if_not_gtid_executed(mysqlrouter::MySQLSession *session, const mysqlrouter::sqlstring &gtid)
This function is dedicated for monitoring of generated timeouts.
Definition: query_retry_on_ro.cc:47
Definition: authorize_manager.h:48