fix: For dumping a db catalog, look up db location in server config first

Rather than requiring the user of this command to know the database UUID
or otherwise having the knowledge of how to construct a database object
store location in this debugging command.
pull/24376/head
Carol (Nichols || Goulding) 2021-10-27 14:07:59 -04:00 committed by Carol (Nichols || Goulding)
parent 4a225cf913
commit 09ad30cbfd
No known key found for this signature in database
GPG Key ID: E907EE5A736F87D4
1 changed files with 36 additions and 17 deletions

View File

@ -1,12 +1,10 @@
use data_types::DatabaseName; use crate::structopt_blocks::{object_store::ObjectStoreConfig, server_id::ServerIdConfig};
use iox_object_store::IoxObjectStore; use iox_object_store::IoxObjectStore;
use object_store::ObjectStore; use object_store::ObjectStore;
use snafu::{OptionExt, ResultExt, Snafu}; use snafu::{OptionExt, ResultExt, Snafu};
use std::{convert::TryFrom, sync::Arc}; use std::{convert::TryFrom, sync::Arc};
use structopt::StructOpt; use structopt::StructOpt;
use crate::structopt_blocks::{object_store::ObjectStoreConfig, server_id::ServerIdConfig};
#[derive(Debug, Snafu)] #[derive(Debug, Snafu)]
pub enum Error { pub enum Error {
#[snafu(display("Cannot parse object store config: {}", source))] #[snafu(display("Cannot parse object store config: {}", source))]
@ -17,11 +15,17 @@ pub enum Error {
#[snafu(display("No server ID provided"))] #[snafu(display("No server ID provided"))]
NoServerId, NoServerId,
#[snafu(display("Invalid database name: {}", source))] #[snafu(display("Can't read server config from object storage: {}", source))]
InvalidDbName { CantReadServerConfig { source: object_store::Error },
source: data_types::DatabaseNameError,
#[snafu(display("Error deserializing server config from protobuf: {}", source))]
CantDeserializeServerConfig {
source: generated_types::DecodeError,
}, },
#[snafu(display("Can't find a database with this name on this server"))]
CantFindDatabase,
#[snafu(display("Cannot open IOx object store: {}", source))] #[snafu(display("Cannot open IOx object store: {}", source))]
IoxObjectStoreFailure { IoxObjectStoreFailure {
source: iox_object_store::IoxObjectStoreError, source: iox_object_store::IoxObjectStoreError,
@ -56,10 +60,11 @@ pub struct Config {
#[derive(Debug, StructOpt)] #[derive(Debug, StructOpt)]
pub struct DumpOptions { pub struct DumpOptions {
/// Show debug output of `DecodedIoxParquetMetaData` if decoding succeeds, show the decoding error otherwise. /// Show debug output of `DecodedIoxParquetMetaData` if decoding succeeds, show the decoding
/// error otherwise.
/// ///
/// Since this contains the entire Apache Parquet metadata object this is quite verbose and is usually not /// Since this contains the entire Apache Parquet metadata object this is quite verbose and is
/// recommended. /// usually not recommended.
#[structopt(long = "--show-parquet-metadata")] #[structopt(long = "--show-parquet-metadata")]
show_parquet_metadata: bool, show_parquet_metadata: bool,
@ -78,11 +83,12 @@ pub struct DumpOptions {
#[structopt(long = "--show-statistics")] #[structopt(long = "--show-statistics")]
show_statistics: bool, show_statistics: bool,
/// Show unparsed `IoxParquetMetaData` -- which are Apache Thrift bytes -- as part of the transaction actions. /// Show unparsed `IoxParquetMetaData` -- which are Apache Thrift bytes -- as part of the
/// transaction actions.
/// ///
/// Since this binary data is usually quite hard to read, it is recommended to set this to `false` which will /// Since this binary data is usually quite hard to read, it is recommended to set this to
/// replace the actual bytes with `b"metadata omitted"`. Use the other toggles to instead show the content of the /// `false` which will replace the actual bytes with `b"metadata omitted"`. Use the other
/// Apache Thrift message. /// toggles to instead show the content of the Apache Thrift message.
#[structopt(long = "--show-unparsed-metadata")] #[structopt(long = "--show-unparsed-metadata")]
show_unparsed_metadata: bool, show_unparsed_metadata: bool,
} }
@ -101,12 +107,25 @@ impl From<DumpOptions> for parquet_catalog::dump::DumpOptions {
pub async fn command(config: Config) -> Result<()> { pub async fn command(config: Config) -> Result<()> {
let object_store = let object_store =
ObjectStore::try_from(&config.object_store_config).context(ObjectStoreParsing)?; Arc::new(ObjectStore::try_from(&config.object_store_config).context(ObjectStoreParsing)?);
let database_name = DatabaseName::try_from(config.db_name).context(InvalidDbName)?;
let server_id = config.server_id_config.server_id.context(NoServerId)?; let server_id = config.server_id_config.server_id.context(NoServerId)?;
let iox_object_store = IoxObjectStore::load(Arc::new(object_store), server_id, &database_name) let server_config_bytes = IoxObjectStore::get_server_config_file(&object_store, server_id)
.await .await
.context(IoxObjectStoreFailure)?; .context(CantReadServerConfig)?;
let server_config =
generated_types::server_config::decode_persisted_server_config(server_config_bytes)
.context(CantDeserializeServerConfig)?;
let database_location = server_config
.databases
.get(&config.db_name)
.context(CantFindDatabase)?;
let iox_object_store =
IoxObjectStore::load_at_root_path(Arc::clone(&object_store), server_id, database_location)
.await
.context(IoxObjectStoreFailure)?;
let mut writer = std::io::stdout(); let mut writer = std::io::stdout();
let options = config.dump_options.into(); let options = config.dump_options.into();