mirror of
https://github.com/GreptimeTeam/greptimedb.git
synced 2026-01-08 14:22:58 +00:00
* feat: don't hidden atomic write dir Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * compatible code Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * Update src/mito2/src/access_layer.rs Co-authored-by: Yingwen <realevenyag@gmail.com> --------- Signed-off-by: Ruihang Xia <waynestxia@gmail.com> Co-authored-by: Yingwen <realevenyag@gmail.com>
54 lines
1.7 KiB
Rust
54 lines
1.7 KiB
Rust
// Copyright 2023 Greptime Team
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
use std::{fs, path};
|
|
|
|
use common_telemetry::info;
|
|
use mito2::access_layer::{ATOMIC_WRITE_DIR, OLD_ATOMIC_WRITE_DIR};
|
|
use object_store::services::Fs;
|
|
use object_store::util::join_dir;
|
|
use object_store::ObjectStore;
|
|
use snafu::prelude::*;
|
|
|
|
use crate::config::FileConfig;
|
|
use crate::error::{self, Result};
|
|
use crate::store;
|
|
|
|
/// A helper function to create a file system object store.
|
|
pub async fn new_fs_object_store(
|
|
data_home: &str,
|
|
_file_config: &FileConfig,
|
|
) -> Result<ObjectStore> {
|
|
fs::create_dir_all(path::Path::new(&data_home))
|
|
.context(error::CreateDirSnafu { dir: data_home })?;
|
|
info!("The file storage home is: {}", data_home);
|
|
|
|
let atomic_write_dir = join_dir(data_home, ATOMIC_WRITE_DIR);
|
|
store::clean_temp_dir(&atomic_write_dir)?;
|
|
|
|
// Compatible code. Remove this after a major release.
|
|
let old_atomic_temp_dir = join_dir(data_home, OLD_ATOMIC_WRITE_DIR);
|
|
store::clean_temp_dir(&old_atomic_temp_dir)?;
|
|
|
|
let builder = Fs::default()
|
|
.root(data_home)
|
|
.atomic_write_dir(&atomic_write_dir);
|
|
|
|
let object_store = ObjectStore::new(builder)
|
|
.context(error::InitBackendSnafu)?
|
|
.finish();
|
|
|
|
Ok(object_store)
|
|
}
|