http_metrics.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. /*
  2. * Copyright The OpenTelemetry Authors
  3. * SPDX-License-Identifier: Apache-2.0
  4. */
  5. /*
  6. * DO NOT EDIT, this is an Auto-generated file from:
  7. * buildscripts/semantic-convention/templates/registry/semantic_metrics-h.j2
  8. */
  9. #pragma once
  10. #include "opentelemetry/common/macros.h"
  11. #include "opentelemetry/metrics/meter.h"
  12. #include "opentelemetry/version.h"
  13. OPENTELEMETRY_BEGIN_NAMESPACE
  14. namespace semconv
  15. {
  16. namespace http
  17. {
  18. /**
  19. Number of active HTTP requests.
  20. <p>
  21. updowncounter
  22. */
  23. static constexpr const char *kMetricHttpClientActiveRequests = "http.client.active_requests";
  24. static constexpr const char *descrMetricHttpClientActiveRequests =
  25. "Number of active HTTP requests.";
  26. static constexpr const char *unitMetricHttpClientActiveRequests = "{request}";
  27. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  28. CreateSyncInt64MetricHttpClientActiveRequests(metrics::Meter *meter)
  29. {
  30. return meter->CreateInt64UpDownCounter(kMetricHttpClientActiveRequests,
  31. descrMetricHttpClientActiveRequests,
  32. unitMetricHttpClientActiveRequests);
  33. }
  34. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  35. CreateSyncDoubleMetricHttpClientActiveRequests(metrics::Meter *meter)
  36. {
  37. return meter->CreateDoubleUpDownCounter(kMetricHttpClientActiveRequests,
  38. descrMetricHttpClientActiveRequests,
  39. unitMetricHttpClientActiveRequests);
  40. }
  41. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  42. CreateAsyncInt64MetricHttpClientActiveRequests(metrics::Meter *meter)
  43. {
  44. return meter->CreateInt64ObservableUpDownCounter(kMetricHttpClientActiveRequests,
  45. descrMetricHttpClientActiveRequests,
  46. unitMetricHttpClientActiveRequests);
  47. }
  48. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  49. CreateAsyncDoubleMetricHttpClientActiveRequests(metrics::Meter *meter)
  50. {
  51. return meter->CreateDoubleObservableUpDownCounter(kMetricHttpClientActiveRequests,
  52. descrMetricHttpClientActiveRequests,
  53. unitMetricHttpClientActiveRequests);
  54. }
  55. /**
  56. The duration of the successfully established outbound HTTP connections.
  57. <p>
  58. histogram
  59. */
  60. static constexpr const char *kMetricHttpClientConnectionDuration =
  61. "http.client.connection.duration";
  62. static constexpr const char *descrMetricHttpClientConnectionDuration =
  63. "The duration of the successfully established outbound HTTP connections.";
  64. static constexpr const char *unitMetricHttpClientConnectionDuration = "s";
  65. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  66. CreateSyncInt64MetricHttpClientConnectionDuration(metrics::Meter *meter)
  67. {
  68. return meter->CreateUInt64Histogram(kMetricHttpClientConnectionDuration,
  69. descrMetricHttpClientConnectionDuration,
  70. unitMetricHttpClientConnectionDuration);
  71. }
  72. static inline nostd::unique_ptr<metrics::Histogram<double>>
  73. CreateSyncDoubleMetricHttpClientConnectionDuration(metrics::Meter *meter)
  74. {
  75. return meter->CreateDoubleHistogram(kMetricHttpClientConnectionDuration,
  76. descrMetricHttpClientConnectionDuration,
  77. unitMetricHttpClientConnectionDuration);
  78. }
  79. /**
  80. Number of outbound HTTP connections that are currently active or idle on the client.
  81. <p>
  82. updowncounter
  83. */
  84. static constexpr const char *kMetricHttpClientOpenConnections = "http.client.open_connections";
  85. static constexpr const char *descrMetricHttpClientOpenConnections =
  86. "Number of outbound HTTP connections that are currently active or idle on the client.";
  87. static constexpr const char *unitMetricHttpClientOpenConnections = "{connection}";
  88. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  89. CreateSyncInt64MetricHttpClientOpenConnections(metrics::Meter *meter)
  90. {
  91. return meter->CreateInt64UpDownCounter(kMetricHttpClientOpenConnections,
  92. descrMetricHttpClientOpenConnections,
  93. unitMetricHttpClientOpenConnections);
  94. }
  95. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  96. CreateSyncDoubleMetricHttpClientOpenConnections(metrics::Meter *meter)
  97. {
  98. return meter->CreateDoubleUpDownCounter(kMetricHttpClientOpenConnections,
  99. descrMetricHttpClientOpenConnections,
  100. unitMetricHttpClientOpenConnections);
  101. }
  102. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  103. CreateAsyncInt64MetricHttpClientOpenConnections(metrics::Meter *meter)
  104. {
  105. return meter->CreateInt64ObservableUpDownCounter(kMetricHttpClientOpenConnections,
  106. descrMetricHttpClientOpenConnections,
  107. unitMetricHttpClientOpenConnections);
  108. }
  109. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  110. CreateAsyncDoubleMetricHttpClientOpenConnections(metrics::Meter *meter)
  111. {
  112. return meter->CreateDoubleObservableUpDownCounter(kMetricHttpClientOpenConnections,
  113. descrMetricHttpClientOpenConnections,
  114. unitMetricHttpClientOpenConnections);
  115. }
  116. /**
  117. Size of HTTP client request bodies.
  118. <p>
  119. The size of the request payload body in bytes. This is the number of bytes transferred excluding
  120. headers and is often, but not always, present as the <a
  121. href="https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length">Content-Length</a> header.
  122. For requests using transport encoding, this should be the compressed size. <p> histogram
  123. */
  124. static constexpr const char *kMetricHttpClientRequestBodySize = "http.client.request.body.size";
  125. static constexpr const char *descrMetricHttpClientRequestBodySize =
  126. "Size of HTTP client request bodies.";
  127. static constexpr const char *unitMetricHttpClientRequestBodySize = "By";
  128. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  129. CreateSyncInt64MetricHttpClientRequestBodySize(metrics::Meter *meter)
  130. {
  131. return meter->CreateUInt64Histogram(kMetricHttpClientRequestBodySize,
  132. descrMetricHttpClientRequestBodySize,
  133. unitMetricHttpClientRequestBodySize);
  134. }
  135. static inline nostd::unique_ptr<metrics::Histogram<double>>
  136. CreateSyncDoubleMetricHttpClientRequestBodySize(metrics::Meter *meter)
  137. {
  138. return meter->CreateDoubleHistogram(kMetricHttpClientRequestBodySize,
  139. descrMetricHttpClientRequestBodySize,
  140. unitMetricHttpClientRequestBodySize);
  141. }
  142. /**
  143. Duration of HTTP client requests.
  144. <p>
  145. histogram
  146. */
  147. static constexpr const char *kMetricHttpClientRequestDuration = "http.client.request.duration";
  148. static constexpr const char *descrMetricHttpClientRequestDuration =
  149. "Duration of HTTP client requests.";
  150. static constexpr const char *unitMetricHttpClientRequestDuration = "s";
  151. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  152. CreateSyncInt64MetricHttpClientRequestDuration(metrics::Meter *meter)
  153. {
  154. return meter->CreateUInt64Histogram(kMetricHttpClientRequestDuration,
  155. descrMetricHttpClientRequestDuration,
  156. unitMetricHttpClientRequestDuration);
  157. }
  158. static inline nostd::unique_ptr<metrics::Histogram<double>>
  159. CreateSyncDoubleMetricHttpClientRequestDuration(metrics::Meter *meter)
  160. {
  161. return meter->CreateDoubleHistogram(kMetricHttpClientRequestDuration,
  162. descrMetricHttpClientRequestDuration,
  163. unitMetricHttpClientRequestDuration);
  164. }
  165. /**
  166. Size of HTTP client response bodies.
  167. <p>
  168. The size of the response payload body in bytes. This is the number of bytes transferred excluding
  169. headers and is often, but not always, present as the <a
  170. href="https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length">Content-Length</a> header.
  171. For requests using transport encoding, this should be the compressed size. <p> histogram
  172. */
  173. static constexpr const char *kMetricHttpClientResponseBodySize = "http.client.response.body.size";
  174. static constexpr const char *descrMetricHttpClientResponseBodySize =
  175. "Size of HTTP client response bodies.";
  176. static constexpr const char *unitMetricHttpClientResponseBodySize = "By";
  177. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  178. CreateSyncInt64MetricHttpClientResponseBodySize(metrics::Meter *meter)
  179. {
  180. return meter->CreateUInt64Histogram(kMetricHttpClientResponseBodySize,
  181. descrMetricHttpClientResponseBodySize,
  182. unitMetricHttpClientResponseBodySize);
  183. }
  184. static inline nostd::unique_ptr<metrics::Histogram<double>>
  185. CreateSyncDoubleMetricHttpClientResponseBodySize(metrics::Meter *meter)
  186. {
  187. return meter->CreateDoubleHistogram(kMetricHttpClientResponseBodySize,
  188. descrMetricHttpClientResponseBodySize,
  189. unitMetricHttpClientResponseBodySize);
  190. }
  191. /**
  192. Number of active HTTP server requests.
  193. <p>
  194. updowncounter
  195. */
  196. static constexpr const char *kMetricHttpServerActiveRequests = "http.server.active_requests";
  197. static constexpr const char *descrMetricHttpServerActiveRequests =
  198. "Number of active HTTP server requests.";
  199. static constexpr const char *unitMetricHttpServerActiveRequests = "{request}";
  200. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  201. CreateSyncInt64MetricHttpServerActiveRequests(metrics::Meter *meter)
  202. {
  203. return meter->CreateInt64UpDownCounter(kMetricHttpServerActiveRequests,
  204. descrMetricHttpServerActiveRequests,
  205. unitMetricHttpServerActiveRequests);
  206. }
  207. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  208. CreateSyncDoubleMetricHttpServerActiveRequests(metrics::Meter *meter)
  209. {
  210. return meter->CreateDoubleUpDownCounter(kMetricHttpServerActiveRequests,
  211. descrMetricHttpServerActiveRequests,
  212. unitMetricHttpServerActiveRequests);
  213. }
  214. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  215. CreateAsyncInt64MetricHttpServerActiveRequests(metrics::Meter *meter)
  216. {
  217. return meter->CreateInt64ObservableUpDownCounter(kMetricHttpServerActiveRequests,
  218. descrMetricHttpServerActiveRequests,
  219. unitMetricHttpServerActiveRequests);
  220. }
  221. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  222. CreateAsyncDoubleMetricHttpServerActiveRequests(metrics::Meter *meter)
  223. {
  224. return meter->CreateDoubleObservableUpDownCounter(kMetricHttpServerActiveRequests,
  225. descrMetricHttpServerActiveRequests,
  226. unitMetricHttpServerActiveRequests);
  227. }
  228. /**
  229. Size of HTTP server request bodies.
  230. <p>
  231. The size of the request payload body in bytes. This is the number of bytes transferred excluding
  232. headers and is often, but not always, present as the <a
  233. href="https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length">Content-Length</a> header.
  234. For requests using transport encoding, this should be the compressed size. <p> histogram
  235. */
  236. static constexpr const char *kMetricHttpServerRequestBodySize = "http.server.request.body.size";
  237. static constexpr const char *descrMetricHttpServerRequestBodySize =
  238. "Size of HTTP server request bodies.";
  239. static constexpr const char *unitMetricHttpServerRequestBodySize = "By";
  240. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  241. CreateSyncInt64MetricHttpServerRequestBodySize(metrics::Meter *meter)
  242. {
  243. return meter->CreateUInt64Histogram(kMetricHttpServerRequestBodySize,
  244. descrMetricHttpServerRequestBodySize,
  245. unitMetricHttpServerRequestBodySize);
  246. }
  247. static inline nostd::unique_ptr<metrics::Histogram<double>>
  248. CreateSyncDoubleMetricHttpServerRequestBodySize(metrics::Meter *meter)
  249. {
  250. return meter->CreateDoubleHistogram(kMetricHttpServerRequestBodySize,
  251. descrMetricHttpServerRequestBodySize,
  252. unitMetricHttpServerRequestBodySize);
  253. }
  254. /**
  255. Duration of HTTP server requests.
  256. <p>
  257. histogram
  258. */
  259. static constexpr const char *kMetricHttpServerRequestDuration = "http.server.request.duration";
  260. static constexpr const char *descrMetricHttpServerRequestDuration =
  261. "Duration of HTTP server requests.";
  262. static constexpr const char *unitMetricHttpServerRequestDuration = "s";
  263. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  264. CreateSyncInt64MetricHttpServerRequestDuration(metrics::Meter *meter)
  265. {
  266. return meter->CreateUInt64Histogram(kMetricHttpServerRequestDuration,
  267. descrMetricHttpServerRequestDuration,
  268. unitMetricHttpServerRequestDuration);
  269. }
  270. static inline nostd::unique_ptr<metrics::Histogram<double>>
  271. CreateSyncDoubleMetricHttpServerRequestDuration(metrics::Meter *meter)
  272. {
  273. return meter->CreateDoubleHistogram(kMetricHttpServerRequestDuration,
  274. descrMetricHttpServerRequestDuration,
  275. unitMetricHttpServerRequestDuration);
  276. }
  277. /**
  278. Size of HTTP server response bodies.
  279. <p>
  280. The size of the response payload body in bytes. This is the number of bytes transferred excluding
  281. headers and is often, but not always, present as the <a
  282. href="https://www.rfc-editor.org/rfc/rfc9110.html#field.content-length">Content-Length</a> header.
  283. For requests using transport encoding, this should be the compressed size. <p> histogram
  284. */
  285. static constexpr const char *kMetricHttpServerResponseBodySize = "http.server.response.body.size";
  286. static constexpr const char *descrMetricHttpServerResponseBodySize =
  287. "Size of HTTP server response bodies.";
  288. static constexpr const char *unitMetricHttpServerResponseBodySize = "By";
  289. static inline nostd::unique_ptr<metrics::Histogram<uint64_t>>
  290. CreateSyncInt64MetricHttpServerResponseBodySize(metrics::Meter *meter)
  291. {
  292. return meter->CreateUInt64Histogram(kMetricHttpServerResponseBodySize,
  293. descrMetricHttpServerResponseBodySize,
  294. unitMetricHttpServerResponseBodySize);
  295. }
  296. static inline nostd::unique_ptr<metrics::Histogram<double>>
  297. CreateSyncDoubleMetricHttpServerResponseBodySize(metrics::Meter *meter)
  298. {
  299. return meter->CreateDoubleHistogram(kMetricHttpServerResponseBodySize,
  300. descrMetricHttpServerResponseBodySize,
  301. unitMetricHttpServerResponseBodySize);
  302. }
  303. } // namespace http
  304. } // namespace semconv
  305. OPENTELEMETRY_END_NAMESPACE