mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	return the on disk size actually used by meilisearch
This commit is contained in:
		| @@ -23,8 +23,13 @@ lazy_static! { | ||||
|     ) | ||||
|     .expect("Can't create a metric"); | ||||
|     pub static ref MEILISEARCH_DB_SIZE_BYTES: IntGauge = | ||||
|         register_int_gauge!(opts!("meilisearch_db_size_bytes", "Meilisearch Db Size In Bytes")) | ||||
|         register_int_gauge!(opts!("meilisearch_db_size_bytes", "Meilisearch DB Size In Bytes")) | ||||
|             .expect("Can't create a metric"); | ||||
|     pub static ref MEILISEARCH_USED_DB_SIZE_BYTES: IntGauge = register_int_gauge!(opts!( | ||||
|         "meilisearch_used_db_size_bytes", | ||||
|         "Meilisearch Used DB Size In Bytes" | ||||
|     )) | ||||
|     .expect("Can't create a metric"); | ||||
|     pub static ref MEILISEARCH_INDEX_COUNT: IntGauge = | ||||
|         register_int_gauge!(opts!("meilisearch_index_count", "Meilisearch Index Count")) | ||||
|             .expect("Can't create a metric"); | ||||
|   | ||||
| @@ -31,6 +31,7 @@ pub async fn get_metrics( | ||||
|     let response = create_all_stats((*index_scheduler).clone(), auth_controller, auth_filters)?; | ||||
|  | ||||
|     crate::metrics::MEILISEARCH_DB_SIZE_BYTES.set(response.database_size as i64); | ||||
|     crate::metrics::MEILISEARCH_USED_DB_SIZE_BYTES.set(response.used_database_size as i64); | ||||
|     crate::metrics::MEILISEARCH_INDEX_COUNT.set(response.indexes.len() as i64); | ||||
|  | ||||
|     for (index, value) in response.indexes.iter() { | ||||
|   | ||||
| @@ -231,6 +231,8 @@ pub async fn running() -> HttpResponse { | ||||
| #[serde(rename_all = "camelCase")] | ||||
| pub struct Stats { | ||||
|     pub database_size: u64, | ||||
|     #[serde(skip)] | ||||
|     pub used_database_size: u64, | ||||
|     #[serde(serialize_with = "time::serde::rfc3339::option::serialize")] | ||||
|     pub last_update: Option<OffsetDateTime>, | ||||
|     pub indexes: BTreeMap<String, indexes::IndexStats>, | ||||
| @@ -259,6 +261,7 @@ pub fn create_all_stats( | ||||
|     let mut last_task: Option<OffsetDateTime> = None; | ||||
|     let mut indexes = BTreeMap::new(); | ||||
|     let mut database_size = 0; | ||||
|     let mut used_database_size = 0; | ||||
|  | ||||
|     for index_uid in index_scheduler.index_names()? { | ||||
|         // Accumulate the size of all indexes, even unauthorized ones, so | ||||
| @@ -266,6 +269,7 @@ pub fn create_all_stats( | ||||
|         // See <https://github.com/meilisearch/meilisearch/pull/3541#discussion_r1126747643> for context. | ||||
|         let stats = index_scheduler.index_stats(&index_uid)?; | ||||
|         database_size += stats.inner_stats.database_size; | ||||
|         used_database_size += stats.inner_stats.used_database_size; | ||||
|  | ||||
|         if !filters.is_index_authorized(&index_uid) { | ||||
|             continue; | ||||
| @@ -278,10 +282,14 @@ pub fn create_all_stats( | ||||
|     } | ||||
|  | ||||
|     database_size += index_scheduler.size()?; | ||||
|     used_database_size += index_scheduler.used_size()?; | ||||
|     database_size += auth_controller.size()?; | ||||
|     database_size += index_scheduler.compute_update_file_size()?; | ||||
|     used_database_size += auth_controller.used_size()?; | ||||
|     let update_file_size = index_scheduler.compute_update_file_size()?; | ||||
|     database_size += update_file_size; | ||||
|     used_database_size += update_file_size; | ||||
|  | ||||
|     let stats = Stats { database_size, last_update: last_task, indexes }; | ||||
|     let stats = Stats { database_size, used_database_size, last_update: last_task, indexes }; | ||||
|     Ok(stats) | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user