ClickHouse/docs/ru/operations/table_engines/graphitemergetree.md
Ivan Blinkov 0a4a5b36cc
Some WIP on documentation refactoring (#2659)
* Additional .gitignore entries

* Merge a bunch of small articles about system tables into single one

* Merge a bunch of small articles about formats into single one

* Adapt table with formats to English docs too

* Add SPb meetup link to main page

* Move Utilities out of top level of docs (the location is probably not yet final) + translate couple articles

* Merge MacOS.md into build_osx.md

* Move Data types higher in ToC

* Publish changelog on website alongside documentation

* Few fixes for en/table_engines/file.md

* Use smaller header sizes in changelogs

* Group up table engines inside ToC

* Move table engines out of top level too

* Specificy in ToC that query language is SQL based. Thats a bit excessive, but catches eye.

* Move stuff that is part of query language into respective folder

* Move table functions lower in ToC

* Lost redirects.txt update

* Do not rely on comments in yaml + fix few ru titles

* Extract major parts of queries.md into separate articles

* queries.md has been supposed to be removed

* Fix weird translation

* Fix a bunch of links

* There is only table of contents left

* "Query language" is actually part of SQL abbreviation

* Change filename in README.md too

* fix mistype
2018-07-18 13:00:53 +03:00

3.3 KiB
Raw Blame History

GraphiteMergeTree

Движок предназначен для rollup (прореживания и агрегирования/усреднения) данных Graphite. Он может быть интересен разработчикам, которые хотят использовать ClickHouse как хранилище данных для Graphite.

Graphite хранит в ClickHouse полные данные, а получать их может следующими способами:

  • Без прореживания.

    Используется движок MergeTree.

  • С прореживанием.

    Используется движок GraphiteMergeTree.

Движок наследует свойства MergeTree. Настройки прореживания данных задаются параметром graphite_rollup в конфигурации сервера .

Использование движка

Таблица с данными Graphite должна содержать как минимум следующие поля:

  • Path - имя метрики (сенсора Graphite).
  • Time - время измерения.
  • Value - значение метрики в момент времени Time.
  • Version - настройка, которая определяет какое значение метрики с одинаковыми Path и Time останется в базе.

Шаблон правил rollup:

pattern
    regexp
    function
    age -> precision
    ...
pattern
    ...
default
    function
       age -> precision
    ...

При обработке записи ClickHouse проверит правила в секции pattern. Если имя метрики соответствует шаблону regexp, то применяются правила из pattern, в противном случае из default.

Поля шаблона правил.

  • age - Минимальный возраст данных в секундах.
  • function - Имя агрегирующей функции, которую следует применить к данным, чей возраст оказался в интервале [age, age + precision].
  • precision - Точность определения возраста данных в секундах.
  • regexp - Шаблон имени метрики.

Пример настройки:

<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>