k8s_metrics.h 78 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723
  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 k8s
  17. {
  18. /**
  19. The number of actively running jobs for a cronjob
  20. <p>
  21. This metric aligns with the @code active @endcode field of the
  22. <a
  23. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#cronjobstatus-v1-batch">K8s
  24. CronJobStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  25. href="../resource/k8s.md#cronjob">@code k8s.cronjob @endcode</a> resource. <p> updowncounter
  26. */
  27. static constexpr const char *kMetricK8sCronjobActiveJobs = "k8s.cronjob.active_jobs";
  28. static constexpr const char *descrMetricK8sCronjobActiveJobs =
  29. "The number of actively running jobs for a cronjob";
  30. static constexpr const char *unitMetricK8sCronjobActiveJobs = "{job}";
  31. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  32. CreateSyncInt64MetricK8sCronjobActiveJobs(metrics::Meter *meter)
  33. {
  34. return meter->CreateInt64UpDownCounter(
  35. kMetricK8sCronjobActiveJobs, descrMetricK8sCronjobActiveJobs, unitMetricK8sCronjobActiveJobs);
  36. }
  37. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  38. CreateSyncDoubleMetricK8sCronjobActiveJobs(metrics::Meter *meter)
  39. {
  40. return meter->CreateDoubleUpDownCounter(
  41. kMetricK8sCronjobActiveJobs, descrMetricK8sCronjobActiveJobs, unitMetricK8sCronjobActiveJobs);
  42. }
  43. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  44. CreateAsyncInt64MetricK8sCronjobActiveJobs(metrics::Meter *meter)
  45. {
  46. return meter->CreateInt64ObservableUpDownCounter(
  47. kMetricK8sCronjobActiveJobs, descrMetricK8sCronjobActiveJobs, unitMetricK8sCronjobActiveJobs);
  48. }
  49. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  50. CreateAsyncDoubleMetricK8sCronjobActiveJobs(metrics::Meter *meter)
  51. {
  52. return meter->CreateDoubleObservableUpDownCounter(
  53. kMetricK8sCronjobActiveJobs, descrMetricK8sCronjobActiveJobs, unitMetricK8sCronjobActiveJobs);
  54. }
  55. /**
  56. Number of nodes that are running at least 1 daemon pod and are supposed to run the daemon pod
  57. <p>
  58. This metric aligns with the @code currentNumberScheduled @endcode field of the
  59. <a
  60. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#daemonsetstatus-v1-apps">K8s
  61. DaemonSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  62. href="../resource/k8s.md#daemonset">@code k8s.daemonset @endcode</a> resource. <p> updowncounter
  63. */
  64. static constexpr const char *kMetricK8sDaemonsetCurrentScheduledNodes =
  65. "k8s.daemonset.current_scheduled_nodes";
  66. static constexpr const char *descrMetricK8sDaemonsetCurrentScheduledNodes =
  67. "Number of nodes that are running at least 1 daemon pod and are supposed to run the daemon pod";
  68. static constexpr const char *unitMetricK8sDaemonsetCurrentScheduledNodes = "{node}";
  69. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  70. CreateSyncInt64MetricK8sDaemonsetCurrentScheduledNodes(metrics::Meter *meter)
  71. {
  72. return meter->CreateInt64UpDownCounter(kMetricK8sDaemonsetCurrentScheduledNodes,
  73. descrMetricK8sDaemonsetCurrentScheduledNodes,
  74. unitMetricK8sDaemonsetCurrentScheduledNodes);
  75. }
  76. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  77. CreateSyncDoubleMetricK8sDaemonsetCurrentScheduledNodes(metrics::Meter *meter)
  78. {
  79. return meter->CreateDoubleUpDownCounter(kMetricK8sDaemonsetCurrentScheduledNodes,
  80. descrMetricK8sDaemonsetCurrentScheduledNodes,
  81. unitMetricK8sDaemonsetCurrentScheduledNodes);
  82. }
  83. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  84. CreateAsyncInt64MetricK8sDaemonsetCurrentScheduledNodes(metrics::Meter *meter)
  85. {
  86. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sDaemonsetCurrentScheduledNodes,
  87. descrMetricK8sDaemonsetCurrentScheduledNodes,
  88. unitMetricK8sDaemonsetCurrentScheduledNodes);
  89. }
  90. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  91. CreateAsyncDoubleMetricK8sDaemonsetCurrentScheduledNodes(metrics::Meter *meter)
  92. {
  93. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sDaemonsetCurrentScheduledNodes,
  94. descrMetricK8sDaemonsetCurrentScheduledNodes,
  95. unitMetricK8sDaemonsetCurrentScheduledNodes);
  96. }
  97. /**
  98. Number of nodes that should be running the daemon pod (including nodes currently running the
  99. daemon pod) <p> This metric aligns with the @code desiredNumberScheduled @endcode field of the <a
  100. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#daemonsetstatus-v1-apps">K8s
  101. DaemonSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  102. href="../resource/k8s.md#daemonset">@code k8s.daemonset @endcode</a> resource. <p> updowncounter
  103. */
  104. static constexpr const char *kMetricK8sDaemonsetDesiredScheduledNodes =
  105. "k8s.daemonset.desired_scheduled_nodes";
  106. static constexpr const char *descrMetricK8sDaemonsetDesiredScheduledNodes =
  107. "Number of nodes that should be running the daemon pod (including nodes currently running the "
  108. "daemon pod)";
  109. static constexpr const char *unitMetricK8sDaemonsetDesiredScheduledNodes = "{node}";
  110. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  111. CreateSyncInt64MetricK8sDaemonsetDesiredScheduledNodes(metrics::Meter *meter)
  112. {
  113. return meter->CreateInt64UpDownCounter(kMetricK8sDaemonsetDesiredScheduledNodes,
  114. descrMetricK8sDaemonsetDesiredScheduledNodes,
  115. unitMetricK8sDaemonsetDesiredScheduledNodes);
  116. }
  117. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  118. CreateSyncDoubleMetricK8sDaemonsetDesiredScheduledNodes(metrics::Meter *meter)
  119. {
  120. return meter->CreateDoubleUpDownCounter(kMetricK8sDaemonsetDesiredScheduledNodes,
  121. descrMetricK8sDaemonsetDesiredScheduledNodes,
  122. unitMetricK8sDaemonsetDesiredScheduledNodes);
  123. }
  124. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  125. CreateAsyncInt64MetricK8sDaemonsetDesiredScheduledNodes(metrics::Meter *meter)
  126. {
  127. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sDaemonsetDesiredScheduledNodes,
  128. descrMetricK8sDaemonsetDesiredScheduledNodes,
  129. unitMetricK8sDaemonsetDesiredScheduledNodes);
  130. }
  131. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  132. CreateAsyncDoubleMetricK8sDaemonsetDesiredScheduledNodes(metrics::Meter *meter)
  133. {
  134. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sDaemonsetDesiredScheduledNodes,
  135. descrMetricK8sDaemonsetDesiredScheduledNodes,
  136. unitMetricK8sDaemonsetDesiredScheduledNodes);
  137. }
  138. /**
  139. Number of nodes that are running the daemon pod, but are not supposed to run the daemon pod
  140. <p>
  141. This metric aligns with the @code numberMisscheduled @endcode field of the
  142. <a
  143. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#daemonsetstatus-v1-apps">K8s
  144. DaemonSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  145. href="../resource/k8s.md#daemonset">@code k8s.daemonset @endcode</a> resource. <p> updowncounter
  146. */
  147. static constexpr const char *kMetricK8sDaemonsetMisscheduledNodes =
  148. "k8s.daemonset.misscheduled_nodes";
  149. static constexpr const char *descrMetricK8sDaemonsetMisscheduledNodes =
  150. "Number of nodes that are running the daemon pod, but are not supposed to run the daemon pod";
  151. static constexpr const char *unitMetricK8sDaemonsetMisscheduledNodes = "{node}";
  152. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  153. CreateSyncInt64MetricK8sDaemonsetMisscheduledNodes(metrics::Meter *meter)
  154. {
  155. return meter->CreateInt64UpDownCounter(kMetricK8sDaemonsetMisscheduledNodes,
  156. descrMetricK8sDaemonsetMisscheduledNodes,
  157. unitMetricK8sDaemonsetMisscheduledNodes);
  158. }
  159. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  160. CreateSyncDoubleMetricK8sDaemonsetMisscheduledNodes(metrics::Meter *meter)
  161. {
  162. return meter->CreateDoubleUpDownCounter(kMetricK8sDaemonsetMisscheduledNodes,
  163. descrMetricK8sDaemonsetMisscheduledNodes,
  164. unitMetricK8sDaemonsetMisscheduledNodes);
  165. }
  166. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  167. CreateAsyncInt64MetricK8sDaemonsetMisscheduledNodes(metrics::Meter *meter)
  168. {
  169. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sDaemonsetMisscheduledNodes,
  170. descrMetricK8sDaemonsetMisscheduledNodes,
  171. unitMetricK8sDaemonsetMisscheduledNodes);
  172. }
  173. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  174. CreateAsyncDoubleMetricK8sDaemonsetMisscheduledNodes(metrics::Meter *meter)
  175. {
  176. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sDaemonsetMisscheduledNodes,
  177. descrMetricK8sDaemonsetMisscheduledNodes,
  178. unitMetricK8sDaemonsetMisscheduledNodes);
  179. }
  180. /**
  181. Number of nodes that should be running the daemon pod and have one or more of the daemon pod
  182. running and ready <p> This metric aligns with the @code numberReady @endcode field of the <a
  183. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#daemonsetstatus-v1-apps">K8s
  184. DaemonSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  185. href="../resource/k8s.md#daemonset">@code k8s.daemonset @endcode</a> resource. <p> updowncounter
  186. */
  187. static constexpr const char *kMetricK8sDaemonsetReadyNodes = "k8s.daemonset.ready_nodes";
  188. static constexpr const char *descrMetricK8sDaemonsetReadyNodes =
  189. "Number of nodes that should be running the daemon pod and have one or more of the daemon pod "
  190. "running and ready";
  191. static constexpr const char *unitMetricK8sDaemonsetReadyNodes = "{node}";
  192. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  193. CreateSyncInt64MetricK8sDaemonsetReadyNodes(metrics::Meter *meter)
  194. {
  195. return meter->CreateInt64UpDownCounter(kMetricK8sDaemonsetReadyNodes,
  196. descrMetricK8sDaemonsetReadyNodes,
  197. unitMetricK8sDaemonsetReadyNodes);
  198. }
  199. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  200. CreateSyncDoubleMetricK8sDaemonsetReadyNodes(metrics::Meter *meter)
  201. {
  202. return meter->CreateDoubleUpDownCounter(kMetricK8sDaemonsetReadyNodes,
  203. descrMetricK8sDaemonsetReadyNodes,
  204. unitMetricK8sDaemonsetReadyNodes);
  205. }
  206. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  207. CreateAsyncInt64MetricK8sDaemonsetReadyNodes(metrics::Meter *meter)
  208. {
  209. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sDaemonsetReadyNodes,
  210. descrMetricK8sDaemonsetReadyNodes,
  211. unitMetricK8sDaemonsetReadyNodes);
  212. }
  213. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  214. CreateAsyncDoubleMetricK8sDaemonsetReadyNodes(metrics::Meter *meter)
  215. {
  216. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sDaemonsetReadyNodes,
  217. descrMetricK8sDaemonsetReadyNodes,
  218. unitMetricK8sDaemonsetReadyNodes);
  219. }
  220. /**
  221. Total number of available replica pods (ready for at least minReadySeconds) targeted by this
  222. deployment <p> This metric aligns with the @code availableReplicas @endcode field of the <a
  223. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#deploymentstatus-v1-apps">K8s
  224. DeploymentStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  225. href="../resource/k8s.md#deployment">@code k8s.deployment @endcode</a> resource. <p> updowncounter
  226. */
  227. static constexpr const char *kMetricK8sDeploymentAvailablePods = "k8s.deployment.available_pods";
  228. static constexpr const char *descrMetricK8sDeploymentAvailablePods =
  229. "Total number of available replica pods (ready for at least minReadySeconds) targeted by this "
  230. "deployment";
  231. static constexpr const char *unitMetricK8sDeploymentAvailablePods = "{pod}";
  232. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  233. CreateSyncInt64MetricK8sDeploymentAvailablePods(metrics::Meter *meter)
  234. {
  235. return meter->CreateInt64UpDownCounter(kMetricK8sDeploymentAvailablePods,
  236. descrMetricK8sDeploymentAvailablePods,
  237. unitMetricK8sDeploymentAvailablePods);
  238. }
  239. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  240. CreateSyncDoubleMetricK8sDeploymentAvailablePods(metrics::Meter *meter)
  241. {
  242. return meter->CreateDoubleUpDownCounter(kMetricK8sDeploymentAvailablePods,
  243. descrMetricK8sDeploymentAvailablePods,
  244. unitMetricK8sDeploymentAvailablePods);
  245. }
  246. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  247. CreateAsyncInt64MetricK8sDeploymentAvailablePods(metrics::Meter *meter)
  248. {
  249. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sDeploymentAvailablePods,
  250. descrMetricK8sDeploymentAvailablePods,
  251. unitMetricK8sDeploymentAvailablePods);
  252. }
  253. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  254. CreateAsyncDoubleMetricK8sDeploymentAvailablePods(metrics::Meter *meter)
  255. {
  256. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sDeploymentAvailablePods,
  257. descrMetricK8sDeploymentAvailablePods,
  258. unitMetricK8sDeploymentAvailablePods);
  259. }
  260. /**
  261. Number of desired replica pods in this deployment
  262. <p>
  263. This metric aligns with the @code replicas @endcode field of the
  264. <a
  265. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#deploymentspec-v1-apps">K8s
  266. DeploymentSpec</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  267. href="../resource/k8s.md#deployment">@code k8s.deployment @endcode</a> resource. <p> updowncounter
  268. */
  269. static constexpr const char *kMetricK8sDeploymentDesiredPods = "k8s.deployment.desired_pods";
  270. static constexpr const char *descrMetricK8sDeploymentDesiredPods =
  271. "Number of desired replica pods in this deployment";
  272. static constexpr const char *unitMetricK8sDeploymentDesiredPods = "{pod}";
  273. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  274. CreateSyncInt64MetricK8sDeploymentDesiredPods(metrics::Meter *meter)
  275. {
  276. return meter->CreateInt64UpDownCounter(kMetricK8sDeploymentDesiredPods,
  277. descrMetricK8sDeploymentDesiredPods,
  278. unitMetricK8sDeploymentDesiredPods);
  279. }
  280. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  281. CreateSyncDoubleMetricK8sDeploymentDesiredPods(metrics::Meter *meter)
  282. {
  283. return meter->CreateDoubleUpDownCounter(kMetricK8sDeploymentDesiredPods,
  284. descrMetricK8sDeploymentDesiredPods,
  285. unitMetricK8sDeploymentDesiredPods);
  286. }
  287. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  288. CreateAsyncInt64MetricK8sDeploymentDesiredPods(metrics::Meter *meter)
  289. {
  290. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sDeploymentDesiredPods,
  291. descrMetricK8sDeploymentDesiredPods,
  292. unitMetricK8sDeploymentDesiredPods);
  293. }
  294. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  295. CreateAsyncDoubleMetricK8sDeploymentDesiredPods(metrics::Meter *meter)
  296. {
  297. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sDeploymentDesiredPods,
  298. descrMetricK8sDeploymentDesiredPods,
  299. unitMetricK8sDeploymentDesiredPods);
  300. }
  301. /**
  302. Current number of replica pods managed by this horizontal pod autoscaler, as last seen by the
  303. autoscaler <p> This metric aligns with the @code currentReplicas @endcode field of the <a
  304. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#horizontalpodautoscalerstatus-v2-autoscaling">K8s
  305. HorizontalPodAutoscalerStatus</a> <p> This metric SHOULD, at a minimum, be reported against a <a
  306. href="../resource/k8s.md#horizontalpodautoscaler">@code k8s.hpa @endcode</a> resource. <p>
  307. updowncounter
  308. */
  309. static constexpr const char *kMetricK8sHpaCurrentPods = "k8s.hpa.current_pods";
  310. static constexpr const char *descrMetricK8sHpaCurrentPods =
  311. "Current number of replica pods managed by this horizontal pod autoscaler, as last seen by the "
  312. "autoscaler";
  313. static constexpr const char *unitMetricK8sHpaCurrentPods = "{pod}";
  314. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  315. CreateSyncInt64MetricK8sHpaCurrentPods(metrics::Meter *meter)
  316. {
  317. return meter->CreateInt64UpDownCounter(kMetricK8sHpaCurrentPods, descrMetricK8sHpaCurrentPods,
  318. unitMetricK8sHpaCurrentPods);
  319. }
  320. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  321. CreateSyncDoubleMetricK8sHpaCurrentPods(metrics::Meter *meter)
  322. {
  323. return meter->CreateDoubleUpDownCounter(kMetricK8sHpaCurrentPods, descrMetricK8sHpaCurrentPods,
  324. unitMetricK8sHpaCurrentPods);
  325. }
  326. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  327. CreateAsyncInt64MetricK8sHpaCurrentPods(metrics::Meter *meter)
  328. {
  329. return meter->CreateInt64ObservableUpDownCounter(
  330. kMetricK8sHpaCurrentPods, descrMetricK8sHpaCurrentPods, unitMetricK8sHpaCurrentPods);
  331. }
  332. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  333. CreateAsyncDoubleMetricK8sHpaCurrentPods(metrics::Meter *meter)
  334. {
  335. return meter->CreateDoubleObservableUpDownCounter(
  336. kMetricK8sHpaCurrentPods, descrMetricK8sHpaCurrentPods, unitMetricK8sHpaCurrentPods);
  337. }
  338. /**
  339. Desired number of replica pods managed by this horizontal pod autoscaler, as last calculated by
  340. the autoscaler <p> This metric aligns with the @code desiredReplicas @endcode field of the <a
  341. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#horizontalpodautoscalerstatus-v2-autoscaling">K8s
  342. HorizontalPodAutoscalerStatus</a> <p> This metric SHOULD, at a minimum, be reported against a <a
  343. href="../resource/k8s.md#horizontalpodautoscaler">@code k8s.hpa @endcode</a> resource. <p>
  344. updowncounter
  345. */
  346. static constexpr const char *kMetricK8sHpaDesiredPods = "k8s.hpa.desired_pods";
  347. static constexpr const char *descrMetricK8sHpaDesiredPods =
  348. "Desired number of replica pods managed by this horizontal pod autoscaler, as last calculated "
  349. "by the autoscaler";
  350. static constexpr const char *unitMetricK8sHpaDesiredPods = "{pod}";
  351. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  352. CreateSyncInt64MetricK8sHpaDesiredPods(metrics::Meter *meter)
  353. {
  354. return meter->CreateInt64UpDownCounter(kMetricK8sHpaDesiredPods, descrMetricK8sHpaDesiredPods,
  355. unitMetricK8sHpaDesiredPods);
  356. }
  357. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  358. CreateSyncDoubleMetricK8sHpaDesiredPods(metrics::Meter *meter)
  359. {
  360. return meter->CreateDoubleUpDownCounter(kMetricK8sHpaDesiredPods, descrMetricK8sHpaDesiredPods,
  361. unitMetricK8sHpaDesiredPods);
  362. }
  363. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  364. CreateAsyncInt64MetricK8sHpaDesiredPods(metrics::Meter *meter)
  365. {
  366. return meter->CreateInt64ObservableUpDownCounter(
  367. kMetricK8sHpaDesiredPods, descrMetricK8sHpaDesiredPods, unitMetricK8sHpaDesiredPods);
  368. }
  369. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  370. CreateAsyncDoubleMetricK8sHpaDesiredPods(metrics::Meter *meter)
  371. {
  372. return meter->CreateDoubleObservableUpDownCounter(
  373. kMetricK8sHpaDesiredPods, descrMetricK8sHpaDesiredPods, unitMetricK8sHpaDesiredPods);
  374. }
  375. /**
  376. The upper limit for the number of replica pods to which the autoscaler can scale up
  377. <p>
  378. This metric aligns with the @code maxReplicas @endcode field of the
  379. <a
  380. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#horizontalpodautoscalerspec-v2-autoscaling">K8s
  381. HorizontalPodAutoscalerSpec</a> <p> This metric SHOULD, at a minimum, be reported against a <a
  382. href="../resource/k8s.md#horizontalpodautoscaler">@code k8s.hpa @endcode</a> resource. <p>
  383. updowncounter
  384. */
  385. static constexpr const char *kMetricK8sHpaMaxPods = "k8s.hpa.max_pods";
  386. static constexpr const char *descrMetricK8sHpaMaxPods =
  387. "The upper limit for the number of replica pods to which the autoscaler can scale up";
  388. static constexpr const char *unitMetricK8sHpaMaxPods = "{pod}";
  389. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>> CreateSyncInt64MetricK8sHpaMaxPods(
  390. metrics::Meter *meter)
  391. {
  392. return meter->CreateInt64UpDownCounter(kMetricK8sHpaMaxPods, descrMetricK8sHpaMaxPods,
  393. unitMetricK8sHpaMaxPods);
  394. }
  395. static inline nostd::unique_ptr<metrics::UpDownCounter<double>> CreateSyncDoubleMetricK8sHpaMaxPods(
  396. metrics::Meter *meter)
  397. {
  398. return meter->CreateDoubleUpDownCounter(kMetricK8sHpaMaxPods, descrMetricK8sHpaMaxPods,
  399. unitMetricK8sHpaMaxPods);
  400. }
  401. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sHpaMaxPods(
  402. metrics::Meter *meter)
  403. {
  404. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sHpaMaxPods, descrMetricK8sHpaMaxPods,
  405. unitMetricK8sHpaMaxPods);
  406. }
  407. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncDoubleMetricK8sHpaMaxPods(
  408. metrics::Meter *meter)
  409. {
  410. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sHpaMaxPods, descrMetricK8sHpaMaxPods,
  411. unitMetricK8sHpaMaxPods);
  412. }
  413. /**
  414. The lower limit for the number of replica pods to which the autoscaler can scale down
  415. <p>
  416. This metric aligns with the @code minReplicas @endcode field of the
  417. <a
  418. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#horizontalpodautoscalerspec-v2-autoscaling">K8s
  419. HorizontalPodAutoscalerSpec</a> <p> This metric SHOULD, at a minimum, be reported against a <a
  420. href="../resource/k8s.md#horizontalpodautoscaler">@code k8s.hpa @endcode</a> resource. <p>
  421. updowncounter
  422. */
  423. static constexpr const char *kMetricK8sHpaMinPods = "k8s.hpa.min_pods";
  424. static constexpr const char *descrMetricK8sHpaMinPods =
  425. "The lower limit for the number of replica pods to which the autoscaler can scale down";
  426. static constexpr const char *unitMetricK8sHpaMinPods = "{pod}";
  427. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>> CreateSyncInt64MetricK8sHpaMinPods(
  428. metrics::Meter *meter)
  429. {
  430. return meter->CreateInt64UpDownCounter(kMetricK8sHpaMinPods, descrMetricK8sHpaMinPods,
  431. unitMetricK8sHpaMinPods);
  432. }
  433. static inline nostd::unique_ptr<metrics::UpDownCounter<double>> CreateSyncDoubleMetricK8sHpaMinPods(
  434. metrics::Meter *meter)
  435. {
  436. return meter->CreateDoubleUpDownCounter(kMetricK8sHpaMinPods, descrMetricK8sHpaMinPods,
  437. unitMetricK8sHpaMinPods);
  438. }
  439. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sHpaMinPods(
  440. metrics::Meter *meter)
  441. {
  442. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sHpaMinPods, descrMetricK8sHpaMinPods,
  443. unitMetricK8sHpaMinPods);
  444. }
  445. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncDoubleMetricK8sHpaMinPods(
  446. metrics::Meter *meter)
  447. {
  448. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sHpaMinPods, descrMetricK8sHpaMinPods,
  449. unitMetricK8sHpaMinPods);
  450. }
  451. /**
  452. The number of pending and actively running pods for a job
  453. <p>
  454. This metric aligns with the @code active @endcode field of the
  455. <a
  456. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#jobstatus-v1-batch">K8s
  457. JobStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  458. href="../resource/k8s.md#job">@code k8s.job @endcode</a> resource. <p> updowncounter
  459. */
  460. static constexpr const char *kMetricK8sJobActivePods = "k8s.job.active_pods";
  461. static constexpr const char *descrMetricK8sJobActivePods =
  462. "The number of pending and actively running pods for a job";
  463. static constexpr const char *unitMetricK8sJobActivePods = "{pod}";
  464. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  465. CreateSyncInt64MetricK8sJobActivePods(metrics::Meter *meter)
  466. {
  467. return meter->CreateInt64UpDownCounter(kMetricK8sJobActivePods, descrMetricK8sJobActivePods,
  468. unitMetricK8sJobActivePods);
  469. }
  470. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  471. CreateSyncDoubleMetricK8sJobActivePods(metrics::Meter *meter)
  472. {
  473. return meter->CreateDoubleUpDownCounter(kMetricK8sJobActivePods, descrMetricK8sJobActivePods,
  474. unitMetricK8sJobActivePods);
  475. }
  476. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  477. CreateAsyncInt64MetricK8sJobActivePods(metrics::Meter *meter)
  478. {
  479. return meter->CreateInt64ObservableUpDownCounter(
  480. kMetricK8sJobActivePods, descrMetricK8sJobActivePods, unitMetricK8sJobActivePods);
  481. }
  482. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  483. CreateAsyncDoubleMetricK8sJobActivePods(metrics::Meter *meter)
  484. {
  485. return meter->CreateDoubleObservableUpDownCounter(
  486. kMetricK8sJobActivePods, descrMetricK8sJobActivePods, unitMetricK8sJobActivePods);
  487. }
  488. /**
  489. The desired number of successfully finished pods the job should be run with
  490. <p>
  491. This metric aligns with the @code completions @endcode field of the
  492. <a
  493. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#jobspec-v1-batch">K8s
  494. JobSpec</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  495. href="../resource/k8s.md#job">@code k8s.job @endcode</a> resource. <p> updowncounter
  496. */
  497. static constexpr const char *kMetricK8sJobDesiredSuccessfulPods = "k8s.job.desired_successful_pods";
  498. static constexpr const char *descrMetricK8sJobDesiredSuccessfulPods =
  499. "The desired number of successfully finished pods the job should be run with";
  500. static constexpr const char *unitMetricK8sJobDesiredSuccessfulPods = "{pod}";
  501. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  502. CreateSyncInt64MetricK8sJobDesiredSuccessfulPods(metrics::Meter *meter)
  503. {
  504. return meter->CreateInt64UpDownCounter(kMetricK8sJobDesiredSuccessfulPods,
  505. descrMetricK8sJobDesiredSuccessfulPods,
  506. unitMetricK8sJobDesiredSuccessfulPods);
  507. }
  508. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  509. CreateSyncDoubleMetricK8sJobDesiredSuccessfulPods(metrics::Meter *meter)
  510. {
  511. return meter->CreateDoubleUpDownCounter(kMetricK8sJobDesiredSuccessfulPods,
  512. descrMetricK8sJobDesiredSuccessfulPods,
  513. unitMetricK8sJobDesiredSuccessfulPods);
  514. }
  515. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  516. CreateAsyncInt64MetricK8sJobDesiredSuccessfulPods(metrics::Meter *meter)
  517. {
  518. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sJobDesiredSuccessfulPods,
  519. descrMetricK8sJobDesiredSuccessfulPods,
  520. unitMetricK8sJobDesiredSuccessfulPods);
  521. }
  522. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  523. CreateAsyncDoubleMetricK8sJobDesiredSuccessfulPods(metrics::Meter *meter)
  524. {
  525. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sJobDesiredSuccessfulPods,
  526. descrMetricK8sJobDesiredSuccessfulPods,
  527. unitMetricK8sJobDesiredSuccessfulPods);
  528. }
  529. /**
  530. The number of pods which reached phase Failed for a job
  531. <p>
  532. This metric aligns with the @code failed @endcode field of the
  533. <a
  534. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#jobstatus-v1-batch">K8s
  535. JobStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  536. href="../resource/k8s.md#job">@code k8s.job @endcode</a> resource. <p> updowncounter
  537. */
  538. static constexpr const char *kMetricK8sJobFailedPods = "k8s.job.failed_pods";
  539. static constexpr const char *descrMetricK8sJobFailedPods =
  540. "The number of pods which reached phase Failed for a job";
  541. static constexpr const char *unitMetricK8sJobFailedPods = "{pod}";
  542. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  543. CreateSyncInt64MetricK8sJobFailedPods(metrics::Meter *meter)
  544. {
  545. return meter->CreateInt64UpDownCounter(kMetricK8sJobFailedPods, descrMetricK8sJobFailedPods,
  546. unitMetricK8sJobFailedPods);
  547. }
  548. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  549. CreateSyncDoubleMetricK8sJobFailedPods(metrics::Meter *meter)
  550. {
  551. return meter->CreateDoubleUpDownCounter(kMetricK8sJobFailedPods, descrMetricK8sJobFailedPods,
  552. unitMetricK8sJobFailedPods);
  553. }
  554. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  555. CreateAsyncInt64MetricK8sJobFailedPods(metrics::Meter *meter)
  556. {
  557. return meter->CreateInt64ObservableUpDownCounter(
  558. kMetricK8sJobFailedPods, descrMetricK8sJobFailedPods, unitMetricK8sJobFailedPods);
  559. }
  560. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  561. CreateAsyncDoubleMetricK8sJobFailedPods(metrics::Meter *meter)
  562. {
  563. return meter->CreateDoubleObservableUpDownCounter(
  564. kMetricK8sJobFailedPods, descrMetricK8sJobFailedPods, unitMetricK8sJobFailedPods);
  565. }
  566. /**
  567. The max desired number of pods the job should run at any given time
  568. <p>
  569. This metric aligns with the @code parallelism @endcode field of the
  570. <a
  571. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#jobspec-v1-batch">K8s
  572. JobSpec</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  573. href="../resource/k8s.md#job">@code k8s.job @endcode</a> resource. <p> updowncounter
  574. */
  575. static constexpr const char *kMetricK8sJobMaxParallelPods = "k8s.job.max_parallel_pods";
  576. static constexpr const char *descrMetricK8sJobMaxParallelPods =
  577. "The max desired number of pods the job should run at any given time";
  578. static constexpr const char *unitMetricK8sJobMaxParallelPods = "{pod}";
  579. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  580. CreateSyncInt64MetricK8sJobMaxParallelPods(metrics::Meter *meter)
  581. {
  582. return meter->CreateInt64UpDownCounter(kMetricK8sJobMaxParallelPods,
  583. descrMetricK8sJobMaxParallelPods,
  584. unitMetricK8sJobMaxParallelPods);
  585. }
  586. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  587. CreateSyncDoubleMetricK8sJobMaxParallelPods(metrics::Meter *meter)
  588. {
  589. return meter->CreateDoubleUpDownCounter(kMetricK8sJobMaxParallelPods,
  590. descrMetricK8sJobMaxParallelPods,
  591. unitMetricK8sJobMaxParallelPods);
  592. }
  593. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  594. CreateAsyncInt64MetricK8sJobMaxParallelPods(metrics::Meter *meter)
  595. {
  596. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sJobMaxParallelPods,
  597. descrMetricK8sJobMaxParallelPods,
  598. unitMetricK8sJobMaxParallelPods);
  599. }
  600. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  601. CreateAsyncDoubleMetricK8sJobMaxParallelPods(metrics::Meter *meter)
  602. {
  603. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sJobMaxParallelPods,
  604. descrMetricK8sJobMaxParallelPods,
  605. unitMetricK8sJobMaxParallelPods);
  606. }
  607. /**
  608. The number of pods which reached phase Succeeded for a job
  609. <p>
  610. This metric aligns with the @code succeeded @endcode field of the
  611. <a
  612. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#jobstatus-v1-batch">K8s
  613. JobStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  614. href="../resource/k8s.md#job">@code k8s.job @endcode</a> resource. <p> updowncounter
  615. */
  616. static constexpr const char *kMetricK8sJobSuccessfulPods = "k8s.job.successful_pods";
  617. static constexpr const char *descrMetricK8sJobSuccessfulPods =
  618. "The number of pods which reached phase Succeeded for a job";
  619. static constexpr const char *unitMetricK8sJobSuccessfulPods = "{pod}";
  620. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  621. CreateSyncInt64MetricK8sJobSuccessfulPods(metrics::Meter *meter)
  622. {
  623. return meter->CreateInt64UpDownCounter(
  624. kMetricK8sJobSuccessfulPods, descrMetricK8sJobSuccessfulPods, unitMetricK8sJobSuccessfulPods);
  625. }
  626. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  627. CreateSyncDoubleMetricK8sJobSuccessfulPods(metrics::Meter *meter)
  628. {
  629. return meter->CreateDoubleUpDownCounter(
  630. kMetricK8sJobSuccessfulPods, descrMetricK8sJobSuccessfulPods, unitMetricK8sJobSuccessfulPods);
  631. }
  632. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  633. CreateAsyncInt64MetricK8sJobSuccessfulPods(metrics::Meter *meter)
  634. {
  635. return meter->CreateInt64ObservableUpDownCounter(
  636. kMetricK8sJobSuccessfulPods, descrMetricK8sJobSuccessfulPods, unitMetricK8sJobSuccessfulPods);
  637. }
  638. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  639. CreateAsyncDoubleMetricK8sJobSuccessfulPods(metrics::Meter *meter)
  640. {
  641. return meter->CreateDoubleObservableUpDownCounter(
  642. kMetricK8sJobSuccessfulPods, descrMetricK8sJobSuccessfulPods, unitMetricK8sJobSuccessfulPods);
  643. }
  644. /**
  645. Describes number of K8s namespaces that are currently in a given phase.
  646. <p>
  647. This metric SHOULD, at a minimum, be reported against a
  648. <a href="../resource/k8s.md#namespace">@code k8s.namespace @endcode</a> resource.
  649. <p>
  650. updowncounter
  651. */
  652. static constexpr const char *kMetricK8sNamespacePhase = "k8s.namespace.phase";
  653. static constexpr const char *descrMetricK8sNamespacePhase =
  654. "Describes number of K8s namespaces that are currently in a given phase.";
  655. static constexpr const char *unitMetricK8sNamespacePhase = "{namespace}";
  656. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  657. CreateSyncInt64MetricK8sNamespacePhase(metrics::Meter *meter)
  658. {
  659. return meter->CreateInt64UpDownCounter(kMetricK8sNamespacePhase, descrMetricK8sNamespacePhase,
  660. unitMetricK8sNamespacePhase);
  661. }
  662. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  663. CreateSyncDoubleMetricK8sNamespacePhase(metrics::Meter *meter)
  664. {
  665. return meter->CreateDoubleUpDownCounter(kMetricK8sNamespacePhase, descrMetricK8sNamespacePhase,
  666. unitMetricK8sNamespacePhase);
  667. }
  668. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  669. CreateAsyncInt64MetricK8sNamespacePhase(metrics::Meter *meter)
  670. {
  671. return meter->CreateInt64ObservableUpDownCounter(
  672. kMetricK8sNamespacePhase, descrMetricK8sNamespacePhase, unitMetricK8sNamespacePhase);
  673. }
  674. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  675. CreateAsyncDoubleMetricK8sNamespacePhase(metrics::Meter *meter)
  676. {
  677. return meter->CreateDoubleObservableUpDownCounter(
  678. kMetricK8sNamespacePhase, descrMetricK8sNamespacePhase, unitMetricK8sNamespacePhase);
  679. }
  680. /**
  681. Total CPU time consumed
  682. <p>
  683. Total CPU time consumed by the specific Node on all available CPU cores
  684. <p>
  685. counter
  686. */
  687. static constexpr const char *kMetricK8sNodeCpuTime = "k8s.node.cpu.time";
  688. static constexpr const char *descrMetricK8sNodeCpuTime = "Total CPU time consumed";
  689. static constexpr const char *unitMetricK8sNodeCpuTime = "s";
  690. static inline nostd::unique_ptr<metrics::Counter<uint64_t>> CreateSyncInt64MetricK8sNodeCpuTime(
  691. metrics::Meter *meter)
  692. {
  693. return meter->CreateUInt64Counter(kMetricK8sNodeCpuTime, descrMetricK8sNodeCpuTime,
  694. unitMetricK8sNodeCpuTime);
  695. }
  696. static inline nostd::unique_ptr<metrics::Counter<double>> CreateSyncDoubleMetricK8sNodeCpuTime(
  697. metrics::Meter *meter)
  698. {
  699. return meter->CreateDoubleCounter(kMetricK8sNodeCpuTime, descrMetricK8sNodeCpuTime,
  700. unitMetricK8sNodeCpuTime);
  701. }
  702. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sNodeCpuTime(
  703. metrics::Meter *meter)
  704. {
  705. return meter->CreateInt64ObservableCounter(kMetricK8sNodeCpuTime, descrMetricK8sNodeCpuTime,
  706. unitMetricK8sNodeCpuTime);
  707. }
  708. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  709. CreateAsyncDoubleMetricK8sNodeCpuTime(metrics::Meter *meter)
  710. {
  711. return meter->CreateDoubleObservableCounter(kMetricK8sNodeCpuTime, descrMetricK8sNodeCpuTime,
  712. unitMetricK8sNodeCpuTime);
  713. }
  714. /**
  715. Node's CPU usage, measured in cpus. Range from 0 to the number of allocatable CPUs
  716. <p>
  717. CPU usage of the specific Node on all available CPU cores, averaged over the sample window
  718. <p>
  719. gauge
  720. */
  721. static constexpr const char *kMetricK8sNodeCpuUsage = "k8s.node.cpu.usage";
  722. static constexpr const char *descrMetricK8sNodeCpuUsage =
  723. "Node's CPU usage, measured in cpus. Range from 0 to the number of allocatable CPUs";
  724. static constexpr const char *unitMetricK8sNodeCpuUsage = "{cpu}";
  725. #if OPENTELEMETRY_ABI_VERSION_NO >= 2
  726. static inline nostd::unique_ptr<metrics::Gauge<int64_t>> CreateSyncInt64MetricK8sNodeCpuUsage(
  727. metrics::Meter *meter)
  728. {
  729. return meter->CreateInt64Gauge(kMetricK8sNodeCpuUsage, descrMetricK8sNodeCpuUsage,
  730. unitMetricK8sNodeCpuUsage);
  731. }
  732. static inline nostd::unique_ptr<metrics::Gauge<double>> CreateSyncDoubleMetricK8sNodeCpuUsage(
  733. metrics::Meter *meter)
  734. {
  735. return meter->CreateDoubleGauge(kMetricK8sNodeCpuUsage, descrMetricK8sNodeCpuUsage,
  736. unitMetricK8sNodeCpuUsage);
  737. }
  738. #endif /* OPENTELEMETRY_ABI_VERSION_NO */
  739. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  740. CreateAsyncInt64MetricK8sNodeCpuUsage(metrics::Meter *meter)
  741. {
  742. return meter->CreateInt64ObservableGauge(kMetricK8sNodeCpuUsage, descrMetricK8sNodeCpuUsage,
  743. unitMetricK8sNodeCpuUsage);
  744. }
  745. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  746. CreateAsyncDoubleMetricK8sNodeCpuUsage(metrics::Meter *meter)
  747. {
  748. return meter->CreateDoubleObservableGauge(kMetricK8sNodeCpuUsage, descrMetricK8sNodeCpuUsage,
  749. unitMetricK8sNodeCpuUsage);
  750. }
  751. /**
  752. Memory usage of the Node
  753. <p>
  754. Total memory usage of the Node
  755. <p>
  756. gauge
  757. */
  758. static constexpr const char *kMetricK8sNodeMemoryUsage = "k8s.node.memory.usage";
  759. static constexpr const char *descrMetricK8sNodeMemoryUsage = "Memory usage of the Node";
  760. static constexpr const char *unitMetricK8sNodeMemoryUsage = "By";
  761. #if OPENTELEMETRY_ABI_VERSION_NO >= 2
  762. static inline nostd::unique_ptr<metrics::Gauge<int64_t>> CreateSyncInt64MetricK8sNodeMemoryUsage(
  763. metrics::Meter *meter)
  764. {
  765. return meter->CreateInt64Gauge(kMetricK8sNodeMemoryUsage, descrMetricK8sNodeMemoryUsage,
  766. unitMetricK8sNodeMemoryUsage);
  767. }
  768. static inline nostd::unique_ptr<metrics::Gauge<double>> CreateSyncDoubleMetricK8sNodeMemoryUsage(
  769. metrics::Meter *meter)
  770. {
  771. return meter->CreateDoubleGauge(kMetricK8sNodeMemoryUsage, descrMetricK8sNodeMemoryUsage,
  772. unitMetricK8sNodeMemoryUsage);
  773. }
  774. #endif /* OPENTELEMETRY_ABI_VERSION_NO */
  775. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  776. CreateAsyncInt64MetricK8sNodeMemoryUsage(metrics::Meter *meter)
  777. {
  778. return meter->CreateInt64ObservableGauge(kMetricK8sNodeMemoryUsage, descrMetricK8sNodeMemoryUsage,
  779. unitMetricK8sNodeMemoryUsage);
  780. }
  781. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  782. CreateAsyncDoubleMetricK8sNodeMemoryUsage(metrics::Meter *meter)
  783. {
  784. return meter->CreateDoubleObservableGauge(
  785. kMetricK8sNodeMemoryUsage, descrMetricK8sNodeMemoryUsage, unitMetricK8sNodeMemoryUsage);
  786. }
  787. /**
  788. Node network errors
  789. <p>
  790. counter
  791. */
  792. static constexpr const char *kMetricK8sNodeNetworkErrors = "k8s.node.network.errors";
  793. static constexpr const char *descrMetricK8sNodeNetworkErrors = "Node network errors";
  794. static constexpr const char *unitMetricK8sNodeNetworkErrors = "{error}";
  795. static inline nostd::unique_ptr<metrics::Counter<uint64_t>>
  796. CreateSyncInt64MetricK8sNodeNetworkErrors(metrics::Meter *meter)
  797. {
  798. return meter->CreateUInt64Counter(kMetricK8sNodeNetworkErrors, descrMetricK8sNodeNetworkErrors,
  799. unitMetricK8sNodeNetworkErrors);
  800. }
  801. static inline nostd::unique_ptr<metrics::Counter<double>>
  802. CreateSyncDoubleMetricK8sNodeNetworkErrors(metrics::Meter *meter)
  803. {
  804. return meter->CreateDoubleCounter(kMetricK8sNodeNetworkErrors, descrMetricK8sNodeNetworkErrors,
  805. unitMetricK8sNodeNetworkErrors);
  806. }
  807. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  808. CreateAsyncInt64MetricK8sNodeNetworkErrors(metrics::Meter *meter)
  809. {
  810. return meter->CreateInt64ObservableCounter(
  811. kMetricK8sNodeNetworkErrors, descrMetricK8sNodeNetworkErrors, unitMetricK8sNodeNetworkErrors);
  812. }
  813. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  814. CreateAsyncDoubleMetricK8sNodeNetworkErrors(metrics::Meter *meter)
  815. {
  816. return meter->CreateDoubleObservableCounter(
  817. kMetricK8sNodeNetworkErrors, descrMetricK8sNodeNetworkErrors, unitMetricK8sNodeNetworkErrors);
  818. }
  819. /**
  820. Network bytes for the Node
  821. <p>
  822. counter
  823. */
  824. static constexpr const char *kMetricK8sNodeNetworkIo = "k8s.node.network.io";
  825. static constexpr const char *descrMetricK8sNodeNetworkIo = "Network bytes for the Node";
  826. static constexpr const char *unitMetricK8sNodeNetworkIo = "By";
  827. static inline nostd::unique_ptr<metrics::Counter<uint64_t>> CreateSyncInt64MetricK8sNodeNetworkIo(
  828. metrics::Meter *meter)
  829. {
  830. return meter->CreateUInt64Counter(kMetricK8sNodeNetworkIo, descrMetricK8sNodeNetworkIo,
  831. unitMetricK8sNodeNetworkIo);
  832. }
  833. static inline nostd::unique_ptr<metrics::Counter<double>> CreateSyncDoubleMetricK8sNodeNetworkIo(
  834. metrics::Meter *meter)
  835. {
  836. return meter->CreateDoubleCounter(kMetricK8sNodeNetworkIo, descrMetricK8sNodeNetworkIo,
  837. unitMetricK8sNodeNetworkIo);
  838. }
  839. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  840. CreateAsyncInt64MetricK8sNodeNetworkIo(metrics::Meter *meter)
  841. {
  842. return meter->CreateInt64ObservableCounter(kMetricK8sNodeNetworkIo, descrMetricK8sNodeNetworkIo,
  843. unitMetricK8sNodeNetworkIo);
  844. }
  845. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  846. CreateAsyncDoubleMetricK8sNodeNetworkIo(metrics::Meter *meter)
  847. {
  848. return meter->CreateDoubleObservableCounter(kMetricK8sNodeNetworkIo, descrMetricK8sNodeNetworkIo,
  849. unitMetricK8sNodeNetworkIo);
  850. }
  851. /**
  852. The time the Node has been running
  853. <p>
  854. Instrumentations SHOULD use a gauge with type @code double @endcode and measure uptime in seconds
  855. as a floating point number with the highest precision available. The actual accuracy would depend
  856. on the instrumentation and operating system. <p> gauge
  857. */
  858. static constexpr const char *kMetricK8sNodeUptime = "k8s.node.uptime";
  859. static constexpr const char *descrMetricK8sNodeUptime = "The time the Node has been running";
  860. static constexpr const char *unitMetricK8sNodeUptime = "s";
  861. #if OPENTELEMETRY_ABI_VERSION_NO >= 2
  862. static inline nostd::unique_ptr<metrics::Gauge<int64_t>> CreateSyncInt64MetricK8sNodeUptime(
  863. metrics::Meter *meter)
  864. {
  865. return meter->CreateInt64Gauge(kMetricK8sNodeUptime, descrMetricK8sNodeUptime,
  866. unitMetricK8sNodeUptime);
  867. }
  868. static inline nostd::unique_ptr<metrics::Gauge<double>> CreateSyncDoubleMetricK8sNodeUptime(
  869. metrics::Meter *meter)
  870. {
  871. return meter->CreateDoubleGauge(kMetricK8sNodeUptime, descrMetricK8sNodeUptime,
  872. unitMetricK8sNodeUptime);
  873. }
  874. #endif /* OPENTELEMETRY_ABI_VERSION_NO */
  875. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sNodeUptime(
  876. metrics::Meter *meter)
  877. {
  878. return meter->CreateInt64ObservableGauge(kMetricK8sNodeUptime, descrMetricK8sNodeUptime,
  879. unitMetricK8sNodeUptime);
  880. }
  881. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncDoubleMetricK8sNodeUptime(
  882. metrics::Meter *meter)
  883. {
  884. return meter->CreateDoubleObservableGauge(kMetricK8sNodeUptime, descrMetricK8sNodeUptime,
  885. unitMetricK8sNodeUptime);
  886. }
  887. /**
  888. Total CPU time consumed
  889. <p>
  890. Total CPU time consumed by the specific Pod on all available CPU cores
  891. <p>
  892. counter
  893. */
  894. static constexpr const char *kMetricK8sPodCpuTime = "k8s.pod.cpu.time";
  895. static constexpr const char *descrMetricK8sPodCpuTime = "Total CPU time consumed";
  896. static constexpr const char *unitMetricK8sPodCpuTime = "s";
  897. static inline nostd::unique_ptr<metrics::Counter<uint64_t>> CreateSyncInt64MetricK8sPodCpuTime(
  898. metrics::Meter *meter)
  899. {
  900. return meter->CreateUInt64Counter(kMetricK8sPodCpuTime, descrMetricK8sPodCpuTime,
  901. unitMetricK8sPodCpuTime);
  902. }
  903. static inline nostd::unique_ptr<metrics::Counter<double>> CreateSyncDoubleMetricK8sPodCpuTime(
  904. metrics::Meter *meter)
  905. {
  906. return meter->CreateDoubleCounter(kMetricK8sPodCpuTime, descrMetricK8sPodCpuTime,
  907. unitMetricK8sPodCpuTime);
  908. }
  909. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sPodCpuTime(
  910. metrics::Meter *meter)
  911. {
  912. return meter->CreateInt64ObservableCounter(kMetricK8sPodCpuTime, descrMetricK8sPodCpuTime,
  913. unitMetricK8sPodCpuTime);
  914. }
  915. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncDoubleMetricK8sPodCpuTime(
  916. metrics::Meter *meter)
  917. {
  918. return meter->CreateDoubleObservableCounter(kMetricK8sPodCpuTime, descrMetricK8sPodCpuTime,
  919. unitMetricK8sPodCpuTime);
  920. }
  921. /**
  922. Pod's CPU usage, measured in cpus. Range from 0 to the number of allocatable CPUs
  923. <p>
  924. CPU usage of the specific Pod on all available CPU cores, averaged over the sample window
  925. <p>
  926. gauge
  927. */
  928. static constexpr const char *kMetricK8sPodCpuUsage = "k8s.pod.cpu.usage";
  929. static constexpr const char *descrMetricK8sPodCpuUsage =
  930. "Pod's CPU usage, measured in cpus. Range from 0 to the number of allocatable CPUs";
  931. static constexpr const char *unitMetricK8sPodCpuUsage = "{cpu}";
  932. #if OPENTELEMETRY_ABI_VERSION_NO >= 2
  933. static inline nostd::unique_ptr<metrics::Gauge<int64_t>> CreateSyncInt64MetricK8sPodCpuUsage(
  934. metrics::Meter *meter)
  935. {
  936. return meter->CreateInt64Gauge(kMetricK8sPodCpuUsage, descrMetricK8sPodCpuUsage,
  937. unitMetricK8sPodCpuUsage);
  938. }
  939. static inline nostd::unique_ptr<metrics::Gauge<double>> CreateSyncDoubleMetricK8sPodCpuUsage(
  940. metrics::Meter *meter)
  941. {
  942. return meter->CreateDoubleGauge(kMetricK8sPodCpuUsage, descrMetricK8sPodCpuUsage,
  943. unitMetricK8sPodCpuUsage);
  944. }
  945. #endif /* OPENTELEMETRY_ABI_VERSION_NO */
  946. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sPodCpuUsage(
  947. metrics::Meter *meter)
  948. {
  949. return meter->CreateInt64ObservableGauge(kMetricK8sPodCpuUsage, descrMetricK8sPodCpuUsage,
  950. unitMetricK8sPodCpuUsage);
  951. }
  952. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  953. CreateAsyncDoubleMetricK8sPodCpuUsage(metrics::Meter *meter)
  954. {
  955. return meter->CreateDoubleObservableGauge(kMetricK8sPodCpuUsage, descrMetricK8sPodCpuUsage,
  956. unitMetricK8sPodCpuUsage);
  957. }
  958. /**
  959. Memory usage of the Pod
  960. <p>
  961. Total memory usage of the Pod
  962. <p>
  963. gauge
  964. */
  965. static constexpr const char *kMetricK8sPodMemoryUsage = "k8s.pod.memory.usage";
  966. static constexpr const char *descrMetricK8sPodMemoryUsage = "Memory usage of the Pod";
  967. static constexpr const char *unitMetricK8sPodMemoryUsage = "By";
  968. #if OPENTELEMETRY_ABI_VERSION_NO >= 2
  969. static inline nostd::unique_ptr<metrics::Gauge<int64_t>> CreateSyncInt64MetricK8sPodMemoryUsage(
  970. metrics::Meter *meter)
  971. {
  972. return meter->CreateInt64Gauge(kMetricK8sPodMemoryUsage, descrMetricK8sPodMemoryUsage,
  973. unitMetricK8sPodMemoryUsage);
  974. }
  975. static inline nostd::unique_ptr<metrics::Gauge<double>> CreateSyncDoubleMetricK8sPodMemoryUsage(
  976. metrics::Meter *meter)
  977. {
  978. return meter->CreateDoubleGauge(kMetricK8sPodMemoryUsage, descrMetricK8sPodMemoryUsage,
  979. unitMetricK8sPodMemoryUsage);
  980. }
  981. #endif /* OPENTELEMETRY_ABI_VERSION_NO */
  982. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  983. CreateAsyncInt64MetricK8sPodMemoryUsage(metrics::Meter *meter)
  984. {
  985. return meter->CreateInt64ObservableGauge(kMetricK8sPodMemoryUsage, descrMetricK8sPodMemoryUsage,
  986. unitMetricK8sPodMemoryUsage);
  987. }
  988. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  989. CreateAsyncDoubleMetricK8sPodMemoryUsage(metrics::Meter *meter)
  990. {
  991. return meter->CreateDoubleObservableGauge(kMetricK8sPodMemoryUsage, descrMetricK8sPodMemoryUsage,
  992. unitMetricK8sPodMemoryUsage);
  993. }
  994. /**
  995. Pod network errors
  996. <p>
  997. counter
  998. */
  999. static constexpr const char *kMetricK8sPodNetworkErrors = "k8s.pod.network.errors";
  1000. static constexpr const char *descrMetricK8sPodNetworkErrors = "Pod network errors";
  1001. static constexpr const char *unitMetricK8sPodNetworkErrors = "{error}";
  1002. static inline nostd::unique_ptr<metrics::Counter<uint64_t>>
  1003. CreateSyncInt64MetricK8sPodNetworkErrors(metrics::Meter *meter)
  1004. {
  1005. return meter->CreateUInt64Counter(kMetricK8sPodNetworkErrors, descrMetricK8sPodNetworkErrors,
  1006. unitMetricK8sPodNetworkErrors);
  1007. }
  1008. static inline nostd::unique_ptr<metrics::Counter<double>> CreateSyncDoubleMetricK8sPodNetworkErrors(
  1009. metrics::Meter *meter)
  1010. {
  1011. return meter->CreateDoubleCounter(kMetricK8sPodNetworkErrors, descrMetricK8sPodNetworkErrors,
  1012. unitMetricK8sPodNetworkErrors);
  1013. }
  1014. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1015. CreateAsyncInt64MetricK8sPodNetworkErrors(metrics::Meter *meter)
  1016. {
  1017. return meter->CreateInt64ObservableCounter(
  1018. kMetricK8sPodNetworkErrors, descrMetricK8sPodNetworkErrors, unitMetricK8sPodNetworkErrors);
  1019. }
  1020. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1021. CreateAsyncDoubleMetricK8sPodNetworkErrors(metrics::Meter *meter)
  1022. {
  1023. return meter->CreateDoubleObservableCounter(
  1024. kMetricK8sPodNetworkErrors, descrMetricK8sPodNetworkErrors, unitMetricK8sPodNetworkErrors);
  1025. }
  1026. /**
  1027. Network bytes for the Pod
  1028. <p>
  1029. counter
  1030. */
  1031. static constexpr const char *kMetricK8sPodNetworkIo = "k8s.pod.network.io";
  1032. static constexpr const char *descrMetricK8sPodNetworkIo = "Network bytes for the Pod";
  1033. static constexpr const char *unitMetricK8sPodNetworkIo = "By";
  1034. static inline nostd::unique_ptr<metrics::Counter<uint64_t>> CreateSyncInt64MetricK8sPodNetworkIo(
  1035. metrics::Meter *meter)
  1036. {
  1037. return meter->CreateUInt64Counter(kMetricK8sPodNetworkIo, descrMetricK8sPodNetworkIo,
  1038. unitMetricK8sPodNetworkIo);
  1039. }
  1040. static inline nostd::unique_ptr<metrics::Counter<double>> CreateSyncDoubleMetricK8sPodNetworkIo(
  1041. metrics::Meter *meter)
  1042. {
  1043. return meter->CreateDoubleCounter(kMetricK8sPodNetworkIo, descrMetricK8sPodNetworkIo,
  1044. unitMetricK8sPodNetworkIo);
  1045. }
  1046. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1047. CreateAsyncInt64MetricK8sPodNetworkIo(metrics::Meter *meter)
  1048. {
  1049. return meter->CreateInt64ObservableCounter(kMetricK8sPodNetworkIo, descrMetricK8sPodNetworkIo,
  1050. unitMetricK8sPodNetworkIo);
  1051. }
  1052. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1053. CreateAsyncDoubleMetricK8sPodNetworkIo(metrics::Meter *meter)
  1054. {
  1055. return meter->CreateDoubleObservableCounter(kMetricK8sPodNetworkIo, descrMetricK8sPodNetworkIo,
  1056. unitMetricK8sPodNetworkIo);
  1057. }
  1058. /**
  1059. The time the Pod has been running
  1060. <p>
  1061. Instrumentations SHOULD use a gauge with type @code double @endcode and measure uptime in seconds
  1062. as a floating point number with the highest precision available. The actual accuracy would depend
  1063. on the instrumentation and operating system. <p> gauge
  1064. */
  1065. static constexpr const char *kMetricK8sPodUptime = "k8s.pod.uptime";
  1066. static constexpr const char *descrMetricK8sPodUptime = "The time the Pod has been running";
  1067. static constexpr const char *unitMetricK8sPodUptime = "s";
  1068. #if OPENTELEMETRY_ABI_VERSION_NO >= 2
  1069. static inline nostd::unique_ptr<metrics::Gauge<int64_t>> CreateSyncInt64MetricK8sPodUptime(
  1070. metrics::Meter *meter)
  1071. {
  1072. return meter->CreateInt64Gauge(kMetricK8sPodUptime, descrMetricK8sPodUptime,
  1073. unitMetricK8sPodUptime);
  1074. }
  1075. static inline nostd::unique_ptr<metrics::Gauge<double>> CreateSyncDoubleMetricK8sPodUptime(
  1076. metrics::Meter *meter)
  1077. {
  1078. return meter->CreateDoubleGauge(kMetricK8sPodUptime, descrMetricK8sPodUptime,
  1079. unitMetricK8sPodUptime);
  1080. }
  1081. #endif /* OPENTELEMETRY_ABI_VERSION_NO */
  1082. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncInt64MetricK8sPodUptime(
  1083. metrics::Meter *meter)
  1084. {
  1085. return meter->CreateInt64ObservableGauge(kMetricK8sPodUptime, descrMetricK8sPodUptime,
  1086. unitMetricK8sPodUptime);
  1087. }
  1088. static inline nostd::shared_ptr<metrics::ObservableInstrument> CreateAsyncDoubleMetricK8sPodUptime(
  1089. metrics::Meter *meter)
  1090. {
  1091. return meter->CreateDoubleObservableGauge(kMetricK8sPodUptime, descrMetricK8sPodUptime,
  1092. unitMetricK8sPodUptime);
  1093. }
  1094. /**
  1095. Total number of available replica pods (ready for at least minReadySeconds) targeted by this
  1096. replicaset <p> This metric aligns with the @code availableReplicas @endcode field of the <a
  1097. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#replicasetstatus-v1-apps">K8s
  1098. ReplicaSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  1099. href="../resource/k8s.md#replicaset">@code k8s.replicaset @endcode</a> resource. <p> updowncounter
  1100. */
  1101. static constexpr const char *kMetricK8sReplicasetAvailablePods = "k8s.replicaset.available_pods";
  1102. static constexpr const char *descrMetricK8sReplicasetAvailablePods =
  1103. "Total number of available replica pods (ready for at least minReadySeconds) targeted by this "
  1104. "replicaset";
  1105. static constexpr const char *unitMetricK8sReplicasetAvailablePods = "{pod}";
  1106. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1107. CreateSyncInt64MetricK8sReplicasetAvailablePods(metrics::Meter *meter)
  1108. {
  1109. return meter->CreateInt64UpDownCounter(kMetricK8sReplicasetAvailablePods,
  1110. descrMetricK8sReplicasetAvailablePods,
  1111. unitMetricK8sReplicasetAvailablePods);
  1112. }
  1113. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1114. CreateSyncDoubleMetricK8sReplicasetAvailablePods(metrics::Meter *meter)
  1115. {
  1116. return meter->CreateDoubleUpDownCounter(kMetricK8sReplicasetAvailablePods,
  1117. descrMetricK8sReplicasetAvailablePods,
  1118. unitMetricK8sReplicasetAvailablePods);
  1119. }
  1120. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1121. CreateAsyncInt64MetricK8sReplicasetAvailablePods(metrics::Meter *meter)
  1122. {
  1123. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sReplicasetAvailablePods,
  1124. descrMetricK8sReplicasetAvailablePods,
  1125. unitMetricK8sReplicasetAvailablePods);
  1126. }
  1127. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1128. CreateAsyncDoubleMetricK8sReplicasetAvailablePods(metrics::Meter *meter)
  1129. {
  1130. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sReplicasetAvailablePods,
  1131. descrMetricK8sReplicasetAvailablePods,
  1132. unitMetricK8sReplicasetAvailablePods);
  1133. }
  1134. /**
  1135. Number of desired replica pods in this replicaset
  1136. <p>
  1137. This metric aligns with the @code replicas @endcode field of the
  1138. <a
  1139. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#replicasetspec-v1-apps">K8s
  1140. ReplicaSetSpec</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  1141. href="../resource/k8s.md#replicaset">@code k8s.replicaset @endcode</a> resource. <p> updowncounter
  1142. */
  1143. static constexpr const char *kMetricK8sReplicasetDesiredPods = "k8s.replicaset.desired_pods";
  1144. static constexpr const char *descrMetricK8sReplicasetDesiredPods =
  1145. "Number of desired replica pods in this replicaset";
  1146. static constexpr const char *unitMetricK8sReplicasetDesiredPods = "{pod}";
  1147. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1148. CreateSyncInt64MetricK8sReplicasetDesiredPods(metrics::Meter *meter)
  1149. {
  1150. return meter->CreateInt64UpDownCounter(kMetricK8sReplicasetDesiredPods,
  1151. descrMetricK8sReplicasetDesiredPods,
  1152. unitMetricK8sReplicasetDesiredPods);
  1153. }
  1154. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1155. CreateSyncDoubleMetricK8sReplicasetDesiredPods(metrics::Meter *meter)
  1156. {
  1157. return meter->CreateDoubleUpDownCounter(kMetricK8sReplicasetDesiredPods,
  1158. descrMetricK8sReplicasetDesiredPods,
  1159. unitMetricK8sReplicasetDesiredPods);
  1160. }
  1161. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1162. CreateAsyncInt64MetricK8sReplicasetDesiredPods(metrics::Meter *meter)
  1163. {
  1164. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sReplicasetDesiredPods,
  1165. descrMetricK8sReplicasetDesiredPods,
  1166. unitMetricK8sReplicasetDesiredPods);
  1167. }
  1168. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1169. CreateAsyncDoubleMetricK8sReplicasetDesiredPods(metrics::Meter *meter)
  1170. {
  1171. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sReplicasetDesiredPods,
  1172. descrMetricK8sReplicasetDesiredPods,
  1173. unitMetricK8sReplicasetDesiredPods);
  1174. }
  1175. /**
  1176. Deprecated, use @code k8s.replicationcontroller.available_pods @endcode instead.
  1177. @deprecated
  1178. {"note": "Replaced by @code k8s.replicationcontroller.available_pods @endcode.", "reason":
  1179. "renamed", "renamed_to": "k8s.replicationcontroller.available_pods"} <p> updowncounter
  1180. */
  1181. OPENTELEMETRY_DEPRECATED static constexpr const char *kMetricK8sReplicationControllerAvailablePods =
  1182. "k8s.replication_controller.available_pods";
  1183. OPENTELEMETRY_DEPRECATED static constexpr const char
  1184. *descrMetricK8sReplicationControllerAvailablePods =
  1185. "Deprecated, use `k8s.replicationcontroller.available_pods` instead.";
  1186. OPENTELEMETRY_DEPRECATED static constexpr const char
  1187. *unitMetricK8sReplicationControllerAvailablePods = "{pod}";
  1188. OPENTELEMETRY_DEPRECATED static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1189. CreateSyncInt64MetricK8sReplicationControllerAvailablePods(metrics::Meter *meter)
  1190. {
  1191. return meter->CreateInt64UpDownCounter(kMetricK8sReplicationControllerAvailablePods,
  1192. descrMetricK8sReplicationControllerAvailablePods,
  1193. unitMetricK8sReplicationControllerAvailablePods);
  1194. }
  1195. OPENTELEMETRY_DEPRECATED static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1196. CreateSyncDoubleMetricK8sReplicationControllerAvailablePods(metrics::Meter *meter)
  1197. {
  1198. return meter->CreateDoubleUpDownCounter(kMetricK8sReplicationControllerAvailablePods,
  1199. descrMetricK8sReplicationControllerAvailablePods,
  1200. unitMetricK8sReplicationControllerAvailablePods);
  1201. }
  1202. OPENTELEMETRY_DEPRECATED static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1203. CreateAsyncInt64MetricK8sReplicationControllerAvailablePods(metrics::Meter *meter)
  1204. {
  1205. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sReplicationControllerAvailablePods,
  1206. descrMetricK8sReplicationControllerAvailablePods,
  1207. unitMetricK8sReplicationControllerAvailablePods);
  1208. }
  1209. OPENTELEMETRY_DEPRECATED static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1210. CreateAsyncDoubleMetricK8sReplicationControllerAvailablePods(metrics::Meter *meter)
  1211. {
  1212. return meter->CreateDoubleObservableUpDownCounter(
  1213. kMetricK8sReplicationControllerAvailablePods,
  1214. descrMetricK8sReplicationControllerAvailablePods,
  1215. unitMetricK8sReplicationControllerAvailablePods);
  1216. }
  1217. /**
  1218. Deprecated, use @code k8s.replicationcontroller.desired_pods @endcode instead.
  1219. @deprecated
  1220. {"note": "Replaced by @code k8s.replicationcontroller.desired_pods @endcode.", "reason":
  1221. "renamed", "renamed_to": "k8s.replicationcontroller.desired_pods"} <p> updowncounter
  1222. */
  1223. OPENTELEMETRY_DEPRECATED static constexpr const char *kMetricK8sReplicationControllerDesiredPods =
  1224. "k8s.replication_controller.desired_pods";
  1225. OPENTELEMETRY_DEPRECATED static constexpr const char
  1226. *descrMetricK8sReplicationControllerDesiredPods =
  1227. "Deprecated, use `k8s.replicationcontroller.desired_pods` instead.";
  1228. OPENTELEMETRY_DEPRECATED static constexpr const char
  1229. *unitMetricK8sReplicationControllerDesiredPods = "{pod}";
  1230. OPENTELEMETRY_DEPRECATED static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1231. CreateSyncInt64MetricK8sReplicationControllerDesiredPods(metrics::Meter *meter)
  1232. {
  1233. return meter->CreateInt64UpDownCounter(kMetricK8sReplicationControllerDesiredPods,
  1234. descrMetricK8sReplicationControllerDesiredPods,
  1235. unitMetricK8sReplicationControllerDesiredPods);
  1236. }
  1237. OPENTELEMETRY_DEPRECATED static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1238. CreateSyncDoubleMetricK8sReplicationControllerDesiredPods(metrics::Meter *meter)
  1239. {
  1240. return meter->CreateDoubleUpDownCounter(kMetricK8sReplicationControllerDesiredPods,
  1241. descrMetricK8sReplicationControllerDesiredPods,
  1242. unitMetricK8sReplicationControllerDesiredPods);
  1243. }
  1244. OPENTELEMETRY_DEPRECATED static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1245. CreateAsyncInt64MetricK8sReplicationControllerDesiredPods(metrics::Meter *meter)
  1246. {
  1247. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sReplicationControllerDesiredPods,
  1248. descrMetricK8sReplicationControllerDesiredPods,
  1249. unitMetricK8sReplicationControllerDesiredPods);
  1250. }
  1251. OPENTELEMETRY_DEPRECATED static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1252. CreateAsyncDoubleMetricK8sReplicationControllerDesiredPods(metrics::Meter *meter)
  1253. {
  1254. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sReplicationControllerDesiredPods,
  1255. descrMetricK8sReplicationControllerDesiredPods,
  1256. unitMetricK8sReplicationControllerDesiredPods);
  1257. }
  1258. /**
  1259. Total number of available replica pods (ready for at least minReadySeconds) targeted by this
  1260. replication controller <p> This metric aligns with the @code availableReplicas @endcode field of
  1261. the <a
  1262. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#replicationcontrollerstatus-v1-core">K8s
  1263. ReplicationControllerStatus</a> <p> This metric SHOULD, at a minimum, be reported against a <a
  1264. href="../resource/k8s.md#replicationcontroller">@code k8s.replicationcontroller @endcode</a>
  1265. resource. <p> updowncounter
  1266. */
  1267. static constexpr const char *kMetricK8sReplicationcontrollerAvailablePods =
  1268. "k8s.replicationcontroller.available_pods";
  1269. static constexpr const char *descrMetricK8sReplicationcontrollerAvailablePods =
  1270. "Total number of available replica pods (ready for at least minReadySeconds) targeted by this "
  1271. "replication controller";
  1272. static constexpr const char *unitMetricK8sReplicationcontrollerAvailablePods = "{pod}";
  1273. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1274. CreateSyncInt64MetricK8sReplicationcontrollerAvailablePods(metrics::Meter *meter)
  1275. {
  1276. return meter->CreateInt64UpDownCounter(kMetricK8sReplicationcontrollerAvailablePods,
  1277. descrMetricK8sReplicationcontrollerAvailablePods,
  1278. unitMetricK8sReplicationcontrollerAvailablePods);
  1279. }
  1280. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1281. CreateSyncDoubleMetricK8sReplicationcontrollerAvailablePods(metrics::Meter *meter)
  1282. {
  1283. return meter->CreateDoubleUpDownCounter(kMetricK8sReplicationcontrollerAvailablePods,
  1284. descrMetricK8sReplicationcontrollerAvailablePods,
  1285. unitMetricK8sReplicationcontrollerAvailablePods);
  1286. }
  1287. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1288. CreateAsyncInt64MetricK8sReplicationcontrollerAvailablePods(metrics::Meter *meter)
  1289. {
  1290. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sReplicationcontrollerAvailablePods,
  1291. descrMetricK8sReplicationcontrollerAvailablePods,
  1292. unitMetricK8sReplicationcontrollerAvailablePods);
  1293. }
  1294. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1295. CreateAsyncDoubleMetricK8sReplicationcontrollerAvailablePods(metrics::Meter *meter)
  1296. {
  1297. return meter->CreateDoubleObservableUpDownCounter(
  1298. kMetricK8sReplicationcontrollerAvailablePods,
  1299. descrMetricK8sReplicationcontrollerAvailablePods,
  1300. unitMetricK8sReplicationcontrollerAvailablePods);
  1301. }
  1302. /**
  1303. Number of desired replica pods in this replication controller
  1304. <p>
  1305. This metric aligns with the @code replicas @endcode field of the
  1306. <a
  1307. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#replicationcontrollerspec-v1-core">K8s
  1308. ReplicationControllerSpec</a> <p> This metric SHOULD, at a minimum, be reported against a <a
  1309. href="../resource/k8s.md#replicationcontroller">@code k8s.replicationcontroller @endcode</a>
  1310. resource. <p> updowncounter
  1311. */
  1312. static constexpr const char *kMetricK8sReplicationcontrollerDesiredPods =
  1313. "k8s.replicationcontroller.desired_pods";
  1314. static constexpr const char *descrMetricK8sReplicationcontrollerDesiredPods =
  1315. "Number of desired replica pods in this replication controller";
  1316. static constexpr const char *unitMetricK8sReplicationcontrollerDesiredPods = "{pod}";
  1317. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1318. CreateSyncInt64MetricK8sReplicationcontrollerDesiredPods(metrics::Meter *meter)
  1319. {
  1320. return meter->CreateInt64UpDownCounter(kMetricK8sReplicationcontrollerDesiredPods,
  1321. descrMetricK8sReplicationcontrollerDesiredPods,
  1322. unitMetricK8sReplicationcontrollerDesiredPods);
  1323. }
  1324. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1325. CreateSyncDoubleMetricK8sReplicationcontrollerDesiredPods(metrics::Meter *meter)
  1326. {
  1327. return meter->CreateDoubleUpDownCounter(kMetricK8sReplicationcontrollerDesiredPods,
  1328. descrMetricK8sReplicationcontrollerDesiredPods,
  1329. unitMetricK8sReplicationcontrollerDesiredPods);
  1330. }
  1331. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1332. CreateAsyncInt64MetricK8sReplicationcontrollerDesiredPods(metrics::Meter *meter)
  1333. {
  1334. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sReplicationcontrollerDesiredPods,
  1335. descrMetricK8sReplicationcontrollerDesiredPods,
  1336. unitMetricK8sReplicationcontrollerDesiredPods);
  1337. }
  1338. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1339. CreateAsyncDoubleMetricK8sReplicationcontrollerDesiredPods(metrics::Meter *meter)
  1340. {
  1341. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sReplicationcontrollerDesiredPods,
  1342. descrMetricK8sReplicationcontrollerDesiredPods,
  1343. unitMetricK8sReplicationcontrollerDesiredPods);
  1344. }
  1345. /**
  1346. The number of replica pods created by the statefulset controller from the statefulset version
  1347. indicated by currentRevision <p> This metric aligns with the @code currentReplicas @endcode field
  1348. of the <a
  1349. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#statefulsetstatus-v1-apps">K8s
  1350. StatefulSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  1351. href="../resource/k8s.md#statefulset">@code k8s.statefulset @endcode</a> resource. <p>
  1352. updowncounter
  1353. */
  1354. static constexpr const char *kMetricK8sStatefulsetCurrentPods = "k8s.statefulset.current_pods";
  1355. static constexpr const char *descrMetricK8sStatefulsetCurrentPods =
  1356. "The number of replica pods created by the statefulset controller from the statefulset version "
  1357. "indicated by currentRevision";
  1358. static constexpr const char *unitMetricK8sStatefulsetCurrentPods = "{pod}";
  1359. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1360. CreateSyncInt64MetricK8sStatefulsetCurrentPods(metrics::Meter *meter)
  1361. {
  1362. return meter->CreateInt64UpDownCounter(kMetricK8sStatefulsetCurrentPods,
  1363. descrMetricK8sStatefulsetCurrentPods,
  1364. unitMetricK8sStatefulsetCurrentPods);
  1365. }
  1366. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1367. CreateSyncDoubleMetricK8sStatefulsetCurrentPods(metrics::Meter *meter)
  1368. {
  1369. return meter->CreateDoubleUpDownCounter(kMetricK8sStatefulsetCurrentPods,
  1370. descrMetricK8sStatefulsetCurrentPods,
  1371. unitMetricK8sStatefulsetCurrentPods);
  1372. }
  1373. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1374. CreateAsyncInt64MetricK8sStatefulsetCurrentPods(metrics::Meter *meter)
  1375. {
  1376. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sStatefulsetCurrentPods,
  1377. descrMetricK8sStatefulsetCurrentPods,
  1378. unitMetricK8sStatefulsetCurrentPods);
  1379. }
  1380. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1381. CreateAsyncDoubleMetricK8sStatefulsetCurrentPods(metrics::Meter *meter)
  1382. {
  1383. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sStatefulsetCurrentPods,
  1384. descrMetricK8sStatefulsetCurrentPods,
  1385. unitMetricK8sStatefulsetCurrentPods);
  1386. }
  1387. /**
  1388. Number of desired replica pods in this statefulset
  1389. <p>
  1390. This metric aligns with the @code replicas @endcode field of the
  1391. <a
  1392. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#statefulsetspec-v1-apps">K8s
  1393. StatefulSetSpec</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  1394. href="../resource/k8s.md#statefulset">@code k8s.statefulset @endcode</a> resource. <p>
  1395. updowncounter
  1396. */
  1397. static constexpr const char *kMetricK8sStatefulsetDesiredPods = "k8s.statefulset.desired_pods";
  1398. static constexpr const char *descrMetricK8sStatefulsetDesiredPods =
  1399. "Number of desired replica pods in this statefulset";
  1400. static constexpr const char *unitMetricK8sStatefulsetDesiredPods = "{pod}";
  1401. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1402. CreateSyncInt64MetricK8sStatefulsetDesiredPods(metrics::Meter *meter)
  1403. {
  1404. return meter->CreateInt64UpDownCounter(kMetricK8sStatefulsetDesiredPods,
  1405. descrMetricK8sStatefulsetDesiredPods,
  1406. unitMetricK8sStatefulsetDesiredPods);
  1407. }
  1408. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1409. CreateSyncDoubleMetricK8sStatefulsetDesiredPods(metrics::Meter *meter)
  1410. {
  1411. return meter->CreateDoubleUpDownCounter(kMetricK8sStatefulsetDesiredPods,
  1412. descrMetricK8sStatefulsetDesiredPods,
  1413. unitMetricK8sStatefulsetDesiredPods);
  1414. }
  1415. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1416. CreateAsyncInt64MetricK8sStatefulsetDesiredPods(metrics::Meter *meter)
  1417. {
  1418. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sStatefulsetDesiredPods,
  1419. descrMetricK8sStatefulsetDesiredPods,
  1420. unitMetricK8sStatefulsetDesiredPods);
  1421. }
  1422. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1423. CreateAsyncDoubleMetricK8sStatefulsetDesiredPods(metrics::Meter *meter)
  1424. {
  1425. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sStatefulsetDesiredPods,
  1426. descrMetricK8sStatefulsetDesiredPods,
  1427. unitMetricK8sStatefulsetDesiredPods);
  1428. }
  1429. /**
  1430. The number of replica pods created for this statefulset with a Ready Condition
  1431. <p>
  1432. This metric aligns with the @code readyReplicas @endcode field of the
  1433. <a
  1434. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#statefulsetstatus-v1-apps">K8s
  1435. StatefulSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  1436. href="../resource/k8s.md#statefulset">@code k8s.statefulset @endcode</a> resource. <p>
  1437. updowncounter
  1438. */
  1439. static constexpr const char *kMetricK8sStatefulsetReadyPods = "k8s.statefulset.ready_pods";
  1440. static constexpr const char *descrMetricK8sStatefulsetReadyPods =
  1441. "The number of replica pods created for this statefulset with a Ready Condition";
  1442. static constexpr const char *unitMetricK8sStatefulsetReadyPods = "{pod}";
  1443. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1444. CreateSyncInt64MetricK8sStatefulsetReadyPods(metrics::Meter *meter)
  1445. {
  1446. return meter->CreateInt64UpDownCounter(kMetricK8sStatefulsetReadyPods,
  1447. descrMetricK8sStatefulsetReadyPods,
  1448. unitMetricK8sStatefulsetReadyPods);
  1449. }
  1450. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1451. CreateSyncDoubleMetricK8sStatefulsetReadyPods(metrics::Meter *meter)
  1452. {
  1453. return meter->CreateDoubleUpDownCounter(kMetricK8sStatefulsetReadyPods,
  1454. descrMetricK8sStatefulsetReadyPods,
  1455. unitMetricK8sStatefulsetReadyPods);
  1456. }
  1457. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1458. CreateAsyncInt64MetricK8sStatefulsetReadyPods(metrics::Meter *meter)
  1459. {
  1460. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sStatefulsetReadyPods,
  1461. descrMetricK8sStatefulsetReadyPods,
  1462. unitMetricK8sStatefulsetReadyPods);
  1463. }
  1464. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1465. CreateAsyncDoubleMetricK8sStatefulsetReadyPods(metrics::Meter *meter)
  1466. {
  1467. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sStatefulsetReadyPods,
  1468. descrMetricK8sStatefulsetReadyPods,
  1469. unitMetricK8sStatefulsetReadyPods);
  1470. }
  1471. /**
  1472. Number of replica pods created by the statefulset controller from the statefulset version
  1473. indicated by updateRevision <p> This metric aligns with the @code updatedReplicas @endcode field
  1474. of the <a
  1475. href="https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#statefulsetstatus-v1-apps">K8s
  1476. StatefulSetStatus</a>. <p> This metric SHOULD, at a minimum, be reported against a <a
  1477. href="../resource/k8s.md#statefulset">@code k8s.statefulset @endcode</a> resource. <p>
  1478. updowncounter
  1479. */
  1480. static constexpr const char *kMetricK8sStatefulsetUpdatedPods = "k8s.statefulset.updated_pods";
  1481. static constexpr const char *descrMetricK8sStatefulsetUpdatedPods =
  1482. "Number of replica pods created by the statefulset controller from the statefulset version "
  1483. "indicated by updateRevision";
  1484. static constexpr const char *unitMetricK8sStatefulsetUpdatedPods = "{pod}";
  1485. static inline nostd::unique_ptr<metrics::UpDownCounter<int64_t>>
  1486. CreateSyncInt64MetricK8sStatefulsetUpdatedPods(metrics::Meter *meter)
  1487. {
  1488. return meter->CreateInt64UpDownCounter(kMetricK8sStatefulsetUpdatedPods,
  1489. descrMetricK8sStatefulsetUpdatedPods,
  1490. unitMetricK8sStatefulsetUpdatedPods);
  1491. }
  1492. static inline nostd::unique_ptr<metrics::UpDownCounter<double>>
  1493. CreateSyncDoubleMetricK8sStatefulsetUpdatedPods(metrics::Meter *meter)
  1494. {
  1495. return meter->CreateDoubleUpDownCounter(kMetricK8sStatefulsetUpdatedPods,
  1496. descrMetricK8sStatefulsetUpdatedPods,
  1497. unitMetricK8sStatefulsetUpdatedPods);
  1498. }
  1499. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1500. CreateAsyncInt64MetricK8sStatefulsetUpdatedPods(metrics::Meter *meter)
  1501. {
  1502. return meter->CreateInt64ObservableUpDownCounter(kMetricK8sStatefulsetUpdatedPods,
  1503. descrMetricK8sStatefulsetUpdatedPods,
  1504. unitMetricK8sStatefulsetUpdatedPods);
  1505. }
  1506. static inline nostd::shared_ptr<metrics::ObservableInstrument>
  1507. CreateAsyncDoubleMetricK8sStatefulsetUpdatedPods(metrics::Meter *meter)
  1508. {
  1509. return meter->CreateDoubleObservableUpDownCounter(kMetricK8sStatefulsetUpdatedPods,
  1510. descrMetricK8sStatefulsetUpdatedPods,
  1511. unitMetricK8sStatefulsetUpdatedPods);
  1512. }
  1513. } // namespace k8s
  1514. } // namespace semconv
  1515. OPENTELEMETRY_END_NAMESPACE