Logging-Middleware
Die Protokollierung spielt eine entscheidende Rolle in Webanwendungen, da sie folgende Funktionen bietet:
- Bereitstellung detaillierter Informationen zum Anfrageverarbeitungsprozess, um Entwicklern bei der Nachverfolgung des Anwendungsverhaltens zu helfen
- Unterstützung bei der Problembehebung und Fehlersuche, insbesondere in Produktionsumgebungen
- Überwachung der Anwendungsleistung und Ressourcennutzung
- Aufzeichnung von Benutzerzugriffsmustern und Systemausnahmen
- Erfüllung von Sicherheitsaudit- und Compliance-Anforderungen
Salvo bietet eine grundlegende Middleware für Logging-Funktionen. Wenn die Middleware direkt zum Router
hinzugefügt wird, kann sie keine 404-Fehler erfassen, die zurückgegeben werden, wenn keine Übereinstimmung mit dem Router
gefunden wird. Es wird empfohlen, sie stattdessen zum Service
hinzuzufügen.
Beispielcode
logging/src/main.rs
use salvo::logging::Logger;
use salvo::prelude::*;
#[handler]
async fn hello() -> &'static str {
"Hello World"
}
#[tokio::main]
async fn main() {
tracing_subscriber::fmt().init();
let router = Router::new().get(hello);
let service = Service::new(router).hoop(Logger::new());
let acceptor = TcpListener::new("0.0.0.0:5800").bind().await;
Server::new(acceptor).serve(service).await;
}