mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-10-24 17:30:49 +00:00
8623cb232c
* CLICKHOUSE-4063: less manual html @ index.md * CLICKHOUSE-4063: recommend markdown="1" in README.md * CLICKHOUSE-4003: manually purge custom.css for now * CLICKHOUSE-4064: expand <details> before any print (including to pdf) * CLICKHOUSE-3927: rearrange interfaces/formats.md a bit * CLICKHOUSE-3306: add few http headers * Remove copy-paste introduced in #3392 * Hopefully better chinese fonts #3392 * get rid of tabs @ custom.css * Apply comments and patch from #3384 * Add jdbc.md to ToC and some translation, though it still looks badly incomplete * minor punctuation * Add some backlinks to official website from mirrors that just blindly take markdown sources * Do not make fonts extra light * find . -name '*.md' -type f | xargs -I{} perl -pi -e 's//g' {} * find . -name '*.md' -type f | xargs -I{} perl -pi -e 's/ sql/g' {} * Remove outdated stuff from roadmap.md * Not so light font on front page too * Refactor Chinese formats.md to match recent changes in other languages
88 lines
3.5 KiB
Markdown
88 lines
3.5 KiB
Markdown
<a name="table_engines-graphitemergetree"></a>
|
||
|
||
# GraphiteMergeTree
|
||
|
||
Движок предназначен для rollup (прореживания и агрегирования/усреднения) данных [Graphite](http://graphite.readthedocs.io/en/latest/index.html). Он может быть интересен разработчикам, которые хотят использовать ClickHouse как хранилище данных для Graphite.
|
||
|
||
Graphite хранит в ClickHouse полные данные, а получать их может следующими способами:
|
||
|
||
- Без прореживания.
|
||
|
||
Используется движок [MergeTree](mergetree.md#table_engines-mergetree).
|
||
|
||
- С прореживанием.
|
||
|
||
Используется движок `GraphiteMergeTree`.
|
||
|
||
Движок наследует свойства MergeTree. Настройки прореживания данных задаются параметром [graphite_rollup](../server_settings/settings.md#server_settings-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` - Шаблон имени метрики.
|
||
|
||
Пример настройки:
|
||
|
||
```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>
|
||
```
|
||
|
||
[Оригинальная статья](https://clickhouse.yandex/docs/ru/operations/table_engines/graphitemergetree/) <!--hide-->
|