diff options
author | bazeltsev <[email protected]> | 2022-08-16 10:17:29 +0300 |
---|---|---|
committer | bazeltsev <[email protected]> | 2022-08-16 10:17:29 +0300 |
commit | d7efecffef1a3d70647a2bb84dd1105cdc3d396a (patch) | |
tree | fa6ecb03c20b77251d0a9833ee9e126662dd5d2e | |
parent | 090d6a73ed082496eddf79943b652ba49b932617 (diff) |
Add ydb cli topic comands
-rw-r--r-- | ydb/docs/ru/core/reference/ydb-cli/toc_i.yaml | 2 | ||||
-rw-r--r-- | ydb/docs/ru/core/reference/ydb-cli/topic.md | 234 |
2 files changed, 236 insertions, 0 deletions
diff --git a/ydb/docs/ru/core/reference/ydb-cli/toc_i.yaml b/ydb/docs/ru/core/reference/ydb-cli/toc_i.yaml index 501fb001e26..53bc06a6005 100644 --- a/ydb/docs/ru/core/reference/ydb-cli/toc_i.yaml +++ b/ydb/docs/ru/core/reference/ydb-cli/toc_i.yaml @@ -33,6 +33,8 @@ items: href: commands/scan-query.md - name: Загрузка и выгрузка данных include: { mode: link, path: export_import/toc_p.yaml } + - name: Работа с топиками + href: topic.md # - name: Утилиты # items: # - name: Копирование таблиц diff --git a/ydb/docs/ru/core/reference/ydb-cli/topic.md b/ydb/docs/ru/core/reference/ydb-cli/topic.md new file mode 100644 index 00000000000..7ecc2b2d22a --- /dev/null +++ b/ydb/docs/ru/core/reference/ydb-cli/topic.md @@ -0,0 +1,234 @@ +# Работа с топиками + +С помощью подкоманды `topic` вы можете создать, изменить или удалить [топик](../../concepts/topic.md), а также создать или удалить [читателя](../../concepts/topic.md#consumer). + +В примерах используется профиль `db1`, подробнее смотрите в [{#T}](../../getting_started/cli.md#profile). + +## Создание топика {#topic-create} + +С помощью подкоманды `topic create` вы можете создать новый топик. + +Общий вид команды: + +```bash +{{ ydb-cli }} [global options...] topic create [options...] <topic-path> +``` + +* `global options` — [глобальные параметры](commands/global-options.md). +* `options` — [параметры подкоманды](#options). +* `topic-path` — путь топика. + +Посмотрите описание команды создания топика: + +```bash +{{ ydb-cli }} topic create --help +``` + +### Параметры подкоманды {#topic-create-options} + +Имя | Описание +---|--- +`--partitions-count VAL`| Количество [партиций](../../concepts/topic.md#partitioning) топика.<br>Значение по умолчанию — `1`. +`--retention-period-hours VAL` | Время хранения данных в топике, задается в часах.<br>Значение по умолчанию — `18`. +`--supported-codecs STRING` | Поддерживаемые метод сжатия данных.<br>Значение по умолчанию — `raw,zstd,gzip,lzop`.<br>Возможные значения:<ul><li>`RAW` — без сжатия;</li><li>`ZSTD` — сжатие [zstd](https://ru.wikipedia.org/wiki/Zstandard);</li><li>`GZIP` — сжатие [gzip](https://ru.wikipedia.org/wiki/Gzip);</li><li>`LZOP` — сжатие [lzop](https://ru.wikipedia.org/wiki/Lzop).</li></ul> + +### Примеры {#topic-create-examples} + +Создайте топик с 2 партициями, методами сжатия `RAW` и `GZIP`, временем хранения сообщений 2 часа и путем `my-topic`: + +```bash +{{ ydb-cli }} -p db1 topic create topic create \ + --partitions-count 2 \ + --supported-codecs raw,gzip \ + --retention-period-hours 2 \ + my-topic +``` + +Посмотрите параметры созданного топика: + +```bash +{{ ydb-cli }} -p db1 scheme describe my-topic +``` + +Результат: + +```text +RetentionPeriod: 2 hours +PartitionsCount: 2 +SupportedCodecs: RAW, GZIP +``` + +## Изменение топика {#topic-alter} + +С помощью подкоманды `topic alter` вы можете изменить [созданный ранее](#topic-create) топик. + +Общий вид команды: + +```bash +{{ ydb-cli }} [global options...] topic alter [options...] <topic-path> +``` + +* `global options` — [глобальные параметры](commands/global-options.md). +* `options` — [параметры подкоманды](#options). +* `topic-path` — путь топика. + +Посмотрите описание команды изменения топика: + +```bash +{{ ydb-cli }} topic alter --help +``` + +### Параметры подкоманды {#topic-alter-options} + +Имя | Описание +---|--- +`--partitions-count VAL`| Количество [партиций](../../concepts/topic.md#partitioning) топика.<br>Значение по умолчанию — `1`. +`--retention-period-hours VAL` | Время хранения данных в топике, задается в часах.<br>Значение по умолчанию — `18`. +`--supported-codecs STRING` | Поддерживаемые метод сжатия данных.<br>Значение по умолчанию — `raw,zstd,gzip,lzop`.<br>Возможные значения:<ul><li>`RAW` — без сжатия;</li><li>`ZSTD` — сжатие [zstd](https://ru.wikipedia.org/wiki/Zstandard);</li><li>`GZIP` — сжатие [gzip](https://ru.wikipedia.org/wiki/Gzip);</li><li>`LZOP` — сжатие [lzop](https://ru.wikipedia.org/wiki/Lzop).</li></ul> + +### Примеры {#topic-alter-examples} + +Добавьте партицию и метод сжатия `lzop` [созданному ранее](#topic-create) топику: + +```bash +{{ ydb-cli }} -p db1 topic alter \ + --partitions-count 3 \ + --supported-codecs raw,gzip,lzop \ + my-topic +``` + +Убедитесь, что параметры топика изменились: + +```bash +{{ ydb-cli }} -p db1 scheme describe my-topic +``` + +Результат: + +```text +RetentionPeriod: 2 hours +PartitionsCount: 3 +SupportedCodecs: RAW, GZIP, LZOP +``` + +## Удаление топика {#topic-drop} + +С помощью подкоманды `topic drop` вы можете удалить [созданный ранее](#topic-create) топик. + +Общий вид команды: + +```bash +{{ ydb-cli }} [global options...] topic drop <topic-path> +``` + +* `global options` — [глобальные параметры](commands/global-options.md). +* `topic-path` — путь топика. + +Посмотрите описание команды удаления топика: + +```bash +{{ ydb-cli }} topic drop --help +``` + +### Примеры {#topic-drop-examples} + +Удалите [созданный ранее](#topic-create) топик: + +```bash +{{ ydb-cli }} -p db1 topic drop my-topic +``` + +## Создание читателя для топика {#consumer-add} + +С помощью подкоманды `topic consumer add` вы можете создать читателя для [созданного ранее](#topic-create) топика. + +Общий вид команды: + +```bash +{{ ydb-cli }} [global options...] topic consumer add [options...] <topic-path> +``` + +* `global options` — [глобальные параметры](commands/global-options.md). +* `options` — [параметры подкоманды](#options). +* `topic-path` — путь топика. + +Посмотрите описание команды добавления читателя: + +```bash +{{ ydb-cli }} topic consumer add --help +``` + +### Параметры подкоманды {#consumer-add-options} + +Имя | Описание +---|--- +`--consumer-name VAL` | Имя читателя, которого нужно создать. +`--starting-message-timestamp VAL` | Время в формате [UNIX timestamp](https://ru.wikipedia.org/wiki/Unix-время). Чтение начнется с первого [сообщения](../../concepts/topic.md#message), полученного после указанного времени. Если время не задано, то чтение начнется с самой старого сообщения в топике. + +### Примеры {#consumer-add-examples} + +Создайте читателя с именем `my-consumer` для [созданного ранее](#topic-create) топика `my-topic`, чтение начнется с первого сообщения, полученного после 15 августа 2022 13:00:00 GMT: + +```bash +{{ ydb-cli }} -p db1 topic consumer add \ + --consumer-name my-consumer \ + --starting-message-timestamp 1660568400 \ + my-topic +``` + +Убедитесь, что читатель создан: + +```bash +{{ ydb-cli }} -p db1 scheme describe my-topic +``` + +Результат: + +```text +RetentionPeriod: 2 hours +PartitionsCount: 2 +SupportedCodecs: RAW, GZIP + +Consumers: +┌──────────────┬─────────────────┬───────────────────────────────┬───────────┐ +| ConsumerName | SupportedCodecs | ReadFrom | Important | +├──────────────┼─────────────────┼───────────────────────────────┼───────────┤ +| my-consumer | RAW, GZIP | Mon, 15 Aug 2022 16:00:00 MSK | 0 | +└──────────────┴─────────────────┴───────────────────────────────┴───────────┘ +``` + +## Удаление читателя {#consumer-drop} + +С помощью подкоманды `topic consumer drop` вы можете удалить [созданного ранее](#consumer-add) читателя. + +Общий вид команды: + +```bash +{{ ydb-cli }} [global options...] topic consumer drop [options...] <topic-path> +``` + +* `global options` — [глобальные параметры](commands/global-options.md). +* `options` — [параметры подкоманды](#options). +* `topic-path` — путь топика. + +Посмотрите описание команды удаления читателя: + +```bash +{{ ydb-cli }} topic consumer drop --help +``` + +### Параметры подкоманды {#consumer-drop-options} + +Имя | Описание +---|--- +`--consumer-name VAL` | Имя читателя, которого нужно удалить. + +### Примеры {#consumer-drop-examples} + +Удалите [ранее созданного](#consumer-add) читателя с именем `my-consumer` для топика `my-topic`: + +```bash +{{ ydb-cli }} -p db1 topic consumer drop \ + --consumer-name my-consumer \ + my-topic +``` |