From 1dcbd607df0696101b40f77d7721489679ebe0ba Mon Sep 17 00:00:00 2001 From: Mehdi Abaakouk Date: Thu, 12 Apr 2018 12:15:56 +0200 Subject: [PATCH] Deprecating transformers and pipeline partitioning Theses features doesn't work well, rate-of-change metrics can still wrongly be computed even with Pipeline partioning enabled. Also backend like Gnocchi offers a better alternative to compute them. This deprecates these two features, to be able to remove them in a couple of releases. Change-Id: I52362c69b7d500bfe6dba76f78403a9d376deb80 --- ceilometer/notification.py | 2 + ceilometer/pipeline/data/event_pipeline.yaml | 1 - ceilometer/pipeline/data/pipeline.yaml | 9 +- doc/source/admin/telemetry-best-practices.rst | 6 - .../admin/telemetry-data-collection.rst | 7 +- doc/source/admin/telemetry-data-pipelines.rst | 288 +----------------- doc/source/admin/telemetry-measurements.rst | 11 +- doc/source/contributor/3-Pipeline.png | Bin 46678 -> 25393 bytes doc/source/contributor/4-Transformer.png | Bin 42222 -> 0 bytes doc/source/contributor/architecture.rst | 21 -- .../notes/transformer-ed4b1ea7d1752576.yaml | 10 + 11 files changed, 32 insertions(+), 323 deletions(-) delete mode 100644 doc/source/contributor/4-Transformer.png create mode 100644 releasenotes/notes/transformer-ed4b1ea7d1752576.yaml diff --git a/ceilometer/notification.py b/ceilometer/notification.py index b724be98b3..cebd09dbf6 100644 --- a/ceilometer/notification.py +++ b/ceilometer/notification.py @@ -37,6 +37,7 @@ LOG = log.getLogger(__name__) OPTS = [ cfg.IntOpt('pipeline_processing_queues', + deprecated_for_removal=True, default=10, min=1, help='Number of queues to parallelize workload across. This ' @@ -47,6 +48,7 @@ OPTS = [ default=True, help='Acknowledge message when event persistence fails.'), cfg.BoolOpt('workload_partitioning', + deprecated_for_removal=True, default=False, help='Enable workload partitioning, allowing multiple ' 'notification agents to be run simultaneously.'), diff --git a/ceilometer/pipeline/data/event_pipeline.yaml b/ceilometer/pipeline/data/event_pipeline.yaml index 6482f4f285..250746feb6 100644 --- a/ceilometer/pipeline/data/event_pipeline.yaml +++ b/ceilometer/pipeline/data/event_pipeline.yaml @@ -7,6 +7,5 @@ sources: - event_sink sinks: - name: event_sink - transformers: publishers: - gnocchi:// diff --git a/ceilometer/pipeline/data/pipeline.yaml b/ceilometer/pipeline/data/pipeline.yaml index 6e361df0a5..1f1ec989ad 100644 --- a/ceilometer/pipeline/data/pipeline.yaml +++ b/ceilometer/pipeline/data/pipeline.yaml @@ -33,9 +33,10 @@ sources: - network_sink sinks: - name: meter_sink - transformers: publishers: - gnocchi:// + + # All these transformers are deprecated, and will be removed in the future, don't use them. - name: cpu_sink transformers: - name: "rate_of_change" @@ -48,6 +49,8 @@ sinks: scale: "100.0 / (10**9 * (resource_metadata.cpu_number or 1))" publishers: - gnocchi:// + + # All these transformers are deprecated, and will be removed in the future, don't use them. - name: cpu_delta_sink transformers: - name: "delta" @@ -57,6 +60,8 @@ sinks: growth_only: True publishers: - gnocchi:// + + # All these transformers are deprecated, and will be removed in the future, don't use them. - name: disk_sink transformers: - name: "rate_of_change" @@ -72,6 +77,8 @@ sinks: type: "gauge" publishers: - gnocchi:// + + # All these transformers are deprecated, and will be removed in the future, don't use them. - name: network_sink transformers: - name: "rate_of_change" diff --git a/doc/source/admin/telemetry-best-practices.rst b/doc/source/admin/telemetry-best-practices.rst index db4439cc49..4c3dc3f792 100644 --- a/doc/source/admin/telemetry-best-practices.rst +++ b/doc/source/admin/telemetry-best-practices.rst @@ -27,9 +27,3 @@ Data collection central and compute agents as necessary. The agents are designed to scale horizontally. For more information refer to the `high availability guide `_. - -#. `workload_partitioning` of notification agents is only required if - the pipeline configuration leverages transformers. It may also be enabled if - batching is required to minimize load on the defined publisher targets. If - transformers are not enabled, multiple agents may still be deployed without - `workload_partitioning` and processing will be done greedily. diff --git a/doc/source/admin/telemetry-data-collection.rst b/doc/source/admin/telemetry-data-collection.rst index fb80bb6095..26c163536f 100644 --- a/doc/source/admin/telemetry-data-collection.rst +++ b/doc/source/admin/telemetry-data-collection.rst @@ -39,10 +39,9 @@ By default, the notification agent is configured to build both events and samples. To enable selective data models, set the required pipelines using `pipelines` option under the `[notification]` section. -Additionally, the notification agent is responsible for all data processing -such as transformations and publishing. After processing, the data is sent -to any supported publisher target such as gnocchi or panko. These services -persist the data in configured databases. +Additionally, the notification agent is responsible to send to any supported +publisher target such as gnocchi or panko. These services persist the data in +configured databases. The different OpenStack services emit several notifications about the various types of events that happen in the system during normal diff --git a/doc/source/admin/telemetry-data-pipelines.rst b/doc/source/admin/telemetry-data-pipelines.rst index ebcac0c548..db6b751b1f 100644 --- a/doc/source/admin/telemetry-data-pipelines.rst +++ b/doc/source/admin/telemetry-data-pipelines.rst @@ -6,7 +6,7 @@ Data processing and pipelines The mechanism by which data is processed is called a pipeline. Pipelines, at the configuration level, describe a coupling between sources of data and -the corresponding sinks for transformation and publication of data. This +the corresponding sinks for publication of data. This functionality is handled by the notification agents. A source is a producer of data: ``samples`` or ``events``. In effect, it is a @@ -17,13 +17,9 @@ Each source configuration encapsulates name matching and mapping to one or more sinks for publication. A sink, on the other hand, is a consumer of data, providing logic for -the transformation and publication of data emitted from related sources. +the publication of data emitted from related sources. -In effect, a sink describes a chain of handlers. The chain starts with -zero or more transformers and ends with one or more publishers. The -first transformer in the chain is passed data from the corresponding -source, takes some action such as deriving rate of change, performing -unit conversion, or aggregating, before publishing_. +In effect, a sink describes a list of one or more publishers. .. _telemetry-pipeline-configuration: @@ -52,7 +48,6 @@ The meter pipeline definition looks like: - 'sink name' sinks: - name: 'sink name' - transformers: 'definition of transformers' publishers: - 'list of publishers' @@ -97,30 +92,8 @@ The above definition methods can be used in the following combinations: same pipeline. Wildcard and included meters cannot co-exist in the same pipeline definition section. -The transformers section of a pipeline sink provides the possibility to -add a list of transformer definitions. The available transformers are: - -.. list-table:: - :widths: 50 50 - :header-rows: 1 - - * - Name of transformer - - Reference name for configuration - * - Accumulator - - accumulator - * - Aggregator - - aggregator - * - Arithmetic - - arithmetic - * - Rate of change - - rate\_of\_change - * - Unit conversion - - unit\_conversion - * - Delta - - delta - The publishers section contains the list of publishers, where the -samples data should be sent after the possible transformations. +samples data should be sent. Similarly, the event pipeline definition looks like: @@ -140,229 +113,6 @@ Similarly, the event pipeline definition looks like: The event filter uses the same filtering logic as the meter pipeline. -.. _telemetry-transformers: - -Transformers ------------- - -.. note:: - - Transformers maintain data in memory and therefore do not guarantee - durability in certain scenarios. A more durable and efficient solution - may be achieved post-storage using solutions like Gnocchi. - -The definition of transformers can contain the following fields: - -name - Name of the transformer. - -parameters - Parameters of the transformer. - -The parameters section can contain transformer specific fields, like -source and target fields with different subfields in case of the rate of -change, which depends on the implementation of the transformer. - -The following are supported transformers: - -Rate of change transformer -`````````````````````````` -Transformer that computes the change in value between two data points in time. -In the case of the transformer that creates the ``cpu_util`` meter, the -definition looks like: - -.. code-block:: yaml - - transformers: - - name: "rate_of_change" - parameters: - target: - name: "cpu_util" - unit: "%" - type: "gauge" - scale: "100.0 / (10**9 * (resource_metadata.cpu_number or 1))" - -The rate of change transformer generates the ``cpu_util`` meter -from the sample values of the ``cpu`` counter, which represents -cumulative CPU time in nanoseconds. The transformer definition above -defines a scale factor (for nanoseconds and multiple CPUs), which is -applied before the transformation derives a sequence of gauge samples -with unit ``%``, from sequential values of the ``cpu`` meter. - -The definition for the disk I/O rate, which is also generated by the -rate of change transformer: - -.. code-block:: yaml - - transformers: - - name: "rate_of_change" - parameters: - source: - map_from: - name: "disk\\.(read|write)\\.(bytes|requests)" - unit: "(B|request)" - target: - map_to: - name: "disk.\\1.\\2.rate" - unit: "\\1/s" - type: "gauge" - -Unit conversion transformer -``````````````````````````` - -Transformer to apply a unit conversion. It takes the volume of the meter -and multiplies it with the given ``scale`` expression. Also supports -``map_from`` and ``map_to`` like the rate of change transformer. - -Sample configuration: - -.. code-block:: yaml - - transformers: - - name: "unit_conversion" - parameters: - target: - name: "disk.kilobytes" - unit: "KB" - scale: "volume * 1.0 / 1024.0" - -With ``map_from`` and ``map_to``: - -.. code-block:: yaml - - transformers: - - name: "unit_conversion" - parameters: - source: - map_from: - name: "disk\\.(read|write)\\.bytes" - target: - map_to: - name: "disk.\\1.kilobytes" - scale: "volume * 1.0 / 1024.0" - unit: "KB" - -Aggregator transformer -`````````````````````` - -A transformer that sums up the incoming samples until enough samples -have come in or a timeout has been reached. - -Timeout can be specified with the ``retention_time`` option. If you want -to flush the aggregation, after a set number of samples have been -aggregated, specify the size parameter. - -The volume of the created sample is the sum of the volumes of samples -that came into the transformer. Samples can be aggregated by the -attributes ``project_id``, ``user_id`` and ``resource_metadata``. To aggregate -by the chosen attributes, specify them in the configuration and set which -value of the attribute to take for the new sample (first to take the -first sample's attribute, last to take the last sample's attribute, and -drop to discard the attribute). - -To aggregate 60s worth of samples by ``resource_metadata`` and keep the -``resource_metadata`` of the latest received sample: - -.. code-block:: yaml - - transformers: - - name: "aggregator" - parameters: - retention_time: 60 - resource_metadata: last - -To aggregate each 15 samples by ``user_id`` and ``resource_metadata`` and keep -the ``user_id`` of the first received sample and drop the -``resource_metadata``: - -.. code-block:: yaml - - transformers: - - name: "aggregator" - parameters: - size: 15 - user_id: first - resource_metadata: drop - -Accumulator transformer -``````````````````````` - -This transformer simply caches the samples until enough samples have -arrived and then flushes them all down the pipeline at once: - -.. code-block:: yaml - - transformers: - - name: "accumulator" - parameters: - size: 15 - -Multi meter arithmetic transformer -`````````````````````````````````` - -This transformer enables us to perform arithmetic calculations over one -or more meters and/or their metadata, for example:: - - memory_util = 100 * memory.usage / memory - -A new sample is created with the properties described in the ``target`` -section of the transformer's configuration. The sample's -volume is the result of the provided expression. The calculation is -performed on samples from the same resource. - -.. note:: - - The calculation is limited to meters with the same interval. - -Example configuration: - -.. code-block:: yaml - - transformers: - - name: "arithmetic" - parameters: - target: - name: "memory_util" - unit: "%" - type: "gauge" - expr: "100 * $(memory.usage) / $(memory)" - -To demonstrate the use of metadata, the following implementation of a -novel meter shows average CPU time per core: - -.. code-block:: yaml - - transformers: - - name: "arithmetic" - parameters: - target: - name: "avg_cpu_per_core" - unit: "ns" - type: "cumulative" - expr: "$(cpu) / ($(cpu).resource_metadata.cpu_number or 1)" - -.. note:: - - Expression evaluation gracefully handles NaNs and exceptions. In - such a case it does not create a new sample but only logs a warning. - -Delta transformer -````````````````` - -This transformer calculates the change between two sample datapoints of a -resource. It can be configured to capture only the positive growth deltas. - -Example configuration: - -.. code-block:: yaml - - transformers: - - name: "delta" - parameters: - target: - name: "cpu.delta" - growth_only: True - .. _publishing: Publishers @@ -510,33 +260,3 @@ specified. A sample ``publishers`` section in the - panko:// - udp://10.0.0.2:1234 - notifier://?policy=drop&max_queue_length=512&topic=custom_target - -Pipeline Partitioning -~~~~~~~~~~~~~~~~~~~~~ - -.. note:: - - Partitioning is only required if pipelines contain transformations. It has - secondary benefit of supporting batching in certain publishers. - -On large workloads, multiple notification agents can be deployed to handle the -flood of incoming messages from monitored services. If transformations are -enabled in the pipeline, the notification agents must be coordinated to ensure -related messages are routed to the same agent. To enable coordination, set the -``workload_partitioning`` value in ``notification`` section. - -To distribute messages across agents, ``pipeline_processing_queues`` option -should be set. This value defines how many pipeline queues to create which will -then be distributed to the active notification agents. It is recommended that -the number of processing queues, at the very least, match the number of agents. - -Increasing the number of processing queues will improve the distribution of -messages across the agents. It will also help batching which minimises the -requests to Gnocchi storage backend. It will also increase the load the on -message queue as it uses the queue to shard data. - -.. warning:: - - Decreasing the number of processing queues may result in lost data as any - previously created queues may no longer be assigned to active agents. It - is only recommended that you **increase** processing queues. diff --git a/doc/source/admin/telemetry-measurements.rst b/doc/source/admin/telemetry-measurements.rst index dbd4148cda..f1d27cec6a 100644 --- a/doc/source/admin/telemetry-measurements.rst +++ b/doc/source/admin/telemetry-measurements.rst @@ -356,12 +356,11 @@ The following meters are collected for OpenStack Compute. To enable libvirt ``disk.*`` support when running on RBD-backed shared storage, you need to install libvirt version 1.2.16+. -The Telemetry service supports creating new meters by using -transformers. For more details about transformers see -:ref:`telemetry-transformers`. Among the meters gathered from libvirt and -Hyper-V, there are a few which are derived from other meters. The list of -meters that are created by using the ``rate_of_change`` transformer from the -above table is the following: +The Telemetry service supports creating new meters by using transformers, but +this is deprecated and discouraged to use. Among the meters gathered from +libvirt and Hyper-V, there are a few which are derived from other meters. The +list of meters that are created by using the ``rate_of_change`` transformer +from the above table is the following: - cpu_util diff --git a/doc/source/contributor/3-Pipeline.png b/doc/source/contributor/3-Pipeline.png index 5948d1c4ad4235efdbfe6caba5989eb2201cdf72..01f8243683e849de77ec65beae03773db99d5aef 100644 GIT binary patch literal 25393 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 MQ(vR_mfiFJ1F^ro7ytkO literal 46678 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 diff --git a/doc/source/contributor/architecture.rst b/doc/source/contributor/architecture.rst index 249208675d..7446c3d370 100644 --- a/doc/source/contributor/architecture.rst +++ b/doc/source/contributor/architecture.rst @@ -154,27 +154,6 @@ Ceilometer offers the ability to take data gathered by the agents, manipulate it, and publish it in various combinations via multiple pipelines. This functionality is handled by the notification agents. -Transforming the data ---------------------- - -.. figure:: ./4-Transformer.png - :width: 100% - :align: center - :alt: Transformer example - - Example of aggregation of multiple cpu time usage samples in a single - cpu percentage sample. - -The data gathered from the polling and notifications agents contains a wealth -of data and if combined with historical or temporal context, can be used to -derive even more data. Ceilometer offers various transformers which can be used -to manipulate data in the pipeline. - -.. note:: - - The equivalent functionality can be handled more stably by storage - drivers such as Gnocchi. - Publishing the data ------------------- diff --git a/releasenotes/notes/transformer-ed4b1ea7d1752576.yaml b/releasenotes/notes/transformer-ed4b1ea7d1752576.yaml new file mode 100644 index 0000000000..872e9716ec --- /dev/null +++ b/releasenotes/notes/transformer-ed4b1ea7d1752576.yaml @@ -0,0 +1,10 @@ +--- +deprecations: + - | + Usage of transformers in Ceilometer pipelines is deprecated. Transformers in Ceilometer + have never computed samples correctly when you have multiple workers. This functionality can + be done by the storage backend easily without all issues that Ceilometer has. For example, the + rating is already computed in Gnocchi today. + - | + Pipeline Partitioning is also deprecated. This was only useful to + workaround of some issues that tranformers has.