You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

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