Skip to content

Commit

Permalink
feat(gateway): add more tracing events
Browse files Browse the repository at this point in the history
  • Loading branch information
akrantz01 committed Dec 6, 2022
1 parent 7f677bf commit f4b47cd
Show file tree
Hide file tree
Showing 3 changed files with 40 additions and 15 deletions.
11 changes: 10 additions & 1 deletion gateway/src/api/latest.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ use shuttle_common::models::error::ErrorKind;
use shuttle_common::models::{project, user};
use tokio::sync::mpsc::Sender;
use tower_http::trace::TraceLayer;
use tracing::{debug, debug_span, field, Span};
use tracing::{debug, debug_span, field, instrument, Span};

use crate::acme::{AcmeClient, CustomDomain};
use crate::auth::{Admin, ScopedUser, User};
Expand Down Expand Up @@ -65,6 +65,7 @@ impl StatusResponse {
}
}

#[instrument(skip_all, fields(%account_name))]
async fn get_user(
State(RouterState { service, .. }): State<RouterState>,
Path(account_name): Path<AccountName>,
Expand All @@ -75,6 +76,7 @@ async fn get_user(
Ok(AxumJson(user.into()))
}

#[instrument(skip_all, fields(%account_name))]
async fn post_user(
State(RouterState { service, .. }): State<RouterState>,
Path(account_name): Path<AccountName>,
Expand All @@ -85,6 +87,7 @@ async fn post_user(
Ok(AxumJson(user.into()))
}

#[instrument(skip(service))]
async fn get_project(
State(RouterState { service, .. }): State<RouterState>,
ScopedUser { scope, .. }: ScopedUser,
Expand All @@ -98,6 +101,7 @@ async fn get_project(
Ok(AxumJson(response))
}

#[instrument(skip_all, fields(%project))]
async fn post_project(
State(RouterState { service, sender }): State<RouterState>,
User { name, .. }: User,
Expand All @@ -121,6 +125,7 @@ async fn post_project(
Ok(AxumJson(response))
}

#[instrument(skip_all, fields(%project))]
async fn delete_project(
State(RouterState { service, sender }): State<RouterState>,
ScopedUser { scope: project, .. }: ScopedUser,
Expand Down Expand Up @@ -149,6 +154,7 @@ async fn delete_project(
Ok(AxumJson(response))
}

#[instrument(skip_all, fields(scope = %scoped_user.scope))]
async fn route_project(
State(RouterState { service, .. }): State<RouterState>,
scoped_user: ScopedUser,
Expand Down Expand Up @@ -176,6 +182,7 @@ async fn get_status(State(RouterState { sender, .. }): State<RouterState>) -> Re
.unwrap()
}

#[instrument(skip_all)]
async fn revive_projects(
_: Admin,
State(RouterState { service, sender }): State<RouterState>,
Expand All @@ -185,6 +192,7 @@ async fn revive_projects(
.map_err(|_| Error::from_kind(ErrorKind::Internal))
}

#[instrument(skip_all, fields(%email, ?acme_server))]
async fn create_acme_account(
_: Admin,
Extension(acme_client): Extension<AcmeClient>,
Expand All @@ -196,6 +204,7 @@ async fn create_acme_account(
Ok(AxumJson(res))
}

#[instrument(skip_all, fields(%project_name, %fqdn))]
async fn request_acme_certificate(
_: Admin,
State(RouterState { service, sender }): State<RouterState>,
Expand Down
32 changes: 19 additions & 13 deletions gateway/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ use std::io::{self, Cursor};
use std::path::{Path, PathBuf};
use std::sync::Arc;
use std::time::Duration;
use tracing::{debug, error, info, info_span, trace, warn};
use tracing::{debug, error, info, info_span, trace, warn, Instrument};
use tracing_subscriber::{fmt, prelude::*, EnvFilter};

#[tokio::main(flavor = "multi_thread")]
Expand Down Expand Up @@ -122,20 +122,26 @@ async fn start(db: SqlitePool, fs: PathBuf, args: StartArgs) -> io::Result<()> {
"running health checks",
healthcheck.num_projects = projects.len()
);
let _ = span.enter();
for (project_name, _) in projects {
if let Ok(handle) = gateway
.new_task()
.project(project_name)
.and_then(task::check_health())
.send(&sender)
.await
{
// we wait for the check to be done before
// queuing up the next one
handle.await

let gateway = gateway.clone();
let sender = sender.clone();
async move {
for (project_name, _) in projects {
if let Ok(handle) = gateway
.new_task()
.project(project_name)
.and_then(task::check_health())
.send(&sender)
.await
{
// we wait for the check to be done before
// queuing up the next one
handle.await
}
}
}
.instrument(span)
.await;
}
}
}
Expand Down
12 changes: 11 additions & 1 deletion gateway/src/project.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ use once_cell::sync::Lazy;
use rand::distributions::{Alphanumeric, DistString};
use serde::{Deserialize, Serialize};
use tokio::time::{self, timeout};
use tracing::{debug, error};
use tracing::{debug, error, instrument};

use crate::{
ContainerSettings, DockerContext, EndState, Error, ErrorKind, IntoTryState, ProjectName,
Expand Down Expand Up @@ -276,6 +276,7 @@ where
type Next = Self;
type Error = Infallible;

#[instrument(skip_all, fields(state = %self.state()))]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
let previous = self.clone();
let previous_state = previous.state();
Expand Down Expand Up @@ -557,6 +558,7 @@ where
type Next = ProjectStarting;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
let container_name = self.container_name(ctx);
let container = ctx
Expand Down Expand Up @@ -593,6 +595,7 @@ where
type Next = ProjectStarted;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
let container_id = self.container.id.as_ref().unwrap();
ctx.docker()
Expand Down Expand Up @@ -642,6 +645,7 @@ where
type Next = ProjectReadying;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
time::sleep(Duration::from_secs(1)).await;

Expand Down Expand Up @@ -688,6 +692,7 @@ where
type Next = Self;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(mut self, _ctx: &Ctx) -> Result<Self::Next, Self::Error> {
Ok(self)
}
Expand Down Expand Up @@ -781,6 +786,7 @@ where

type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
let Self { container } = self;
ctx.docker()
Expand Down Expand Up @@ -808,6 +814,7 @@ where
type Next = ProjectStarting;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
let container = self.container;

Expand Down Expand Up @@ -860,6 +867,7 @@ where
type Next = ProjectDestroyed;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, ctx: &Ctx) -> Result<Self::Next, Self::Error> {
let container_id = self.container.id.as_ref().unwrap();
ctx.docker()
Expand Down Expand Up @@ -895,6 +903,7 @@ where
type Next = ProjectDestroyed;
type Error = ProjectError;

#[instrument(skip_all)]
async fn next(self, _ctx: &Ctx) -> Result<Self::Next, Self::Error> {
Ok(self)
}
Expand Down Expand Up @@ -980,6 +989,7 @@ where
type Next = Self;
type Error = Infallible;

#[instrument(skip_all)]
async fn next(self, _ctx: &Ctx) -> Result<Self::Next, Self::Error> {
Ok(self)
}
Expand Down

0 comments on commit f4b47cd

Please sign in to comment.