Skip to content

Commit

Permalink
[omdb] Add a couple simple Sled Agent queries
Browse files Browse the repository at this point in the history
  • Loading branch information
smklein committed Sep 20, 2023
1 parent 69a5b18 commit 2a05568
Show file tree
Hide file tree
Showing 5 changed files with 117 additions and 2 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions omdb/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ omicron-common.workspace = true
pq-sys = "*"
serde.workspace = true
serde_json.workspace = true
sled-agent-client.workspace = true
slog.workspace = true
strum.workspace = true
tabled.workspace = true
Expand Down
6 changes: 5 additions & 1 deletion omdb/src/bin/omdb/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ use clap::Subcommand;

mod db;
mod nexus;
mod sled;

#[tokio::main]
async fn main() -> Result<(), anyhow::Error> {
Expand All @@ -35,8 +36,9 @@ async fn main() -> Result<(), anyhow::Error> {
.context("failed to create logger")?;

match args.command {
OmdbCommands::Nexus(nexus) => nexus.run_cmd(&log).await,
OmdbCommands::Db(db) => db.run_cmd(&log).await,
OmdbCommands::Nexus(nexus) => nexus.run_cmd(&log).await,
OmdbCommands::Sled(sled) => sled.run_cmd(&log).await,
}
}

Expand Down Expand Up @@ -67,6 +69,8 @@ enum OmdbCommands {
Db(db::DbArgs),
/// Debug a specific Nexus instance
Nexus(nexus::NexusArgs),
/// Debug a specific Sled
Sled(sled::SledArgs),
}

fn parse_dropshot_log_level(
Expand Down
2 changes: 1 addition & 1 deletion omdb/src/bin/omdb/nexus.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ impl NexusArgs {
&self,
log: &slog::Logger,
) -> Result<(), anyhow::Error> {
// This is a little goofy. The database URL is required, but can come
// This is a little goofy. The nexuus URL is required, but can come
// from the environment, in which case it won't be on the command line.
let Some(nexus_url) = &self.nexus_internal_url else {
bail!(
Expand Down
109 changes: 109 additions & 0 deletions omdb/src/bin/omdb/sled.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at https://mozilla.org/MPL/2.0/.

//! omdb commands that query or update specific Sleds
use anyhow::bail;
use anyhow::Context;
use clap::Args;
use clap::Subcommand;

/// Arguments to the "omdb sled" subcommand
#[derive(Debug, Args)]
pub struct SledArgs {
/// URL of the Sled internal API
#[clap(long, env("OMDB_SLED_URL"))]
sled_url: Option<String>,

#[command(subcommand)]
command: SledCommands,
}

/// Subcommands for the "omdb sled" subcommand
#[derive(Debug, Subcommand)]
enum SledCommands {
/// print information about zones
#[clap(subcommand)]
Zones(ZoneCommands),

/// print information about zpools
#[clap(subcommand)]
Zpools(ZpoolCommands),
}

#[derive(Debug, Subcommand)]
enum ZoneCommands {
/// Print list of all zones
List,
}

#[derive(Debug, Subcommand)]
enum ZpoolCommands {
/// Print list of all zpools
List,
}

impl SledArgs {
/// Run a `omdb sled` subcommand.
pub async fn run_cmd(
&self,
log: &slog::Logger,
) -> Result<(), anyhow::Error> {
// This is a little goofy. The sled URL is required, but can come
// from the environment, in which case it won't be on the command line.
let Some(sled_url) = &self.sled_url else {
bail!(
"sled URL must be specified with --sled-url or \
OMDB_SLED_URL"
);
};
let client = sled_agent_client::Client::new(sled_url, log.clone());

match &self.command {
SledCommands::Zones(ZoneCommands::List) => {
cmd_zones_list(&client).await
}
SledCommands::Zpools(ZpoolCommands::List) => {
cmd_zpools_list(&client).await
}
}
}
}

/// Runs `omdb sled zones list`
async fn cmd_zones_list(
client: &sled_agent_client::Client,
) -> Result<(), anyhow::Error> {
let response = client.zones_list().await.context("listing zones")?;
let zones = response.into_inner();
let zones: Vec<_> = zones.into_iter().collect();

println!("zones:");
if zones.is_empty() {
println!(" <none>");
}
for zone in &zones {
println!(" {:?}", zone);
}

Ok(())
}

/// Runs `omdb sled zpools list`
async fn cmd_zpools_list(
client: &sled_agent_client::Client,
) -> Result<(), anyhow::Error> {
let response = client.zpools_get().await.context("listing zpools")?;
let zpools = response.into_inner();

println!("zpools:");
if zpools.is_empty() {
println!(" <none>");
}
for zpool in &zpools {
println!(" {:?}", zpool);
}

Ok(())
}

0 comments on commit 2a05568

Please sign in to comment.