monitoring-settings.asciidoc 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. [role="xpack"]
  2. [[monitoring-settings]]
  3. === Monitoring settings in Elasticsearch
  4. ++++
  5. <titleabbrev>Monitoring settings</titleabbrev>
  6. ++++
  7. By default, monitoring is enabled but data collection is disabled. To enable
  8. data collection, use the `xpack.monitoring.collection.enabled` setting.
  9. You can configure these monitoring settings in the `elasticsearch.yml` file.
  10. Some of them can also be set across the cluster by using the
  11. <<cluster-update-settings,cluster update settings API>>.
  12. TIP: Cluster settings take precedence over settings in the `elasticsearch.yml`
  13. file.
  14. To adjust how monitoring data is displayed in the monitoring UI, configure
  15. {kibana-ref}/monitoring-settings-kb.html[`xpack.monitoring` settings] in
  16. `kibana.yml`. To control how monitoring data is collected from
  17. Logstash, configure
  18. {logstash-ref}/configuring-logstash.html#monitoring-settings[`xpack.monitoring` settings]
  19. in `logstash.yml`.
  20. For more information, see
  21. {xpack-ref}/xpack-monitoring.html[Monitoring the Elastic Stack].
  22. [float]
  23. [[general-monitoring-settings]]
  24. ==== General Monitoring Settings
  25. `xpack.monitoring.enabled`::
  26. Set to `true` (default) to enable {es} {monitoring} for {es} on the node.
  27. +
  28. --
  29. NOTE: To enable data collection, you must also set `xpack.monitoring.collection.enabled`
  30. to `true`. Its default value is `false`.
  31. --
  32. [float]
  33. [[monitoring-collection-settings]]
  34. ==== Monitoring Collection Settings
  35. The `xpack.monitoring.collection` settings control how data is collected from
  36. your Elasticsearch nodes.
  37. `xpack.monitoring.collection.enabled` (<<cluster-update-settings,Dynamic>>)::
  38. added[6.3.0] Set to `true` to enable the collection of monitoring data. When
  39. this setting is `false` (default), {es} monitoring data is not collected and
  40. all monitoring data from other sources such as {kib}, Beats, and Logstash is
  41. ignored.
  42. `xpack.monitoring.collection.interval` (<<cluster-update-settings,Dynamic>>)::
  43. Setting to `-1` to disable data collection is no longer supported beginning with
  44. 7.0.0. deprecated[6.3.0, Use `xpack.monitoring.collection.enabled` set to
  45. `false` instead.]
  46. +
  47. Controls how often data samples are collected. Defaults to `10s`. If you
  48. modify the collection interval, set the `xpack.monitoring.min_interval_seconds`
  49. option in `kibana.yml` to the same value.
  50. `xpack.monitoring.elasticsearch.collection.enabled` (<<cluster-update-settings,Dynamic>>)::
  51. Controls whether statistics about your {es} cluster should be collected. Defaults to `true`.
  52. This is different from xpack.monitoring.collection.enabled, which allows you to enable or disable
  53. all monitoring collection. However, this setting simply disables the collection of Elasticsearch
  54. data while still allowing other data (e.g., Kibana, Logstash, Beats, or APM Server monitoring data)
  55. to pass through this cluster.
  56. `xpack.monitoring.collection.cluster.stats.timeout`::
  57. Sets the timeout for collecting the cluster statistics. Defaults to `10s`.
  58. `xpack.monitoring.collection.indices` (<<cluster-update-settings,Dynamic>>)::
  59. Controls which indices Monitoring collects data from. Defaults to all indices. Specify the index names
  60. as a comma-separated list, for example `test1,test2,test3`. Names can include wildcards, for
  61. example `test*`. You can explicitly exclude indices by prepending `-`. For example `test*,-test3` will
  62. monitor all indexes that start with `test` except for `test3`. System indices like .security* or .kibana*
  63. always start with a `.`, and generally should be monitored. Consider adding `.*` to the list of indices
  64. ensure monitoring of system indices. For example `.*,test*,-test3`
  65. `xpack.monitoring.collection.index.stats.timeout`::
  66. Sets the timeout for collecting index statistics. Defaults to `10s`.
  67. `xpack.monitoring.collection.index.recovery.active_only`::
  68. Controls whether or not all recoveries are collected. Set to `true` to
  69. collect only active recoveries. Defaults to `false`.
  70. `xpack.monitoring.collection.index.recovery.timeout`::
  71. Sets the timeout for collecting the recovery information. Defaults to `10s`.
  72. `xpack.monitoring.history.duration`::
  73. Sets the retention duration beyond which the indices created by a Monitoring
  74. exporter are automatically deleted. Defaults to `7d` (7 days).
  75. +
  76. --
  77. This setting has a minimum value of `1d` (1 day) to ensure that something is
  78. being monitored, and it cannot be disabled.
  79. IMPORTANT: This setting currently only impacts `local`-type exporters. Indices created using
  80. the `http` exporter will not be deleted automatically.
  81. --
  82. `xpack.monitoring.exporters`::
  83. Configures where the agent stores monitoring data. By default, the agent uses a
  84. local exporter that indexes monitoring data on the cluster where it is installed.
  85. Use an HTTP exporter to send data to a separate monitoring cluster. For more
  86. information, see <<local-exporter-settings,Local Exporter Settings>>,
  87. <<http-exporter-settings,HTTP Exporter Settings>>, and
  88. {xpack-ref}/how-monitoring-works.html[How Monitoring Works].
  89. [float]
  90. [[local-exporter-settings]]
  91. ==== Local Exporter Settings
  92. The `local` exporter is the default exporter used by Monitoring. As the name is
  93. meant to imply, it exports data to the _local_ cluster, which means that there
  94. is not much needed to be configured.
  95. If you do not supply _any_ exporters, then Monitoring will automatically create
  96. one for you. If any exporter is provided, then no default is added.
  97. [source,yaml]
  98. ----------------------------------
  99. xpack.monitoring.exporters.my_local:
  100. type: local
  101. ----------------------------------
  102. `type`::
  103. The value for a Local exporter must always be `local` and it is required.
  104. `use_ingest`::
  105. Whether to supply a placeholder pipeline to the cluster and a pipeline processor with
  106. every bulk request. The default value is `true`. If disabled, then it means that it will not
  107. use pipelines, which means that a future release cannot automatically upgrade bulk requests
  108. to future-proof them.
  109. `cluster_alerts.management.enabled`::
  110. Whether to create cluster alerts for this cluster. The default value is `true`.
  111. To use this feature, {watcher} must be enabled. If you have a basic license,
  112. cluster alerts are not displayed.
  113. [float]
  114. [[http-exporter-settings]]
  115. ==== HTTP Exporter Settings
  116. The following lists settings that can be supplied with the `http` exporter.
  117. All settings are shown as what follows the name you select for your exporter:
  118. [source,yaml]
  119. ----------------------------------
  120. xpack.monitoring.exporters.my_remote:
  121. type: http
  122. host: ["host:port", ...]
  123. ----------------------------------
  124. `type`::
  125. The value for an HTTP exporter must always be `http` and it is required.
  126. `host`::
  127. Host supports multiple formats, both as an array or as a single value. Supported formats include
  128. `hostname`, `hostname:port`, `http://hostname` `http://hostname:port`, `https://hostname`, and
  129. `https://hostname:port`. Hosts cannot be assumed. The default scheme is always `http` and the default
  130. port is always `9200` if not supplied as part of the `host` string.
  131. +
  132. [source,yaml]
  133. ----------------------------------
  134. xpack.monitoring.exporters:
  135. example1:
  136. type: http
  137. host: "10.1.2.3"
  138. example2:
  139. type: http
  140. host: ["http://10.1.2.4"]
  141. example3:
  142. type: http
  143. host: ["10.1.2.5", "10.1.2.6"]
  144. example4:
  145. type: http
  146. host: ["https://10.1.2.3:9200"]
  147. ----------------------------------
  148. `auth.username`::
  149. The username is required if a `auth.password` is supplied.
  150. `auth.password`::
  151. The password for the `auth.username`.
  152. `connection.timeout`::
  153. The amount of time that the HTTP connection is supposed to wait for a socket to open for the
  154. request. The default value is `6s`.
  155. `connection.read_timeout`::
  156. The amount of time that the HTTP connection is supposed to wait for a socket to
  157. send back a response. The default value is `10 * connection.timeout` (`60s` if neither are set).
  158. `ssl`::
  159. Each HTTP exporter can define its own TLS / SSL settings or inherit them. See the
  160. <<ssl-monitoring-settings, TLS / SSL section below>>.
  161. `proxy.base_path`::
  162. The base path to prefix any outgoing request, such as `/base/path` (e.g., bulk requests would
  163. then be sent as `/base/path/_bulk`). There is no default value.
  164. `headers`::
  165. Optional headers that are added to every request, which can assist with routing requests through
  166. proxies.
  167. +
  168. [source,yaml]
  169. ----------------------------------
  170. xpack.monitoring.exporters.my_remote:
  171. headers:
  172. X-My-Array: [abc, def, xyz]
  173. X-My-Header: abc123
  174. ----------------------------------
  175. +
  176. Array-based headers are sent `n` times where `n` is the size of the array. `Content-Type`
  177. and `Content-Length` cannot be set. Any headers created by the Monitoring agent will override
  178. anything defined here.
  179. `index.name.time_format`::
  180. A mechanism for changing the default date suffix for the, by default, daily Monitoring indices.
  181. The default value is `YYYY.MM.DD`, which is why the indices are created daily.
  182. `use_ingest`::
  183. Whether to supply a placeholder pipeline to the monitoring cluster and a pipeline processor with
  184. every bulk request. The default value is `true`. If disabled, then it means that it will not
  185. use pipelines, which means that a future release cannot automatically upgrade bulk requests
  186. to future-proof them.
  187. `cluster_alerts.management.enabled`::
  188. Whether to create cluster alerts for this cluster. The default value is `true`.
  189. To use this feature, {watcher} must be enabled. If you have a basic license,
  190. cluster alerts are not displayed.
  191. `cluster_alerts.management.blacklist`::
  192. Prevents the creation of specific cluster alerts. It also removes any applicable
  193. watches that already exist in the current cluster. +
  194. +
  195. --
  196. You can add any of the following watch identifiers to the blacklist:
  197. * `elasticsearch_cluster_status`
  198. * `elasticsearch_version_mismatch`
  199. * `elasticsearch_nodes`
  200. * `kibana_version_mismatch`
  201. * `logstash_version_mismatch`
  202. * `xpack_license_expiration`
  203. For example: `["elasticsearch_version_mismatch","xpack_license_expiration"]`.
  204. --
  205. [[ssl-monitoring-settings]]
  206. :ssl-prefix: xpack.monitoring.exporters.$NAME
  207. :component: {monitoring}
  208. :verifies:
  209. :server!:
  210. include::ssl-settings.asciidoc[]