* 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
3.3 KiB
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>