日誌中介軟體

日誌記錄在Web應用程式中扮演著至關重要的角色,它能夠:

  • 提供請求處理過程的詳細資訊,幫助開發者追蹤應用行為
  • 輔助問題排查與除錯,尤其在生產環境中
  • 監控應用效能和資源使用情況
  • 記錄使用者存取模式和系統異常
  • 滿足安全稽核和合規性要求

Salvo提供具備基礎日誌功能的中介軟體。若直接將中介軟體新增至 Router,將無法擷取所有 Router 皆不匹配時返回的404錯誤,建議新增至 Service 上。

範例程式碼

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;
}