From 40068b122a3eb91f97e2e666ad18e117efe5150c Mon Sep 17 00:00:00 2001 From: Rahim Kanji Date: Fri, 26 Apr 2024 00:54:05 +0500 Subject: [PATCH 1/6] Addeda new attribute called 'monitor_slave_lag_when_null' in hostgroup settings, which takes precedence over 'mysql_thread_monitor_slave_lag_when_null' if both are configured. --- include/MySQL_HostGroups_Manager.h | 5 +++++ lib/MyHGC.cpp | 1 + lib/MySQL_HostGroups_Manager.cpp | 16 +++++++++++++--- lib/MySQL_Monitor.cpp | 4 ---- 4 files changed, 19 insertions(+), 7 deletions(-) diff --git a/include/MySQL_HostGroups_Manager.h b/include/MySQL_HostGroups_Manager.h index eaa71a293c..995e340518 100644 --- a/include/MySQL_HostGroups_Manager.h +++ b/include/MySQL_HostGroups_Manager.h @@ -291,6 +291,7 @@ class MyHGC { // MySQL Host Group Container char * ignore_session_variables_text; // this is the original version (text format) of ignore_session_variables uint32_t max_num_online_servers; uint32_t throttle_connections_per_sec; + int32_t monitor_slave_lag_when_null; int8_t autocommit; int8_t free_connections_pct; int8_t handle_warnings; @@ -310,6 +311,10 @@ class MyHGC { // MySQL Host Group Container bool handle_warnings_enabled() const { return attributes.configured == true && attributes.handle_warnings != -1 ? attributes.handle_warnings : mysql_thread___handle_warnings; } + inline + int32_t get_monitor_slave_lag_when_null() const { + return attributes.configured == true && attributes.monitor_slave_lag_when_null != -1 ? attributes.monitor_slave_lag_when_null : mysql_thread___monitor_slave_lag_when_null; + } MyHGC(int); ~MyHGC(); MySrvC *get_random_MySrvC(char * gtid_uuid, uint64_t gtid_trxid, int max_lag_ms, MySQL_Session *sess); diff --git a/lib/MyHGC.cpp b/lib/MyHGC.cpp index 9a2a8a0629..9602f156a4 100644 --- a/lib/MyHGC.cpp +++ b/lib/MyHGC.cpp @@ -33,6 +33,7 @@ void MyHGC::reset_attributes() { attributes.autocommit = -1; attributes.free_connections_pct = 10; attributes.handle_warnings = -1; + attributes.monitor_slave_lag_when_null = -1; attributes.multiplex = true; attributes.connection_warming = false; free(attributes.init_connect); diff --git a/lib/MySQL_HostGroups_Manager.cpp b/lib/MySQL_HostGroups_Manager.cpp index 705a06515a..d380c3b29a 100644 --- a/lib/MySQL_HostGroups_Manager.cpp +++ b/lib/MySQL_HostGroups_Manager.cpp @@ -2686,8 +2686,13 @@ void MySQL_HostGroups_Manager::add(MySrvC *mysrvc, unsigned int _hid) { } void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const char *address, unsigned int port, int current_replication_lag) { - int j; - for (j=0; j<(int)myhgc->mysrvs->cnt(); j++) { + + if (current_replication_lag == -1) { + current_replication_lag = myhgc->get_monitor_slave_lag_when_null(); + proxy_error("Replication lag on server %s:%d is NULL, using value %d\n", address, port, current_replication_lag); + } + + for (int j=0; j<(int)myhgc->mysrvs->cnt(); j++) { MySrvC *mysrvc=(MySrvC *)myhgc->mysrvs->servers->index(j); if (strcmp(mysrvc->address,address)==0 && mysrvc->port==port) { mysrvc->cur_replication_lag = current_replication_lag; @@ -6219,8 +6224,13 @@ void init_myhgc_hostgroup_settings(const char* hostgroup_settings, MyHGC* myhgc) nlohmann::json j = nlohmann::json::parse(hostgroup_settings); const auto handle_warnings_check = [](int8_t handle_warnings) -> bool { return handle_warnings == 0 || handle_warnings == 1; }; - int8_t handle_warnings = j_get_srv_default_int_val(j, hid, "handle_warnings", handle_warnings_check); + const int8_t handle_warnings = j_get_srv_default_int_val(j, hid, "handle_warnings", handle_warnings_check); myhgc->attributes.handle_warnings = handle_warnings; + + const auto monitor_slave_lag_when_null_check = [](int32_t monitor_slave_lag_when_null) -> bool + { return (monitor_slave_lag_when_null >= 0 && monitor_slave_lag_when_null <= 604800); }; + const int32_t monitor_slave_lag_when_null = j_get_srv_default_int_val(j, hid, "monitor_slave_lag_when_null", monitor_slave_lag_when_null_check); + myhgc->attributes.monitor_slave_lag_when_null = monitor_slave_lag_when_null; } catch (const json::exception& e) { proxy_error( diff --git a/lib/MySQL_Monitor.cpp b/lib/MySQL_Monitor.cpp index a943f10a98..1034129653 100644 --- a/lib/MySQL_Monitor.cpp +++ b/lib/MySQL_Monitor.cpp @@ -2792,11 +2792,9 @@ void * monitor_replication_lag_thread(void *arg) { MYSQL_ROW row=mysql_fetch_row(mmsd->result); if (row) { repl_lag=-1; // this is old behavior - repl_lag=mysql_thread___monitor_slave_lag_when_null; // new behavior, see 669 if (row[j]) { // if Seconds_Behind_Master is not NULL repl_lag=atoi(row[j]); } else { - proxy_error("Replication lag on server %s:%d is NULL, using the value %d (mysql-monitor_slave_lag_when_null)\n", mmsd->hostname, mmsd->port, mysql_thread___monitor_slave_lag_when_null); MyHGM->p_update_mysql_error_counter(p_mysql_error_type::proxysql, mmsd->hostgroup_id, mmsd->hostname, mmsd->port, ER_PROXYSQL_SRV_NULL_REPLICATION_LAG); } } @@ -7820,11 +7818,9 @@ bool MySQL_Monitor::monitor_replication_lag_process_ready_tasks(const std::vecto MYSQL_ROW row = mysql_fetch_row(mmsd->result); if (row) { repl_lag = -1; // this is old behavior - repl_lag = mysql_thread___monitor_slave_lag_when_null; // new behavior, see 669 if (row[j]) { // if Seconds_Behind_Master is not NULL repl_lag = atoi(row[j]); } else { - proxy_error("Replication lag on server %s:%d is NULL, using the value %d (mysql-monitor_slave_lag_when_null)\n", mmsd->hostname, mmsd->port, mysql_thread___monitor_slave_lag_when_null); MyHGM->p_update_mysql_error_counter(p_mysql_error_type::proxysql, mmsd->hostgroup_id, mmsd->hostname, mmsd->port, ER_PROXYSQL_SRV_NULL_REPLICATION_LAG); } } From 648c3ab61dfb3b4ffcc61078becfde57c7a29cde Mon Sep 17 00:00:00 2001 From: Rahim Kanji Date: Fri, 3 May 2024 01:59:19 +0500 Subject: [PATCH 2/6] * Improved handling for cases where seconds_behind_master is null or negative --- include/MySQL_HostGroups_Manager.h | 6 +++-- include/SQLite3_Server.h | 4 ++-- lib/MySQL_HostGroups_Manager.cpp | 12 +++++----- lib/MySQL_Monitor.cpp | 17 ++++++++++----- src/SQLite3_Server.cpp | 35 ++++++++++++++++++++---------- 5 files changed, 48 insertions(+), 26 deletions(-) diff --git a/include/MySQL_HostGroups_Manager.h b/include/MySQL_HostGroups_Manager.h index 995e340518..1415884455 100644 --- a/include/MySQL_HostGroups_Manager.h +++ b/include/MySQL_HostGroups_Manager.h @@ -541,9 +541,10 @@ using address_t = std::string; using port_t = unsigned int; using read_only_t = int; using current_replication_lag = int; +using replace_current_replication_lag = bool; using read_only_server_t = std::tuple; -using replication_lag_server_t = std::tuple; +using replication_lag_server_t = std::tuple; enum READ_ONLY_SERVER_T { ROS_HOSTNAME = 0, @@ -557,6 +558,7 @@ enum REPLICATION_LAG_SERVER_T { RLS_ADDRESS, RLS_PORT, RLS_CURRENT_REPLICATION_LAG, + RLS_OVERRIDE_REPLICATION_LAG, RLS__SIZE }; @@ -1090,7 +1092,7 @@ class MySQL_HostGroups_Manager { void push_MyConn_to_pool_array(MySQL_Connection **, unsigned int); void destroy_MyConn_from_pool(MySQL_Connection *, bool _lock=true); - void replication_lag_action_inner(MyHGC *, const char*, unsigned int, int); + void replication_lag_action_inner(MyHGC *, const char*, unsigned int, int, bool); void replication_lag_action(const std::list& mysql_servers); void read_only_action(char *hostname, int port, int read_only); void read_only_action_v2(const std::list& mysql_servers); diff --git a/include/SQLite3_Server.h b/include/SQLite3_Server.h index 6b0526983e..09fe3f9bc0 100644 --- a/include/SQLite3_Server.h +++ b/include/SQLite3_Server.h @@ -56,7 +56,7 @@ class SQLite3_Server { std::vector *tables_defs_readonly; #endif // TEST_READONLY #ifdef TEST_REPLICATIONLAG - std::unordered_map replicationlag_map; + std::unordered_map> replicationlag_map; std::vector* tables_defs_replicationlag; #endif // TEST_REPLICATIONLAG #if defined(TEST_AURORA) || defined(TEST_GALERA) || defined(TEST_GROUPREP) || defined(TEST_READONLY) || defined(TEST_REPLICATIONLAG) @@ -105,7 +105,7 @@ class SQLite3_Server { #ifdef TEST_REPLICATIONLAG pthread_mutex_t test_replicationlag_mutex; void load_replicationlag_table(MySQL_Session* sess); - int replicationlag_test_value(const char* p); + int* replicationlag_test_value(const char* p); int replicationlag_map_size() { return replicationlag_map.size(); } diff --git a/lib/MySQL_HostGroups_Manager.cpp b/lib/MySQL_HostGroups_Manager.cpp index d380c3b29a..0a724fe922 100644 --- a/lib/MySQL_HostGroups_Manager.cpp +++ b/lib/MySQL_HostGroups_Manager.cpp @@ -2685,9 +2685,10 @@ void MySQL_HostGroups_Manager::add(MySrvC *mysrvc, unsigned int _hid) { myhgc->mysrvs->add(mysrvc); } -void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const char *address, unsigned int port, int current_replication_lag) { +void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const char *address, unsigned int port, + int current_replication_lag, bool override_repl_lag) { - if (current_replication_lag == -1) { + if (current_replication_lag == -1 && override_repl_lag == true) { current_replication_lag = myhgc->get_monitor_slave_lag_when_null(); proxy_error("Replication lag on server %s:%d is NULL, using value %d\n", address, port, current_replication_lag); } @@ -2730,7 +2731,7 @@ void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const if ( (current_replication_lag>=0 && ((unsigned int)current_replication_lag <= mysrvc->max_replication_lag)) || - (current_replication_lag==-2) // see issue 959 + (current_replication_lag==-2 && override_repl_lag == true) // see issue 959 ) { mysrvc->status=MYSQL_SERVER_STATUS_ONLINE; proxy_warning("Re-enabling server %s:%d from HG %u with replication lag of %d second\n", address, port, myhgc->hid, current_replication_lag); @@ -2756,18 +2757,19 @@ void MySQL_HostGroups_Manager::replication_lag_action(const std::list(server); const unsigned int port = std::get(server); const int current_replication_lag = std::get(server); + const bool override_repl_lag = std::get(server); if (mysql_thread___monitor_replication_lag_group_by_host == false) { // legacy check. 1 check per server per hostgroup MyHGC *myhgc = MyHGC_find(hid); - replication_lag_action_inner(myhgc,address.c_str(),port,current_replication_lag); + replication_lag_action_inner(myhgc,address.c_str(),port,current_replication_lag,override_repl_lag); } else { // only 1 check per server, no matter the hostgroup // all hostgroups must be searched for (unsigned int i=0; ilen; i++) { MyHGC*myhgc=(MyHGC*)MyHostGroups->index(i); - replication_lag_action_inner(myhgc,address.c_str(),port,current_replication_lag); + replication_lag_action_inner(myhgc,address.c_str(),port,current_replication_lag,override_repl_lag); } } } diff --git a/lib/MySQL_Monitor.cpp b/lib/MySQL_Monitor.cpp index 1034129653..d306f7dbb0 100644 --- a/lib/MySQL_Monitor.cpp +++ b/lib/MySQL_Monitor.cpp @@ -2756,6 +2756,7 @@ void * monitor_replication_lag_thread(void *arg) { ASSERT_SQLITE_OK(rc, mmsd->mondb); // 'replication_lag' to be feed to 'replication_lag_action' int repl_lag=-2; + bool override_repl_lag = true; rc=(*proxy_sqlite3_bind_text)(statement, 1, mmsd->hostname, -1, SQLITE_TRANSIENT); ASSERT_SQLITE_OK(rc, mmsd->mondb); rc=(*proxy_sqlite3_bind_int)(statement, 2, mmsd->port); ASSERT_SQLITE_OK(rc, mmsd->mondb); unsigned long long time_now=realtime_time(); @@ -2792,14 +2793,16 @@ void * monitor_replication_lag_thread(void *arg) { MYSQL_ROW row=mysql_fetch_row(mmsd->result); if (row) { repl_lag=-1; // this is old behavior + override_repl_lag = true; if (row[j]) { // if Seconds_Behind_Master is not NULL repl_lag=atoi(row[j]); + override_repl_lag = false; } else { MyHGM->p_update_mysql_error_counter(p_mysql_error_type::proxysql, mmsd->hostgroup_id, mmsd->hostname, mmsd->port, ER_PROXYSQL_SRV_NULL_REPLICATION_LAG); } } } - if (repl_lag>=0) { + if (/*repl_lag >= 0 ||*/ override_repl_lag == false) { rc=(*proxy_sqlite3_bind_int64)(statement, 5, repl_lag); ASSERT_SQLITE_OK(rc, mmsd->mondb); } else { rc=(*proxy_sqlite3_bind_null)(statement, 5); ASSERT_SQLITE_OK(rc, mmsd->mondb); @@ -2820,7 +2823,7 @@ void * monitor_replication_lag_thread(void *arg) { rc=(*proxy_sqlite3_clear_bindings)(statement); ASSERT_SQLITE_OK(rc, mmsd->mondb); rc=(*proxy_sqlite3_reset)(statement); ASSERT_SQLITE_OK(rc, mmsd->mondb); MyHGM->replication_lag_action( std::list { - replication_lag_server_t {mmsd->hostgroup_id, mmsd->hostname, mmsd->port, repl_lag} + replication_lag_server_t {mmsd->hostgroup_id, mmsd->hostname, mmsd->port, repl_lag, override_repl_lag } } ); (*proxy_sqlite3_finalize)(statement); if (mmsd->mysql_error_msg == NULL) { @@ -7739,8 +7742,7 @@ void MySQL_Monitor::monitor_gr_async_actions_handler( bool MySQL_Monitor::monitor_replication_lag_process_ready_tasks(const std::vector& mmsds) { - - std::list> mysql_servers; + std::list mysql_servers; for (auto& mmsd : mmsds) { @@ -7782,6 +7784,7 @@ bool MySQL_Monitor::monitor_replication_lag_process_ready_tasks(const std::vecto ASSERT_SQLITE_OK(rc, mmsd->mondb); // 'replication_lag' to be feed to 'replication_lag_action' int repl_lag = -2; + bool override_repl_lag = true; rc = (*proxy_sqlite3_bind_text)(statement, 1, mmsd->hostname, -1, SQLITE_TRANSIENT); ASSERT_SQLITE_OK(rc, mmsd->mondb); rc = (*proxy_sqlite3_bind_int)(statement, 2, mmsd->port); ASSERT_SQLITE_OK(rc, mmsd->mondb); unsigned long long time_now = realtime_time(); @@ -7818,14 +7821,16 @@ bool MySQL_Monitor::monitor_replication_lag_process_ready_tasks(const std::vecto MYSQL_ROW row = mysql_fetch_row(mmsd->result); if (row) { repl_lag = -1; // this is old behavior + override_repl_lag = true; if (row[j]) { // if Seconds_Behind_Master is not NULL repl_lag = atoi(row[j]); + override_repl_lag = false; } else { MyHGM->p_update_mysql_error_counter(p_mysql_error_type::proxysql, mmsd->hostgroup_id, mmsd->hostname, mmsd->port, ER_PROXYSQL_SRV_NULL_REPLICATION_LAG); } } } - if (repl_lag >= 0) { + if (/*repl_lag >= 0 ||*/ override_repl_lag == false) { rc = (*proxy_sqlite3_bind_int64)(statement, 5, repl_lag); ASSERT_SQLITE_OK(rc, mmsd->mondb); } else { rc = (*proxy_sqlite3_bind_null)(statement, 5); ASSERT_SQLITE_OK(rc, mmsd->mondb); @@ -7847,7 +7852,7 @@ bool MySQL_Monitor::monitor_replication_lag_process_ready_tasks(const std::vecto rc = (*proxy_sqlite3_reset)(statement); ASSERT_SQLITE_OK(rc, mmsd->mondb); //MyHGM->replication_lag_action(mmsd->hostgroup_id, mmsd->hostname, mmsd->port, repl_lag); (*proxy_sqlite3_finalize)(statement); - mysql_servers.push_back( std::tuple { mmsd->hostgroup_id, mmsd->hostname, mmsd->port, repl_lag }); + mysql_servers.push_back( replication_lag_server_t { mmsd->hostgroup_id, mmsd->hostname, mmsd->port, repl_lag, override_repl_lag }); } //executing replication lag action diff --git a/src/SQLite3_Server.cpp b/src/SQLite3_Server.cpp index ad269a6078..926e54783e 100644 --- a/src/SQLite3_Server.cpp +++ b/src/SQLite3_Server.cpp @@ -879,11 +879,17 @@ void SQLite3_Server_session_handler(MySQL_Session *sess, void *_pa, PtrSize_t *p // probably never initialized GloSQLite3Server->load_replicationlag_table(sess); } - const int rc = GloSQLite3Server->replicationlag_test_value(query_no_space + strlen("SELECT SLAVE STATUS ")); + const int* rc = GloSQLite3Server->replicationlag_test_value(query_no_space + strlen("SELECT SLAVE STATUS ")); free(query); - char* a = (char*)"SELECT %d as Seconds_Behind_Master"; - query = (char*)malloc(strlen(a) + 2); - sprintf(query, a, rc); + if (rc == nullptr) { + const char* a = (char*)"SELECT null as Seconds_Behind_Master"; + query = (char*)malloc(strlen(a) + 2); + sprintf(query, a); + } else { + const char* a = (char*)"SELECT %d as Seconds_Behind_Master"; + query = (char*)malloc(strlen(a) + 2); + sprintf(query, a, *rc); + } pthread_mutex_unlock(&GloSQLite3Server->test_replicationlag_mutex); } } @@ -1845,7 +1851,7 @@ bool SQLite3_Server::init() { insert_into_tables_defs(tables_defs_replicationlag, (const char*)"REPLICATIONLAG_HOST_STATUS", (const char*)"CREATE TABLE REPLICATIONLAG_HOST_STATUS (" - "hostname VARCHAR NOT NULL, port INT NOT NULL, seconds_behind_master INT NOT NULL, PRIMARY KEY (hostname, port)" + "hostname VARCHAR NOT NULL, port INT NOT NULL, seconds_behind_master INT DEFAULT NULL, PRIMARY KEY (hostname, port)" ")" ); @@ -2016,7 +2022,14 @@ void SQLite3_Server::load_replicationlag_table(MySQL_Session* sess) { for (std::vector::iterator it = resultset->rows.begin(); it != resultset->rows.end(); ++it) { SQLite3_row* r = *it; const std::string& s = std::string(r->fields[0]) + ":" + std::string(r->fields[1]); - replicationlag_map[s] = atoi(r->fields[2]); + + if (r->fields[2] == nullptr) { + replicationlag_map[s] = nullptr; + } else { + int* repl_lag = new int; + *repl_lag = atoi(r->fields[2]); + replicationlag_map[s] = std::unique_ptr(repl_lag); + } } } delete resultset; @@ -2024,7 +2037,7 @@ void SQLite3_Server::load_replicationlag_table(MySQL_Session* sess) { GloAdmin->admindb->execute_statement((char*)"SELECT DISTINCT hostname, port FROM mysql_servers WHERE hostgroup_id BETWEEN 5202 AND 5700", &error, &cols, &affected_rows, &resultset); for (std::vector::iterator it = resultset->rows.begin(); it != resultset->rows.end(); ++it) { SQLite3_row* r = *it; - const std::string& s = "INSERT INTO REPLICATIONLAG_HOST_STATUS VALUES ('" + std::string(r->fields[0]) + "'," + std::string(r->fields[1]) + ",0)"; + const std::string& s = "INSERT INTO REPLICATIONLAG_HOST_STATUS VALUES ('" + std::string(r->fields[0]) + "'," + std::string(r->fields[1]) + ",null)"; sessdb->execute(s.c_str()); } delete resultset; @@ -2032,11 +2045,11 @@ void SQLite3_Server::load_replicationlag_table(MySQL_Session* sess) { GloAdmin->mysql_servers_wrunlock(); } -int SQLite3_Server::replicationlag_test_value(const char* p) { - int rc = 0; // default - std::unordered_map::iterator it = replicationlag_map.find(std::string(p)); +int* SQLite3_Server::replicationlag_test_value(const char* p) { + int* rc = 0; // default + std::unordered_map>::iterator it = replicationlag_map.find(std::string(p)); if (it != replicationlag_map.end()) { - rc = it->second; + rc = it->second.get(); } return rc; } From 407fa7fb6a023b85a79ec23a88aa50127ea4a6b3 Mon Sep 17 00:00:00 2001 From: Rahim Kanji Date: Fri, 3 May 2024 02:17:21 +0500 Subject: [PATCH 3/6] Fixed a Typo --- include/MySQL_HostGroups_Manager.h | 4 ++-- src/SQLite3_Server.cpp | 3 +-- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/include/MySQL_HostGroups_Manager.h b/include/MySQL_HostGroups_Manager.h index 1415884455..ff052e008e 100644 --- a/include/MySQL_HostGroups_Manager.h +++ b/include/MySQL_HostGroups_Manager.h @@ -541,10 +541,10 @@ using address_t = std::string; using port_t = unsigned int; using read_only_t = int; using current_replication_lag = int; -using replace_current_replication_lag = bool; +using override_replication_lag = bool; using read_only_server_t = std::tuple; -using replication_lag_server_t = std::tuple; +using replication_lag_server_t = std::tuple; enum READ_ONLY_SERVER_T { ROS_HOSTNAME = 0, diff --git a/src/SQLite3_Server.cpp b/src/SQLite3_Server.cpp index 926e54783e..9d09cdf20f 100644 --- a/src/SQLite3_Server.cpp +++ b/src/SQLite3_Server.cpp @@ -2026,8 +2026,7 @@ void SQLite3_Server::load_replicationlag_table(MySQL_Session* sess) { if (r->fields[2] == nullptr) { replicationlag_map[s] = nullptr; } else { - int* repl_lag = new int; - *repl_lag = atoi(r->fields[2]); + int* repl_lag = new int(atoi(r->fields[2])); replicationlag_map[s] = std::unique_ptr(repl_lag); } } From 526a1115a79fb4e364d204406a2f7bd27cb642e9 Mon Sep 17 00:00:00 2001 From: Rahim Kanji Date: Fri, 3 May 2024 02:28:26 +0500 Subject: [PATCH 4/6] Code improvement --- src/SQLite3_Server.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/SQLite3_Server.cpp b/src/SQLite3_Server.cpp index 9d09cdf20f..d4b678366b 100644 --- a/src/SQLite3_Server.cpp +++ b/src/SQLite3_Server.cpp @@ -2026,8 +2026,7 @@ void SQLite3_Server::load_replicationlag_table(MySQL_Session* sess) { if (r->fields[2] == nullptr) { replicationlag_map[s] = nullptr; } else { - int* repl_lag = new int(atoi(r->fields[2])); - replicationlag_map[s] = std::unique_ptr(repl_lag); + replicationlag_map[s] = std::make_unique(atoi(r->fields[2])); } } } From 3ef9c5ed5505e4d42f2e123c976972a021a45d8c Mon Sep 17 00:00:00 2001 From: Rahim Kanji Date: Fri, 3 May 2024 16:34:03 +0500 Subject: [PATCH 5/6] negative replication lag value will bring server back online --- lib/MySQL_HostGroups_Manager.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/lib/MySQL_HostGroups_Manager.cpp b/lib/MySQL_HostGroups_Manager.cpp index 0a724fe922..fde677aea4 100644 --- a/lib/MySQL_HostGroups_Manager.cpp +++ b/lib/MySQL_HostGroups_Manager.cpp @@ -2690,6 +2690,7 @@ void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const if (current_replication_lag == -1 && override_repl_lag == true) { current_replication_lag = myhgc->get_monitor_slave_lag_when_null(); + override_repl_lag = false; proxy_error("Replication lag on server %s:%d is NULL, using value %d\n", address, port, current_replication_lag); } @@ -2702,9 +2703,9 @@ void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const // (current_replication_lag==-1 ) // || ( - current_replication_lag>=0 && + current_replication_lag >= 0 && mysrvc->max_replication_lag > 0 && // see issue #4018 - ((unsigned int)current_replication_lag > mysrvc->max_replication_lag) + (current_replication_lag > (int)mysrvc->max_replication_lag) ) ) { // always increase the counter @@ -2729,7 +2730,8 @@ void MySQL_HostGroups_Manager::replication_lag_action_inner(MyHGC *myhgc, const } else { if (mysrvc->status==MYSQL_SERVER_STATUS_SHUNNED_REPLICATION_LAG) { if ( - (current_replication_lag>=0 && ((unsigned int)current_replication_lag <= mysrvc->max_replication_lag)) + (/*current_replication_lag >= 0 &&*/override_repl_lag == false && + (current_replication_lag <= (int)mysrvc->max_replication_lag)) || (current_replication_lag==-2 && override_repl_lag == true) // see issue 959 ) { From 88af1f1a29692f4bf6e69661e86990abf3ae5742 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Javier=20Jaramago=20Fern=C3=A1ndez?= Date: Sat, 18 May 2024 14:17:05 +0200 Subject: [PATCH 6/6] Remove legacy 'INFO' log messages on Cluster checksums These messages were introduced by #44678343, and got deprecated at the same time that 'admin-checksum_*' were deprecated (#d61d9892). Their original motivation is summarized in the following note: ``` LOGGING-NOTE: Log only if the remote checksum has just been updated. Avoids constant logging when 'global_checksum' are not used to prevent individual modules fetching. ``` These two messages mistakenly survived this deprecation with the introduction of table 'mysql_servers_v2'. --- lib/ProxySQL_Cluster.cpp | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/lib/ProxySQL_Cluster.cpp b/lib/ProxySQL_Cluster.cpp index 514182b491..15b369f3ec 100644 --- a/lib/ProxySQL_Cluster.cpp +++ b/lib/ProxySQL_Cluster.cpp @@ -562,13 +562,6 @@ void ProxySQL_Node_Entry::set_checksums(MYSQL_RES *_r) { checksums_values.mysql_servers.checksum, GloVars.checksums_values.mysql_servers.checksum, checksums_values.mysql_servers.diff_check); } if (strcmp(checksums_values.mysql_servers.checksum, GloVars.checksums_values.mysql_servers.checksum) == 0) { - // See LOGGING-NOTE at 'admin_variables' above. - if (checksums_values.mysql_servers.last_changed == now) { - proxy_info( - "Cluster: checksum for mysql_servers from peer %s:%d matches with local checksum %s , we won't sync.\n", - hostname, port, GloVars.checksums_values.mysql_servers.checksum - ); - } checksums_values.mysql_servers.diff_check = 0; proxy_debug(PROXY_DEBUG_CLUSTER, 5, "Checksum for mysql_servers from peer %s:%d matches with local checksum %s, reset diff_check to 0.\n", hostname, port, GloVars.checksums_values.mysql_servers.checksum); } @@ -609,13 +602,6 @@ void ProxySQL_Node_Entry::set_checksums(MYSQL_RES *_r) { checksums_values.mysql_servers_v2.checksum, GloVars.checksums_values.mysql_servers_v2.checksum, checksums_values.mysql_servers_v2.diff_check); } if (strcmp(checksums_values.mysql_servers_v2.checksum, GloVars.checksums_values.mysql_servers_v2.checksum) == 0) { - // See LOGGING-NOTE at 'admin_variables' above. - if (checksums_values.mysql_servers_v2.last_changed == now) { - proxy_info( - "Cluster: checksum for mysql_servers_v2 from peer %s:%d matches with local checksum %s , we won't sync.\n", - hostname, port, GloVars.checksums_values.mysql_servers_v2.checksum - ); - } checksums_values.mysql_servers_v2.diff_check = 0; proxy_debug(PROXY_DEBUG_CLUSTER, 5, "Checksum for mysql_servers_v2 from peer %s:%d matches with local checksum %s, reset diff_check to 0.\n", hostname, port, GloVars.checksums_values.mysql_servers.checksum); }