Add metrics to administrator guide
This adds information on configuring metrics to the administrator's guide. Change-Id: I7d1c89ef97c8398ee8ac41bfe5a4537552c0795b Partial-bug: #1611559
This commit is contained in:
parent
57838f01da
commit
72a212e29a
102
doc/source/deploy/metrics.rst
Normal file
102
doc/source/deploy/metrics.rst
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
.. _metrics:
|
||||||
|
|
||||||
|
=========================
|
||||||
|
Emitting Software Metrics
|
||||||
|
=========================
|
||||||
|
|
||||||
|
Beginning with the Newton (6.1.0) release, the ironic services support
|
||||||
|
emitting internal performance data to
|
||||||
|
`statsd <https://github.com/etsy/statsd>`_. This allows operators to graph
|
||||||
|
and understand performance bottlenecks in their system.
|
||||||
|
|
||||||
|
This guide assumes you have a statsd server setup. For information on using
|
||||||
|
and configuring statsd, please see the
|
||||||
|
`statsd <https://github.com/etsy/statsd>`_ README and documentation.
|
||||||
|
|
||||||
|
These performance measurements, herein referred to as "metrics", can be
|
||||||
|
emitted from the Bare Metal service, including ironic-api, ironic-conductor,
|
||||||
|
and ironic-python-agent. By default, none of the services will emit metrics.
|
||||||
|
|
||||||
|
Configuring the Bare Metal Service to Enable Metrics
|
||||||
|
====================================================
|
||||||
|
|
||||||
|
Enabling metrics in ironic-api and ironic-conductor
|
||||||
|
---------------------------------------------------
|
||||||
|
|
||||||
|
The ironic-api and ironic-conductor services can be configured to emit metrics
|
||||||
|
to statsd by adding the following to the ironic configuration file, usually
|
||||||
|
located at ``/etc/ironic/ironic.conf``::
|
||||||
|
|
||||||
|
[metrics]
|
||||||
|
backend = statsd
|
||||||
|
|
||||||
|
If a statsd daemon is installed and configured on every host running an ironic
|
||||||
|
service, listening on the default UDP port (8125), no further configuration is
|
||||||
|
needed. If you are using a remote statsd server, you must also supply
|
||||||
|
connection information in the ironic configuration file::
|
||||||
|
|
||||||
|
[metrics_statsd]
|
||||||
|
# Point this at your environments' statsd host
|
||||||
|
statsd_host = 192.0.2.1
|
||||||
|
statsd_port = 8125
|
||||||
|
|
||||||
|
|
||||||
|
Enabling metrics in ironic-python-agent
|
||||||
|
---------------------------------------
|
||||||
|
|
||||||
|
The ironic-python-agent process receives its configuration in the response from
|
||||||
|
the inital lookup request to the ironic-api service. This means to configure
|
||||||
|
ironic-python-agent to emit metrics, you must enable the agent metrics backend
|
||||||
|
in your ironic configuration file on all ironic-conductor hosts::
|
||||||
|
|
||||||
|
[metrics]
|
||||||
|
agent_backend = statsd
|
||||||
|
|
||||||
|
In order to reliably emit metrics from the ironic-python-agent, you must
|
||||||
|
provide a statsd server that is reachable from both the configured provisioning
|
||||||
|
and cleaning networks. The agent statsd connection information is configured
|
||||||
|
in the ironic configuration file as well::
|
||||||
|
|
||||||
|
[metrics_statsd]
|
||||||
|
# Point this at a statsd host reachable from the provisioning and cleaning nets
|
||||||
|
agent_statsd_host = 198.51.100.2
|
||||||
|
agent_statsd_port = 8125
|
||||||
|
|
||||||
|
|
||||||
|
Types of Metrics Emitted
|
||||||
|
========================
|
||||||
|
|
||||||
|
The Bare Metal service emits timing metrics for every API method, as well as
|
||||||
|
for most driver methods. These metrics measure how long a given method takes
|
||||||
|
to execute.
|
||||||
|
|
||||||
|
A deployer with metrics enabled should expect between 100 and 500 distinctly
|
||||||
|
named data points to be emitted from the Bare Metal service. This will
|
||||||
|
increase if the metrics.preserve_host option is set to true or if multiple
|
||||||
|
drivers are used in the Bare Metal deployment. This estimate may be used to
|
||||||
|
determine if a deployer needs to scale their metrics backend to handle the
|
||||||
|
additional load before enablng metrics.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
With the default statsd configuration, each timing metric may create
|
||||||
|
additional metrics due to how statsd handles timing metrics. For more
|
||||||
|
information, see statds documentation on
|
||||||
|
`metric types <https://github.com/etsy/statsd/blob/master/docs/metric_types.md#timing>`_.
|
||||||
|
|
||||||
|
The ironic-python-agent ramdisk emits timing metrics for every API method.
|
||||||
|
|
||||||
|
Deployers who use custom HardwareManagers can emit custom metrics for their
|
||||||
|
hardware. For more information on custom HardwareManagers, and emitting
|
||||||
|
metrics from them, please see the
|
||||||
|
`ironic-python-agent documentation <http://docs.openstack.org/developer/ironic-python-agent/>`_.
|
||||||
|
|
||||||
|
|
||||||
|
Adding New Metrics
|
||||||
|
==================
|
||||||
|
|
||||||
|
If you're a developer, and would like to add additional metrics to ironic,
|
||||||
|
please see the ironic-lib developer documentation for details on how to use
|
||||||
|
the metrics library.
|
||||||
|
|
||||||
|
.. TODO::
|
||||||
|
Link to ironic-lib developer documentation once it's published.
|
@ -153,9 +153,7 @@ of ironic that may or may not be suitable to every situation.
|
|||||||
Auditing API Traffic <deploy/api-audit-support>
|
Auditing API Traffic <deploy/api-audit-support>
|
||||||
Configuring for Multi-tenant Networking <deploy/multitenancy>
|
Configuring for Multi-tenant Networking <deploy/multitenancy>
|
||||||
Configuring node web or serial console <deploy/console>
|
Configuring node web or serial console <deploy/console>
|
||||||
|
Emitting software metrics <deploy/metrics>
|
||||||
.. TODO::
|
|
||||||
Add page on metrics.
|
|
||||||
|
|
||||||
A reference guide listing all available configuration options is published for
|
A reference guide listing all available configuration options is published for
|
||||||
every major release. Additionally, a `sample configuration file`_ is included
|
every major release. Additionally, a `sample configuration file`_ is included
|
||||||
|
Loading…
Reference in New Issue
Block a user