forked from codership/galera
-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
MDEV-26851 Add interface to monitor connections in Galera
- Loading branch information
1 parent
8a5fc7c
commit 8782838
Showing
10 changed files
with
139 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -22,6 +22,7 @@ Authors from Codership Oy: | |
* Daniele Sciascia <[email protected]>, Codership Oy | ||
* Philip Stoev <[email protected]>, Codership Oy | ||
* Mario Karuza <[email protected]>, Codership Oy | ||
* Jan Lindström <[email protected]>, Codership Oy | ||
[Codership employees, add name and email/username above this line, but leave this line intact] | ||
|
||
Other contributors: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
// | ||
// Copyright (C) 2010-2021 Codership Oy <[email protected]> | ||
// Copyright (C) 2010-2024 Codership Oy <[email protected]> | ||
// | ||
|
||
#include "wsrep_api.h" | ||
|
@@ -23,6 +23,7 @@ | |
#include "gu_event_service.hpp" | ||
#include "wsrep_config_service.h" | ||
#include "wsrep_node_isolation.h" | ||
#include "wsrep_connection_monitor_service.h" | ||
|
||
#include <cassert> | ||
|
||
|
@@ -1941,4 +1942,14 @@ wsrep_node_isolation_mode_set_v1(enum wsrep_node_isolation_mode mode) | |
return WSREP_NODE_ISOLATION_SUCCESS; | ||
} | ||
|
||
extern "C" | ||
int wsrep_init_connection_monitor_service_v1(wsrep_connection_monitor_service_v1_t *connection_monitor_service) | ||
{ | ||
return gu::init_connection_monitor_service_v1(connection_monitor_service); | ||
} | ||
|
||
extern "C" void wsrep_deinit_connection_monitor_service_v1() | ||
{ | ||
gu::deinit_connection_monitor_service_v1(); | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
// | ||
// Copyright (C) 2014-2020 Codership Oy <[email protected]> | ||
// Copyright (C) 2014-2024 Codership Oy <[email protected]> | ||
// | ||
|
||
#include "gu_config.hpp" | ||
|
@@ -53,6 +53,8 @@ static wsrep_tls_service_v1_t* gu_tls_service(0); | |
|
||
static wsrep_allowlist_service_v1_t* gu_allowlist_service(0); | ||
|
||
static wsrep_connection_monitor_service_v1_t* gu_connection_monitor_service(0); | ||
|
||
// | ||
// AsioIpAddress wrapper | ||
// | ||
|
@@ -955,3 +957,75 @@ void gu::deinit_allowlist_service_v1() | |
std::atomic<enum wsrep_node_isolation_mode> gu::gu_asio_node_isolation_mode{ | ||
WSREP_NODE_ISOLATION_NOT_ISOLATED | ||
}; | ||
|
||
// | ||
// ConnectionMonitor | ||
// | ||
|
||
static std::mutex gu_connection_monitor_service_init_mutex; | ||
static size_t gu_connection_monitor_service_usage; | ||
|
||
int gu::init_connection_monitor_service_v1(wsrep_connection_monitor_service_v1_t* connection_monitor) | ||
{ | ||
log_info << "init_connection_monitor_service_v1"; | ||
std::lock_guard<std::mutex> lock(gu_connection_monitor_service_init_mutex); | ||
++gu_connection_monitor_service_usage; | ||
if (gu_connection_monitor_service) | ||
{ | ||
assert(gu_connection_monitor_service == connection_monitor); | ||
return 0; | ||
} | ||
gu_connection_monitor_service = connection_monitor; | ||
return 0; | ||
} | ||
|
||
void gu::deinit_connection_monitor_service_v1() | ||
{ | ||
log_info << "deinit_connection_monitor_service_v1"; | ||
std::lock_guard<std::mutex> lock(gu_connection_monitor_service_init_mutex); | ||
assert(gu_connection_monitor_service_usage > 0); | ||
--gu_connection_monitor_service_usage; | ||
if (gu_connection_monitor_service_usage == 0) | ||
gu_connection_monitor_service = 0; | ||
} | ||
|
||
void gu::connection_monitor_connect(wsrep_connection_key_t id, | ||
const std::string& scheme, | ||
const std::string& local_addr, | ||
const std::string& remote_uuid, | ||
const std::string& remote_addr) | ||
{ | ||
if (gu_connection_monitor_service == nullptr) | ||
{ | ||
return; // No action | ||
} | ||
|
||
// tcp://127.0.0.1:19006 --> 127.0.0.1:19006 | ||
std::string ra = remote_addr.substr(6, remote_addr.length()); | ||
std::string la = local_addr.substr(6, local_addr.length()); | ||
|
||
wsrep_buf_t const remote = {remote_uuid.c_str(), remote_uuid.length() }; | ||
wsrep_buf_t const lscheme = {scheme.c_str(), scheme.length() }; | ||
wsrep_buf_t const raddr = {ra.c_str(), ra.length() }; | ||
wsrep_buf_t const laddr = {la.c_str(), la.length() }; | ||
|
||
gu_connection_monitor_service->connection_monitor_connect_cb( | ||
gu_connection_monitor_service->context, | ||
id, | ||
&lscheme, | ||
&laddr, | ||
&remote, | ||
&raddr); | ||
} | ||
|
||
void gu::connection_monitor_disconnect(wsrep_connection_key_t id) | ||
{ | ||
if (gu_connection_monitor_service == nullptr) | ||
{ | ||
return; // No action | ||
} | ||
|
||
gu_connection_monitor_service->connection_monitor_disconnect_cb( | ||
gu_connection_monitor_service->context, | ||
id); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters