Middleware di Registrazione

La registrazione dei log svolge un ruolo cruciale nelle applicazioni web, poiché consente di:

  • Fornire informazioni dettagliate sul processo di gestione delle richieste per aiutare gli sviluppatori a monitorare il comportamento dell'applicazione
  • Assistere nella risoluzione dei problemi e nel debug, specialmente in ambienti di produzione
  • Monitorare le prestazioni dell'applicazione e l'utilizzo delle risorse
  • Registrare i modelli di accesso degli utenti e le eccezioni del sistema
  • Soddisfare i requisiti di audit di sicurezza e conformità

Salvo fornisce un middleware con funzionalità di registrazione di base. Se il middleware viene aggiunto direttamente a un Router, non catturerà gli errori 404 restituiti quando nessun Router corrisponde alla richiesta. Si consiglia invece di aggiungerlo al Service.

Codice di Esempio

main.rs
Cargo.toml
use salvo::logging::Logger;
use salvo::prelude::*;

#[handler]
async fn hello() -> &'static str {
    "Hello World"
}

#[handler]
async fn error() -> StatusError {
    StatusError::bad_request()
        .brief("Bad request error")
        .detail("The request was malformed.")
}

#[tokio::main]
async fn main() {
    tracing_subscriber::fmt().init();

    let router = Router::new()
        .get(hello)
        .push(Router::with_path("error").get(error));
    let service = Service::new(router).hoop(Logger::new());

    let acceptor = TcpListener::new("0.0.0.0:8698").bind().await;
    Server::new(acceptor).serve(service).await;
}