Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 

200 Zeilen
9.5 KiB

  1. // Copyright 2014 The Prometheus Authors
  2. // Licensed under the Apache License, Version 2.0 (the "License");
  3. // you may not use this file except in compliance with the License.
  4. // You may obtain a copy of the License at
  5. //
  6. // http://www.apache.org/licenses/LICENSE-2.0
  7. //
  8. // Unless required by applicable law or agreed to in writing, software
  9. // distributed under the License is distributed on an "AS IS" BASIS,
  10. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. // See the License for the specific language governing permissions and
  12. // limitations under the License.
  13. // Package prometheus is the core instrumentation package. It provides metrics
  14. // primitives to instrument code for monitoring. It also offers a registry for
  15. // metrics. Sub-packages allow to expose the registered metrics via HTTP
  16. // (package promhttp) or push them to a Pushgateway (package push). There is
  17. // also a sub-package promauto, which provides metrics constructors with
  18. // automatic registration.
  19. //
  20. // All exported functions and methods are safe to be used concurrently unless
  21. // specified otherwise.
  22. //
  23. // A Basic Example
  24. //
  25. // As a starting point, a very basic usage example:
  26. //
  27. // package main
  28. //
  29. // import (
  30. // "log"
  31. // "net/http"
  32. //
  33. // "github.com/prometheus/client_golang/prometheus"
  34. // "github.com/prometheus/client_golang/prometheus/promhttp"
  35. // )
  36. //
  37. // var (
  38. // cpuTemp = prometheus.NewGauge(prometheus.GaugeOpts{
  39. // Name: "cpu_temperature_celsius",
  40. // Help: "Current temperature of the CPU.",
  41. // })
  42. // hdFailures = prometheus.NewCounterVec(
  43. // prometheus.CounterOpts{
  44. // Name: "hd_errors_total",
  45. // Help: "Number of hard-disk errors.",
  46. // },
  47. // []string{"device"},
  48. // )
  49. // )
  50. //
  51. // func init() {
  52. // // Metrics have to be registered to be exposed:
  53. // prometheus.MustRegister(cpuTemp)
  54. // prometheus.MustRegister(hdFailures)
  55. // }
  56. //
  57. // func main() {
  58. // cpuTemp.Set(65.3)
  59. // hdFailures.With(prometheus.Labels{"device":"/dev/sda"}).Inc()
  60. //
  61. // // The Handler function provides a default handler to expose metrics
  62. // // via an HTTP server. "/metrics" is the usual endpoint for that.
  63. // http.Handle("/metrics", promhttp.Handler())
  64. // log.Fatal(http.ListenAndServe(":8080", nil))
  65. // }
  66. //
  67. //
  68. // This is a complete program that exports two metrics, a Gauge and a Counter,
  69. // the latter with a label attached to turn it into a (one-dimensional) vector.
  70. //
  71. // Metrics
  72. //
  73. // The number of exported identifiers in this package might appear a bit
  74. // overwhelming. However, in addition to the basic plumbing shown in the example
  75. // above, you only need to understand the different metric types and their
  76. // vector versions for basic usage. Furthermore, if you are not concerned with
  77. // fine-grained control of when and how to register metrics with the registry,
  78. // have a look at the promauto package, which will effectively allow you to
  79. // ignore registration altogether in simple cases.
  80. //
  81. // Above, you have already touched the Counter and the Gauge. There are two more
  82. // advanced metric types: the Summary and Histogram. A more thorough description
  83. // of those four metric types can be found in the Prometheus docs:
  84. // https://prometheus.io/docs/concepts/metric_types/
  85. //
  86. // In addition to the fundamental metric types Gauge, Counter, Summary, and
  87. // Histogram, a very important part of the Prometheus data model is the
  88. // partitioning of samples along dimensions called labels, which results in
  89. // metric vectors. The fundamental types are GaugeVec, CounterVec, SummaryVec,
  90. // and HistogramVec.
  91. //
  92. // While only the fundamental metric types implement the Metric interface, both
  93. // the metrics and their vector versions implement the Collector interface. A
  94. // Collector manages the collection of a number of Metrics, but for convenience,
  95. // a Metric can also “collect itself”. Note that Gauge, Counter, Summary, and
  96. // Histogram are interfaces themselves while GaugeVec, CounterVec, SummaryVec,
  97. // and HistogramVec are not.
  98. //
  99. // To create instances of Metrics and their vector versions, you need a suitable
  100. // …Opts struct, i.e. GaugeOpts, CounterOpts, SummaryOpts, or HistogramOpts.
  101. //
  102. // Custom Collectors and constant Metrics
  103. //
  104. // While you could create your own implementations of Metric, most likely you
  105. // will only ever implement the Collector interface on your own. At a first
  106. // glance, a custom Collector seems handy to bundle Metrics for common
  107. // registration (with the prime example of the different metric vectors above,
  108. // which bundle all the metrics of the same name but with different labels).
  109. //
  110. // There is a more involved use case, too: If you already have metrics
  111. // available, created outside of the Prometheus context, you don't need the
  112. // interface of the various Metric types. You essentially want to mirror the
  113. // existing numbers into Prometheus Metrics during collection. An own
  114. // implementation of the Collector interface is perfect for that. You can create
  115. // Metric instances “on the fly” using NewConstMetric, NewConstHistogram, and
  116. // NewConstSummary (and their respective Must… versions). NewConstMetric is used
  117. // for all metric types with just a float64 as their value: Counter, Gauge, and
  118. // a special “type” called Untyped. Use the latter if you are not sure if the
  119. // mirrored metric is a Counter or a Gauge. Creation of the Metric instance
  120. // happens in the Collect method. The Describe method has to return separate
  121. // Desc instances, representative of the “throw-away” metrics to be created
  122. // later. NewDesc comes in handy to create those Desc instances. Alternatively,
  123. // you could return no Desc at all, which will mark the Collector “unchecked”.
  124. // No checks are performed at registration time, but metric consistency will
  125. // still be ensured at scrape time, i.e. any inconsistencies will lead to scrape
  126. // errors. Thus, with unchecked Collectors, the responsibility to not collect
  127. // metrics that lead to inconsistencies in the total scrape result lies with the
  128. // implementer of the Collector. While this is not a desirable state, it is
  129. // sometimes necessary. The typical use case is a situation where the exact
  130. // metrics to be returned by a Collector cannot be predicted at registration
  131. // time, but the implementer has sufficient knowledge of the whole system to
  132. // guarantee metric consistency.
  133. //
  134. // The Collector example illustrates the use case. You can also look at the
  135. // source code of the processCollector (mirroring process metrics), the
  136. // goCollector (mirroring Go metrics), or the expvarCollector (mirroring expvar
  137. // metrics) as examples that are used in this package itself.
  138. //
  139. // If you just need to call a function to get a single float value to collect as
  140. // a metric, GaugeFunc, CounterFunc, or UntypedFunc might be interesting
  141. // shortcuts.
  142. //
  143. // Advanced Uses of the Registry
  144. //
  145. // While MustRegister is the by far most common way of registering a Collector,
  146. // sometimes you might want to handle the errors the registration might cause.
  147. // As suggested by the name, MustRegister panics if an error occurs. With the
  148. // Register function, the error is returned and can be handled.
  149. //
  150. // An error is returned if the registered Collector is incompatible or
  151. // inconsistent with already registered metrics. The registry aims for
  152. // consistency of the collected metrics according to the Prometheus data model.
  153. // Inconsistencies are ideally detected at registration time, not at collect
  154. // time. The former will usually be detected at start-up time of a program,
  155. // while the latter will only happen at scrape time, possibly not even on the
  156. // first scrape if the inconsistency only becomes relevant later. That is the
  157. // main reason why a Collector and a Metric have to describe themselves to the
  158. // registry.
  159. //
  160. // So far, everything we did operated on the so-called default registry, as it
  161. // can be found in the global DefaultRegisterer variable. With NewRegistry, you
  162. // can create a custom registry, or you can even implement the Registerer or
  163. // Gatherer interfaces yourself. The methods Register and Unregister work in the
  164. // same way on a custom registry as the global functions Register and Unregister
  165. // on the default registry.
  166. //
  167. // There are a number of uses for custom registries: You can use registries with
  168. // special properties, see NewPedanticRegistry. You can avoid global state, as
  169. // it is imposed by the DefaultRegisterer. You can use multiple registries at
  170. // the same time to expose different metrics in different ways. You can use
  171. // separate registries for testing purposes.
  172. //
  173. // Also note that the DefaultRegisterer comes registered with a Collector for Go
  174. // runtime metrics (via NewGoCollector) and a Collector for process metrics (via
  175. // NewProcessCollector). With a custom registry, you are in control and decide
  176. // yourself about the Collectors to register.
  177. //
  178. // HTTP Exposition
  179. //
  180. // The Registry implements the Gatherer interface. The caller of the Gather
  181. // method can then expose the gathered metrics in some way. Usually, the metrics
  182. // are served via HTTP on the /metrics endpoint. That's happening in the example
  183. // above. The tools to expose metrics via HTTP are in the promhttp sub-package.
  184. //
  185. // Pushing to the Pushgateway
  186. //
  187. // Function for pushing to the Pushgateway can be found in the push sub-package.
  188. //
  189. // Graphite Bridge
  190. //
  191. // Functions and examples to push metrics from a Gatherer to Graphite can be
  192. // found in the graphite sub-package.
  193. //
  194. // Other Means of Exposition
  195. //
  196. // More ways of exposing metrics can easily be added by following the approaches
  197. // of the existing implementations.
  198. package prometheus