KeeperMap
This engine allows you to use Keeper/ZooKeeper cluster as consistent key-value store with linearizable writes and sequentially consistent reads.
To enable KeeperMap storage engine, you need to define a ZooKeeper path where the tables will be stored using <keeper_map_path_prefix> config.
For example:
where path can be any other valid ZooKeeper path.
Creating a table
Engine parameters:
- root_path- ZooKeeper path where the- table_namewill be stored.
 This path should not contain the prefix defined by- <keeper_map_path_prefix>config because the prefix will be automatically appended to the- root_path.
 Additionally, format of- auxiliary_zookeeper_cluster_name:/some/pathis also supported where- auxiliary_zookeeper_clusteris a ZooKeeper cluster defined inside- <auxiliary_zookeepers>config.
 By default, ZooKeeper cluster defined inside- <zookeeper>config is used.
- keys_limit- number of keys allowed inside the table.
 This limit is a soft limit and it can be possible that more keys will end up in the table for some edge cases.
- primary_key_name– any column name in the column list.
- primary keymust be specified, it supports only one column in the primary key. The primary key will be serialized in binary as a- node nameinside ZooKeeper.
- columns other than the primary key will be serialized to binary in corresponding order and stored as a value of the resulting node defined by the serialized key.
- queries with key equalsorinfiltering will be optimized to multi keys lookup fromKeeper, otherwise all values will be fetched.
Example:
with
Each value, which is binary serialization of (v1, v2, v3), will be stored inside /keeper_map_tables/keeper_map_table/data/serialized_key in Keeper.
Additionally, number of keys will have a soft limit of 4 for the number of keys.
If multiple tables are created on the same ZooKeeper path, the values are persisted until there exists at least 1 table using it.
As a result, it is possible to use ON CLUSTER clause when creating the table and sharing the data from multiple ClickHouse instances.
Of course, it's possible to manually run CREATE TABLE with same path on unrelated ClickHouse instances to have same data sharing effect.
Supported operations
Inserts
When new rows are inserted into KeeperMap, if the key does not exist, a new entry for the key is created.
If the key exists, and setting keeper_map_strict_mode is set to true, an exception is thrown, otherwise, the value for the key is overwritten.
Example:
Deletes
Rows can be deleted using DELETE query or TRUNCATE.
If the key exists, and setting keeper_map_strict_mode is set to true, fetching and deleting data will succeed only if it can be executed atomically.
Updates
Values can be updated using ALTER TABLE query. Primary key cannot be updated.
If setting keeper_map_strict_mode is set to true, fetching and updating data will succeed only if it's executed atomically.
