store_api/
mito_engine_options.rs

1// Copyright 2023 Greptime Team
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7//     http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15//! Option keys for the mito engine.
16//! We define them in this mod so the create parser can use it to validate table options.
17
18/// Option key for all WAL options.
19pub use common_wal::options::WAL_OPTIONS_KEY;
20/// Option key for append mode.
21pub const APPEND_MODE_KEY: &str = "append_mode";
22/// Option key for merge mode.
23pub const MERGE_MODE_KEY: &str = "merge_mode";
24/// Option key for TTL(time-to-live)
25pub const TTL_KEY: &str = "ttl";
26/// Option key for snapshot read.
27pub const SNAPSHOT_READ: &str = "snapshot_read";
28/// Option key for compaction type.
29pub const COMPACTION_TYPE: &str = "compaction.type";
30/// TWCS compaction strategy.
31pub const COMPACTION_TYPE_TWCS: &str = "twcs";
32/// Option key for twcs min file num to trigger a compaction.
33pub const TWCS_TRIGGER_FILE_NUM: &str = "compaction.twcs.trigger_file_num";
34/// Option key for twcs max output file size.
35pub const TWCS_MAX_OUTPUT_FILE_SIZE: &str = "compaction.twcs.max_output_file_size";
36/// Option key for twcs time window.
37pub const TWCS_TIME_WINDOW: &str = "compaction.twcs.time_window";
38/// Option key for twcs remote compaction.
39pub const TWCS_REMOTE_COMPACTION: &str = "compaction.twcs.remote_compaction";
40/// Option key for twcs fallback to local.
41pub const TWCS_FALLBACK_TO_LOCAL: &str = "compaction.twcs.fallback_to_local";
42/// Option key for memtable type.
43pub const MEMTABLE_TYPE: &str = "memtable.type";
44/// Option key for memtable partition tree primary key encoding.
45pub const MEMTABLE_PARTITION_TREE_PRIMARY_KEY_ENCODING: &str =
46    "memtable.partition_tree.primary_key_encoding";
47/// Option key for memtable partition tree index max keys per shard.
48pub const MEMTABLE_PARTITION_TREE_INDEX_MAX_KEYS_PER_SHARD: &str =
49    "memtable.partition_tree.index_max_keys_per_shard";
50/// Option key for memtable partition tree data freeze threshold.
51pub const MEMTABLE_PARTITION_TREE_DATA_FREEZE_THRESHOLD: &str =
52    "memtable.partition_tree.data_freeze_threshold";
53/// Option key for memtable partition tree fork dictionary bytes.
54pub const MEMTABLE_PARTITION_TREE_FORK_DICTIONARY_BYTES: &str =
55    "memtable.partition_tree.fork_dictionary_bytes";
56/// Option key for skipping WAL.
57pub const SKIP_WAL_KEY: &str = "skip_wal";
58/// Option key for sst format.
59pub const SST_FORMAT_KEY: &str = "sst_format";
60// Note: Adding new options here should also check if this option should be removed in [metric_engine::engine::create::region_options_for_metadata_region].
61
62/// Returns true if the `key` is a valid option key for the mito engine.
63pub fn is_mito_engine_option_key(key: &str) -> bool {
64    [
65        "ttl",
66        COMPACTION_TYPE,
67        TWCS_TRIGGER_FILE_NUM,
68        TWCS_MAX_OUTPUT_FILE_SIZE,
69        TWCS_TIME_WINDOW,
70        TWCS_REMOTE_COMPACTION,
71        TWCS_FALLBACK_TO_LOCAL,
72        "storage",
73        "index.inverted_index.ignore_column_ids",
74        "index.inverted_index.segment_row_count",
75        WAL_OPTIONS_KEY,
76        MEMTABLE_TYPE,
77        MEMTABLE_PARTITION_TREE_INDEX_MAX_KEYS_PER_SHARD,
78        MEMTABLE_PARTITION_TREE_DATA_FREEZE_THRESHOLD,
79        MEMTABLE_PARTITION_TREE_FORK_DICTIONARY_BYTES,
80        MEMTABLE_PARTITION_TREE_PRIMARY_KEY_ENCODING,
81        APPEND_MODE_KEY,
82        MERGE_MODE_KEY,
83        SST_FORMAT_KEY,
84    ]
85    .contains(&key)
86}
87
88#[cfg(test)]
89mod tests {
90    use super::*;
91
92    #[test]
93    fn test_is_mito_engine_option_key() {
94        assert!(is_mito_engine_option_key("ttl"));
95        assert!(is_mito_engine_option_key("compaction.type"));
96        assert!(is_mito_engine_option_key(
97            "compaction.twcs.trigger_file_num"
98        ));
99        assert!(is_mito_engine_option_key("compaction.twcs.time_window"));
100        assert!(is_mito_engine_option_key("storage"));
101        assert!(is_mito_engine_option_key(
102            "index.inverted_index.ignore_column_ids"
103        ));
104        assert!(is_mito_engine_option_key(
105            "index.inverted_index.segment_row_count"
106        ));
107        assert!(is_mito_engine_option_key("wal_options"));
108        assert!(is_mito_engine_option_key("memtable.type"));
109        assert!(is_mito_engine_option_key(
110            "memtable.partition_tree.index_max_keys_per_shard"
111        ));
112        assert!(is_mito_engine_option_key(
113            "memtable.partition_tree.data_freeze_threshold"
114        ));
115        assert!(is_mito_engine_option_key(
116            "memtable.partition_tree.fork_dictionary_bytes"
117        ));
118        assert!(is_mito_engine_option_key("append_mode"));
119        assert!(!is_mito_engine_option_key("foo"));
120    }
121}