Node-specific configurations
In RisingWave, certain configurations are node-specific and can vary between different nodes. These configurations are stored in a TOML file, which is read at system startup.
Setting up node-specific configurations
Node-specific configurations can be set in the risingwave.toml
configuration file. Here’s the steps on how to set them up:
- Create or locate your
risingwave.toml
file. This file will contain all your node-specific configurations. If it doesn’t exist, create a new one. - Edit the
risingwave.toml
file. Open the file in a text editor. Each configuration item should be specified in the formatconfig_name = value
. For example:
- Save your changes.
After editing, save the
risingwave.toml
file. - Provide the configuration file to the node.
You can do this via the
--config-path
command-line argument when starting the node. For example:
Alternatively, you can set the RW_CONFIG_PATH
environment variable to the path of your risingwave.toml
file.
For example, in a Kubernetes environment, you can copy the configuration file into the Docker container, or mount a path containing the configuration file into the pod. Then, specify the path to the configuration file using the RW_CONFIG_PATH
environment variable or the --config-path
command-line argument.
5. Restart the node.
For the changes to take effect, you must restart the node.
Any items present in risingwave.toml
will override the default values in the source code. If no configuration file is specified, the default values in /risingwave/src/common/src/config.rs
will be used.
For more details about the parameters in the configuration file, see RisingWave configuration files directory. There you’ll find information like the definitions and default values of these parameters.
Node-specific configurations
Configurations for different components lie under different TOML sections. Here’s an example:
When setting up configurations, please be extra careful with those items prefixed by unsafe_
. Typically these configurations can cause system or data damage if wrongly configured. You may want to contact our technical support before changing the unsafe_
prefixed configurations.
System configurations
System configurations are used to initialize the system parameters at the first startup. Once the system has started, the system parameters are managed by Meta service and can be altered using the ALTER SYSTEM SET
command.
Example for the system configuration section:
For more information on system parameters, please refer to View and configure system parameters.
Streaming configurations
Streaming configurations can be set in [streaming]
section in the configuration file. For example:
RisingWave now supports the following configurations:
Configuration | Default | Description |
---|---|---|
unsafe_enable_strict_consistency | true | Control the strictness of stream consistency. When set to false, data inconsistency like double-insertion or double-deletion with the same primary keys will be tolerated. |
Storage configurations
Storage configurations can be set in [storage]
and [storage.xxx]
sections.
File cache and block cache
In RisingWave, several node-specific configurations are provided to control the refilling process of file cache and block cache.
For now, the file cache and cache refilling features are still in technical preview. The configuration items might change in future versions.
The configuration of the file cache and the block cache refilling is separated into 3 parts:
- Data file cache config:
[storage.data_file_cache]
- Meta file cache config:
[storage.meta_file_cache]
- Cache refill config:
[storage.cache_refill]
Below is an example of the data file cache configuration for your reference. Please be aware that the data file cache configuration and the meta file cache configuration share the same options.
Configuration | Default | Description |
---|---|---|
dir | "" | The directory for the file cache. If left empty, the file cache will be disabled. |
capacity_mb | 1024 | The file cache capacity in MB. |
file_capacity_mb | 64 | The capacity for each cache file in MB. |
flushers | 4 | Worker count for concurrently writing cache files. |
reclaimers | 4 | Worker count for concurrently reclaiming cache files. |
recover_concurrency | 8 | Worker count for restoring cache when opening. |
insert_rate_limit_mb | 0 | File cache insertion rate limit in MB/s. This option is important as disk bandwidth is usually lower than memory. |
indexer_shards | 64 | The shard number of the indexer. |
compression | ”none” | Compression algorithm for cached data. Supports none, lz4, and zstd. |
The cache refill configuration is responsible for managing the behavior of LSM-tree data block cache refilling after compaction. The data blocks are refilling at the unit level, where a unit refers to a range of continuous data blocks that are batched and refilled together in one request.
RisingWave uses a recent filter to decide whether to fill a block or unit. The recent filter is a multi-layer hash set. The first layer records the accessed block IDs within a time window. When each time window passes, the recent filter will add a new layer to record and evict the last layer. Blocks whose IDs appear in the recent filter will be treated as “recently used”. When the “recently used” block ratio exceeds a threshold, the unit will be refilled.
Below is an example of the cache refill configuration for your reference.
Configuration | Default | Description |
---|---|---|
data_refill_levels | [] | Only blocks in the given levels will be refilled. |
timeout_ms | 6000 | The metadata update will be delayed at most timeout_ms to wait for refilling. |
concurrency | 10 | Block refilling concurrency (by unit level). |
unit | 64 | The length of continuous data blocks that can be batched and refilled in one request. |
threshold | 0.5 | Only units whose recently used block ratio exceeds the threshold will be refilled. |
recent_filter_layers | 6 | Number of layers in the recent filter. |
recent_filter_rotate_interval_ms | 10000 | Time interval for rotating recent filter layers. |
Other storage configurations
Except for the above, RisingWave also provides some other storage configurations to help control the overall buffer and cache limits. Please see Dedicated compute node for more.