summaryrefslogtreecommitdiffstats
path: root/src/messages/MMDSMetrics.h
blob: 1cb74188017fa15181acc13594485efcf01eed22 (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
// -*- 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(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);
};

#endif // CEPH_MDS_METRICS_H