2017-06-26 07:14:13 +00:00
.. _table_engines-graphitemergetree:
2017-05-16 16:54:45 +00:00
GraphiteMergeTree
-----------------
Движок предназначен для rollup (прореживания и агрегирования/усреднения) данных `Graphite <http://graphite.readthedocs.io/en/latest/index.html> `_ . Он может быть интересен разработчикам, которые хотят использовать ClickHouse как хранилище данных для Graphite.
Graphite хранит в ClickHouse полные данные, а получать их может следующими способами:
* Без прореживания.
Используется движок :ref: `MergeTree <table_engines-mergetree>` .
* С прореживанием.
Используется движок `` GraphiteMergeTree `` .
2017-06-26 07:14:13 +00:00
Движок наследует свойства `MergeTree` . Настройки прореживания данных задаются параметром :ref: `server_settings-graphite_rollup` в конфигурации сервера .
2017-05-16 16:54:45 +00:00
Использование движка
^^^^^^^^^^^^^^^^^^^^
Таблица с данными Graphite должна содержать как минимум следующие поля:
* `` Path `` - имя метрики (сенсора Graphite).
* `` Time `` - время измерения.
* `` Value `` - значение метрики в момент времени Time.
* `` Version `` - настройка, которая определяет какое значение метрики с одинаковыми Path и Time останется в базе.
2017-06-13 04:15:47 +00:00
Шаблон правил rollup:
2017-06-13 20:14:20 +00:00
2017-06-13 04:15:47 +00:00
.. code-block :: text
2017-05-16 16:54:45 +00:00
2017-06-26 07:14:13 +00:00
pattern
2017-05-16 16:54:45 +00:00
regexp
function
age -> precision
...
pattern
...
default
function
age -> precision
...
При обработке записи ClickHouse проверит правила в секции `` ` pattern ` `` . Если имя метрики соответствует шаблону `` ` regexp ` `` , то применяются правила из `` ` pattern ` `` , в противном случае из `` ` default ` `` .
Поля шаблона правил.
2017-06-13 20:14:20 +00:00
2017-06-26 07:14:13 +00:00
+---------------+----------------------------------------------------------------------------------------------------------------------------+
| Поле | Описание |
+===============+============================================================================================================================+
| `` age `` | Минимальный возраст данных в секундах. |
+---------------+----------------------------------------------------------------------------------------------------------------------------+
| `` function `` | Имя агрегирующей функции, которую следует применить к данным, чей возраст оказался в интервале `` [age, age + precision] `` . |
+---------------+----------------------------------------------------------------------------------------------------------------------------+
| `` precision `` | Точность определения возраста данных в секундах. |
+---------------+----------------------------------------------------------------------------------------------------------------------------+
| `` regexp `` | Шаблон имени метрики. |
+---------------+----------------------------------------------------------------------------------------------------------------------------+
2017-05-16 16:54:45 +00:00
Пример настройки:
.. code-block :: xml
<graphite_rollup>
<pattern>
<regexp>click_cost</regexp>
<function>any</function>
<retention>
<age>0</age>
<precision>5</precision>
</retention>
<retention>
<age>86400</age>
<precision>60</precision>
</retention>
</pattern>
<default>
<function>max</function>
<retention>
<age>0</age>
<precision>60</precision>
</retention>
<retention>
<age>3600</age>
<precision>300</precision>
</retention>
<retention>
<age>86400</age>
<precision>3600</precision>
</retention>
</default>
</graphite_rollup>