blob: 4a8e036eb0a77d5257c9d62912f3ae067d78b9b1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
// vim: ts=8 sw=2 smarttab
#ifndef CEPH_MDS_METRICS_H
#define CEPH_MDS_METRICS_H
#include "messages/MMDSOp.h"
#include "mds/MDSPerfMetricTypes.h"
class MMDSMetrics final : public MMDSOp {
private:
static constexpr int HEAD_VERSION = 1;
static constexpr int COMPAT_VERSION = 1;
public:
// metrics messsage (client -> metrics map, rank, etc..)
metrics_message_t metrics_message;
protected:
MMDSMetrics() : MMDSOp(MSG_MDS_METRICS, HEAD_VERSION, COMPAT_VERSION) {
}
MMDSMetrics(metrics_message_t metrics_message)
: MMDSOp(MSG_MDS_METRICS, HEAD_VERSION, COMPAT_VERSION),
metrics_message(metrics_message) {
}
~MMDSMetrics() final {}
public:
std::string_view get_type_name() const override {
return "mds_metrics";
}
void print(std::ostream &out) const override {
out << "mds_metrics from rank=" << metrics_message.rank << " carrying "
<< metrics_message.client_metrics_map.size() << " metric updates";
}
void encode_payload(uint64_t features) override {
using ceph::encode;
encode(metrics_message, payload, features);
}
void decode_payload() override {
using ceph::decode;
auto iter = payload.cbegin();
decode(metrics_message, iter);
}
private:
template<class T, typename... Args>
friend boost::intrusive_ptr<T> ceph::make_message(Args&&... args);
template<class T, typename... Args>
friend MURef<T> crimson::make_message(Args&&... args);
};
#endif // CEPH_MDS_METRICS_H
|