Metrics.hpp 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. /*
  2. * Copyright (c)2013-2023 ZeroTier, Inc.
  3. *
  4. * Use of this software is governed by the Business Source License included
  5. * in the LICENSE.TXT file in the project's root directory.
  6. *
  7. * Change Date: 2026-01-01
  8. *
  9. * On the date above, in accordance with the Business Source License, use
  10. * of this software will be governed by version 2.0 of the Apache License.
  11. */
  12. #ifndef METRICS_H_
  13. #define METRICS_H_
  14. // clang-format off
  15. #include <prometheus/simpleapi.h>
  16. #include <prometheus/histogram.h>
  17. // clang-format on
  18. namespace prometheus {
  19. namespace simpleapi {
  20. extern std::shared_ptr<Registry> registry_ptr;
  21. }
  22. } // namespace prometheus
  23. namespace ZeroTier {
  24. namespace Metrics {
  25. // Packet Type Counts
  26. extern prometheus::simpleapi::counter_family_t packets;
  27. // incoming packets
  28. extern prometheus::simpleapi::counter_metric_t pkt_nop_in;
  29. extern prometheus::simpleapi::counter_metric_t pkt_error_in;
  30. extern prometheus::simpleapi::counter_metric_t pkt_ack_in;
  31. extern prometheus::simpleapi::counter_metric_t pkt_qos_in;
  32. extern prometheus::simpleapi::counter_metric_t pkt_hello_in;
  33. extern prometheus::simpleapi::counter_metric_t pkt_ok_in;
  34. extern prometheus::simpleapi::counter_metric_t pkt_whois_in;
  35. extern prometheus::simpleapi::counter_metric_t pkt_rendezvous_in;
  36. extern prometheus::simpleapi::counter_metric_t pkt_frame_in;
  37. extern prometheus::simpleapi::counter_metric_t pkt_ext_frame_in;
  38. extern prometheus::simpleapi::counter_metric_t pkt_echo_in;
  39. extern prometheus::simpleapi::counter_metric_t pkt_multicast_like_in;
  40. extern prometheus::simpleapi::counter_metric_t pkt_network_credentials_in;
  41. extern prometheus::simpleapi::counter_metric_t pkt_network_config_request_in;
  42. extern prometheus::simpleapi::counter_metric_t pkt_network_config_in;
  43. extern prometheus::simpleapi::counter_metric_t pkt_multicast_gather_in;
  44. extern prometheus::simpleapi::counter_metric_t pkt_multicast_frame_in;
  45. extern prometheus::simpleapi::counter_metric_t pkt_push_direct_paths_in;
  46. extern prometheus::simpleapi::counter_metric_t pkt_user_message_in;
  47. extern prometheus::simpleapi::counter_metric_t pkt_remote_trace_in;
  48. extern prometheus::simpleapi::counter_metric_t pkt_path_negotiation_request_in;
  49. // outgoing packets
  50. extern prometheus::simpleapi::counter_metric_t pkt_nop_out;
  51. extern prometheus::simpleapi::counter_metric_t pkt_error_out;
  52. extern prometheus::simpleapi::counter_metric_t pkt_ack_out;
  53. extern prometheus::simpleapi::counter_metric_t pkt_qos_out;
  54. extern prometheus::simpleapi::counter_metric_t pkt_hello_out;
  55. extern prometheus::simpleapi::counter_metric_t pkt_ok_out;
  56. extern prometheus::simpleapi::counter_metric_t pkt_whois_out;
  57. extern prometheus::simpleapi::counter_metric_t pkt_rendezvous_out;
  58. extern prometheus::simpleapi::counter_metric_t pkt_frame_out;
  59. extern prometheus::simpleapi::counter_metric_t pkt_ext_frame_out;
  60. extern prometheus::simpleapi::counter_metric_t pkt_echo_out;
  61. extern prometheus::simpleapi::counter_metric_t pkt_multicast_like_out;
  62. extern prometheus::simpleapi::counter_metric_t pkt_network_credentials_out;
  63. extern prometheus::simpleapi::counter_metric_t pkt_network_config_request_out;
  64. extern prometheus::simpleapi::counter_metric_t pkt_network_config_out;
  65. extern prometheus::simpleapi::counter_metric_t pkt_multicast_gather_out;
  66. extern prometheus::simpleapi::counter_metric_t pkt_multicast_frame_out;
  67. extern prometheus::simpleapi::counter_metric_t pkt_push_direct_paths_out;
  68. extern prometheus::simpleapi::counter_metric_t pkt_user_message_out;
  69. extern prometheus::simpleapi::counter_metric_t pkt_remote_trace_out;
  70. extern prometheus::simpleapi::counter_metric_t pkt_path_negotiation_request_out;
  71. // Packet Error Counts
  72. extern prometheus::simpleapi::counter_family_t packet_errors;
  73. // incoming errors
  74. extern prometheus::simpleapi::counter_metric_t pkt_error_obj_not_found_in;
  75. extern prometheus::simpleapi::counter_metric_t pkt_error_unsupported_op_in;
  76. extern prometheus::simpleapi::counter_metric_t pkt_error_identity_collision_in;
  77. extern prometheus::simpleapi::counter_metric_t pkt_error_need_membership_cert_in;
  78. extern prometheus::simpleapi::counter_metric_t pkt_error_network_access_denied_in;
  79. extern prometheus::simpleapi::counter_metric_t pkt_error_unwanted_multicast_in;
  80. extern prometheus::simpleapi::counter_metric_t pkt_error_authentication_required_in;
  81. extern prometheus::simpleapi::counter_metric_t pkt_error_internal_server_error_in;
  82. // outgoing errors
  83. extern prometheus::simpleapi::counter_metric_t pkt_error_obj_not_found_out;
  84. extern prometheus::simpleapi::counter_metric_t pkt_error_unsupported_op_out;
  85. extern prometheus::simpleapi::counter_metric_t pkt_error_identity_collision_out;
  86. extern prometheus::simpleapi::counter_metric_t pkt_error_need_membership_cert_out;
  87. extern prometheus::simpleapi::counter_metric_t pkt_error_network_access_denied_out;
  88. extern prometheus::simpleapi::counter_metric_t pkt_error_unwanted_multicast_out;
  89. extern prometheus::simpleapi::counter_metric_t pkt_error_authentication_required_out;
  90. extern prometheus::simpleapi::counter_metric_t pkt_error_internal_server_error_out;
  91. // Data Sent/Received Metrics
  92. extern prometheus::simpleapi::counter_family_t data;
  93. extern prometheus::simpleapi::counter_metric_t udp_send;
  94. extern prometheus::simpleapi::counter_metric_t udp_recv;
  95. extern prometheus::simpleapi::counter_metric_t tcp_send;
  96. extern prometheus::simpleapi::counter_metric_t tcp_recv;
  97. // Network Metrics
  98. extern prometheus::simpleapi::gauge_metric_t network_num_joined;
  99. extern prometheus::simpleapi::gauge_family_t network_num_multicast_groups;
  100. extern prometheus::simpleapi::counter_family_t network_packets;
  101. #ifndef ZT_NO_PEER_METRICS
  102. // Peer Metrics
  103. extern prometheus::CustomFamily<prometheus::Histogram<uint64_t> >& peer_latency;
  104. extern prometheus::simpleapi::gauge_family_t peer_path_count;
  105. extern prometheus::simpleapi::counter_family_t peer_packets;
  106. extern prometheus::simpleapi::counter_family_t peer_packet_errors;
  107. #endif
  108. // General Controller Metrics
  109. extern prometheus::simpleapi::gauge_metric_t network_count;
  110. extern prometheus::simpleapi::gauge_metric_t member_count;
  111. extern prometheus::simpleapi::counter_metric_t network_changes;
  112. extern prometheus::simpleapi::counter_metric_t member_changes;
  113. extern prometheus::simpleapi::counter_metric_t member_auths;
  114. extern prometheus::simpleapi::counter_metric_t member_deauths;
  115. extern prometheus::simpleapi::gauge_metric_t network_config_request_queue_size;
  116. extern prometheus::simpleapi::counter_metric_t sso_expiration_checks;
  117. extern prometheus::simpleapi::counter_metric_t sso_member_deauth;
  118. extern prometheus::simpleapi::counter_metric_t network_config_request;
  119. extern prometheus::simpleapi::gauge_metric_t network_config_request_threads;
  120. extern prometheus::simpleapi::counter_metric_t db_get_network;
  121. extern prometheus::simpleapi::counter_metric_t db_get_network_and_member;
  122. extern prometheus::simpleapi::counter_metric_t db_get_network_and_member_and_summary;
  123. extern prometheus::simpleapi::counter_metric_t db_get_member_list;
  124. extern prometheus::simpleapi::counter_metric_t db_get_network_list;
  125. extern prometheus::simpleapi::counter_metric_t db_member_change;
  126. extern prometheus::simpleapi::counter_metric_t db_network_change;
  127. // Fragmentation Metrics
  128. extern prometheus::simpleapi::counter_family_t packet_fragmentation;
  129. // VL2 Fragmentation Metrics
  130. extern prometheus::simpleapi::counter_metric_t vl2_oversized_frame_tx;
  131. extern prometheus::simpleapi::counter_metric_t vl2_would_fragment_or_drop_rx;
  132. // VL1 Fragmentation Metrics
  133. extern prometheus::simpleapi::counter_metric_t vl1_fragmented_tx;
  134. extern prometheus::simpleapi::counter_metric_t vl1_fragment_rx;
  135. extern prometheus::simpleapi::counter_metric_t vl1_reassembly_failed_rx;
  136. extern prometheus::simpleapi::counter_metric_t vl1_fragment_without_head_rx;
  137. extern prometheus::simpleapi::counter_metric_t vl1_fragment_before_head_rx;
  138. extern prometheus::simpleapi::counter_metric_t vl1_duplicate_fragment_rx;
  139. extern prometheus::simpleapi::counter_metric_t vl1_duplicate_head_rx;
  140. // VL1 Fragmentation Histogram and Counters
  141. extern prometheus::CustomFamily<prometheus::Histogram<uint64_t>> &vl1_fragments_per_packet_histogram;
  142. extern prometheus::simpleapi::counter_metric_t vl1_incomplete_reassembly_rx;
  143. extern prometheus::simpleapi::counter_metric_t vl1_vl2_double_fragmentation_tx;
  144. // VL2 Frame Size Histogram
  145. // Buckets: 512 (IoT/legacy), 576 (min IPv4), 1200 (QUIC/mobile), 1280 (min IPv6),
  146. // 1332, 1380, 1400 (VPN/overlay), 1420 (cloud), 1460 (TCP MSS), 1472 (ICMP/MTU),
  147. // 1480 (ICMP/MTU), 1492 (PPPoE), 1500 (Ethernet), 2800 (VL2 default), 9000 (jumbo)
  148. extern prometheus::CustomFamily<prometheus::Histogram<uint64_t>> &vl2_frame_size_histogram;
  149. // Histogram bucket boundaries for VL1 fragments per packet
  150. inline constexpr uint64_t VL1_FRAGMENTS_PER_PACKET_BUCKETS[] = {1,2,3,4,5,6,7,8,9,10,12,16};
  151. // Histogram bucket boundaries for VL2 frame size
  152. inline constexpr uint64_t VL2_FRAME_SIZE_BUCKETS[] = {512,576,1200,1280,1332,1380,1400,1420,1460,1472,1480,1492,1500,2800,9000};
  153. #ifdef ZT_CONTROLLER_USE_LIBPQ
  154. // Central Controller Metrics
  155. extern prometheus::simpleapi::counter_metric_t pgsql_mem_notification;
  156. extern prometheus::simpleapi::counter_metric_t pgsql_net_notification;
  157. extern prometheus::simpleapi::counter_metric_t pgsql_node_checkin;
  158. extern prometheus::simpleapi::counter_metric_t pgsql_commit_ticks;
  159. extern prometheus::simpleapi::counter_metric_t db_get_sso_info;
  160. extern prometheus::simpleapi::counter_metric_t redis_mem_notification;
  161. extern prometheus::simpleapi::counter_metric_t redis_net_notification;
  162. extern prometheus::simpleapi::counter_metric_t redis_node_checkin;
  163. // Central DB Pool Metrics
  164. extern prometheus::simpleapi::counter_metric_t conn_counter;
  165. extern prometheus::simpleapi::counter_metric_t max_pool_size;
  166. extern prometheus::simpleapi::counter_metric_t min_pool_size;
  167. extern prometheus::simpleapi::gauge_metric_t pool_avail;
  168. extern prometheus::simpleapi::gauge_metric_t pool_in_use;
  169. extern prometheus::simpleapi::counter_metric_t pool_errors;
  170. #endif
  171. extern prometheus::Histogram<uint64_t> &vl1_fragments_per_packet_hist;
  172. extern prometheus::Histogram<uint64_t> &vl2_frame_size_hist;
  173. } // namespace Metrics
  174. }// namespace ZeroTier
  175. #endif // METRICS_H_