]>
git.proxmox.com Git - ceph.git/blob - ceph/src/crimson/mgr/client.cc
1 // -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2 // vim: ts=8 sw=2 smarttab
6 #include "crimson/common/log.h"
7 #include "crimson/net/Connection.h"
8 #include "crimson/net/Messenger.h"
9 #include "messages/MMgrConfigure.h"
10 #include "messages/MMgrMap.h"
11 #include "messages/MMgrOpen.h"
14 seastar::logger
& logger()
16 return crimson::get_logger(ceph_subsys_mgrc
);
20 using crimson::common::local_conf
;
22 namespace crimson::mgr
25 Client::Client(crimson::net::Messenger
& msgr
,
26 WithStats
& with_stats
)
28 with_stats
{with_stats
},
29 tick_timer
{[this] {tick();}}
32 seastar::future
<> Client::start()
34 return seastar::now();
37 seastar::future
<> Client::stop()
39 return gate
.close().then([this] {
43 return seastar::now();
48 seastar::future
<> Client::ms_dispatch(crimson::net::Connection
* conn
,
51 switch(m
->get_type()) {
53 return handle_mgr_map(conn
, boost::static_pointer_cast
<MMgrMap
>(m
));
54 case MSG_MGR_CONFIGURE
:
55 return handle_mgr_conf(conn
, boost::static_pointer_cast
<MMgrConfigure
>(m
));
57 return seastar::now();
61 seastar::future
<> Client::ms_handle_reset(crimson::net::ConnectionRef c
)
67 return seastar::now();
70 seastar::future
<> Client::reconnect()
73 // crimson::net::Protocol::close() is able to close() in background
76 if (!mgrmap
.get_available()) {
77 logger().warn("No active mgr available yet");
78 return seastar::now();
80 auto peer
= mgrmap
.get_active_addrs().front();
81 conn
= msgr
.connect(peer
, CEPH_ENTITY_TYPE_MGR
);
82 // ask for the mgrconfigure message
83 auto m
= ceph::make_message
<MMgrOpen
>();
84 m
->daemon_name
= local_conf()->name
.get_id();
85 return conn
->send(std::move(m
));
88 seastar::future
<> Client::handle_mgr_map(crimson::net::Connection
*,
91 mgrmap
= m
->get_map();
94 } else if (conn
->get_peer_addr() !=
95 mgrmap
.get_active_addrs().legacy_addr()) {
98 return seastar::now();
102 seastar::future
<> Client::handle_mgr_conf(crimson::net::Connection
* conn
,
103 Ref
<MMgrConfigure
> m
)
105 logger().info("{} {}", __func__
, *m
);
107 auto tick_period
= std::chrono::seconds
{m
->stats_period
};
108 if (tick_period
.count()) {
109 if (tick_timer
.armed()) {
110 tick_timer
.rearm(tick_timer
.get_timeout(), tick_period
);
112 tick_timer
.arm_periodic(tick_period
);
117 return seastar::now();
122 (void) seastar::with_gate(gate
, [this] {
124 auto pg_stats
= with_stats
.get_stats();
125 return conn
->send(std::move(pg_stats
));