Atomic поддерживает неблокирующие запросы DROP TABLE и RENAME TABLE, а также атомарные запросы EXCHANGE TABLES. В ClickHouse с открытым исходным кодом по умолчанию используется движок базы данных Atomic.
В ClickHouse Cloud по умолчанию используется движок базы данных
Shared, который также поддерживает
описанные выше операции.Создание базы данных
Особенности и рекомендации
UUID таблицы
Atomic есть постоянный UUID, а её данные хранятся в следующем каталоге:
xxxyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy — UUID таблицы.
По умолчанию UUID генерируется автоматически. Однако при создании таблицы пользователи могут явно указать UUID, хотя делать это не рекомендуется.
Например:
Вы можете использовать настройку show_table_uuid_in_table_create_query_if_not_nil, чтобы выводить UUID в запросе
SHOW CREATE.RENAME TABLE
RENAME не изменяют UUID и не перемещают данные таблицы. Они выполняются немедленно и не ждут завершения других запросов, использующих эту таблицу.
DROP/DETACH TABLE
DROP TABLE данные не удаляются. Движок Atomic лишь помечает таблицу как удалённую, перемещая её метаданные в /clickhouse_path/metadata_dropped/, и уведомляет фоновый поток. Задержка перед окончательным удалением данных таблицы задаётся настройкой database_atomic_delay_before_drop_table_sec.
Вы можете включить синхронный режим с помощью модификатора SYNC. Для этого используйте настройку database_atomic_wait_for_drop_and_detach_synchronously. В этом случае DROP ожидает завершения выполняющихся SELECT, INSERT и других запросов, использующих таблицу. Таблица будет удалена, когда она перестанет использоваться.
EXCHANGE TABLES/DICTIONARIES
EXCHANGE атомарно меняет местами таблицы или словари. Например, вместо этой неатомарной операции:
Non-atomic
Atomic
ReplicatedMergeTree в базе данных Atomic
ReplicatedMergeTree рекомендуется не задавать параметры движка для пути в ZooKeeper и имени реплики. В этом случае будут использоваться параметры конфигурации default_replica_path и default_replica_name. Если вы хотите явно указать параметры движка, рекомендуется использовать макрос {uuid}. Это гарантирует автоматическое создание уникальных путей в ZooKeeper для каждой таблицы.
Диск для метаданных
SETTINGS указан параметр disk, этот диск используется для хранения файлов метаданных таблицы.
Например:
database_disk.disk.
См. также
- системная таблица system.databases