mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-05-25 09:03:59 +02:00
60 lines
1.8 KiB
Rust
60 lines
1.8 KiB
Rust
use std::path::Path;
|
|
|
|
use anyhow::Context;
|
|
use chrono::{DateTime, Utc};
|
|
use log::info;
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use crate::{index::Index, index_controller::{update_actor::UpdateStore, uuid_resolver::HeedUuidStore}, option::IndexerOpts};
|
|
|
|
#[derive(Serialize, Deserialize, Debug)]
|
|
pub struct MetadataV2 {
|
|
db_version: String,
|
|
index_db_size: u64,
|
|
update_db_size: u64,
|
|
dump_date: DateTime<Utc>,
|
|
}
|
|
|
|
impl MetadataV2 {
|
|
pub fn load_dump(
|
|
self,
|
|
src: impl AsRef<Path>,
|
|
dst: impl AsRef<Path>,
|
|
indexing_options: &IndexerOpts,
|
|
) -> anyhow::Result<()> {
|
|
info!(
|
|
"Loading dump from {}, dump database version: {}, dump version: V2",
|
|
self.dump_date, self.db_version
|
|
);
|
|
// get dir in which to load the db:
|
|
let dst_dir = dst
|
|
.as_ref()
|
|
.parent()
|
|
.with_context(|| format!("Invalid db path: {}", dst.as_ref().display()))?;
|
|
|
|
let tmp_dst = tempfile::tempdir_in(dst_dir)?;
|
|
|
|
info!("Loading index database.");
|
|
let uuid_resolver_path = dst.as_ref().join("uuid_resolver/");
|
|
std::fs::create_dir_all(&uuid_resolver_path)?;
|
|
HeedUuidStore::load_dump(src.as_ref(), tmp_dst.as_ref())?;
|
|
|
|
info!("Loading updates.");
|
|
UpdateStore::load_dump(&src, &tmp_dst.as_ref(), self.update_db_size)?;
|
|
|
|
info!("Loading indexes");
|
|
let indexes_path = src.as_ref().join("indexes");
|
|
let indexes = indexes_path.read_dir()?;
|
|
for index in indexes {
|
|
let index = index?;
|
|
Index::load_dump(&index.path(), &dst, self.index_db_size, indexing_options)?;
|
|
}
|
|
|
|
// Persist and atomically rename the db
|
|
let persisted_dump = tmp_dst.into_path();
|
|
std::fs::rename(&persisted_dump, &dst)?;
|
|
|
|
Ok(())
|
|
}
|
|
}
|