亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用Rust實現(xiàn)日志記錄功能

 更新時間:2024年04月02日 08:49:20   作者:二次元攻城獅  
這篇文章主要為大家詳細介紹了使用Rust實現(xiàn)日志記錄功能的相關(guān)知識,文中的示例代碼講解詳細,具有一定的借鑒價值,有需要的可以參考一下

log 日志庫標(biāo)準(zhǔn)

log 是 Rust 的日志門面庫,由官方積極維護可以放心使用。它是Rust的日志門面,相應(yīng)的日志 API 已成為事實上的標(biāo)準(zhǔn)被其它日志框架所使用,有了日志門面開發(fā)者可以很方便切換自己的日志框架。

簡單示例

創(chuàng)建一個名為 log_test 二進制項目:

cargo new log_test

執(zhí)行以下命令,引入 log 依賴:

cargo add log

修改 main.rs 的代碼如下:

use log::{info, warn,error,trace};

fn main() {
    // 記錄日志
    info!("This is an info message");
    warn!("This is a warning message");
    error!("This is an error message");
    trace!("This is an trace message");
}

運行上面的示例,實際上看不到任何輸出。因為 log 僅僅是日志門面庫,它并不具備完整的日志庫功能

使用方法

因為 log 僅僅是日志門面庫,對于庫和應(yīng)用的開發(fā)者來說使用方法是有區(qū)別的,這也是 log 包這么設(shè)計的優(yōu)勢所在。

庫的開發(fā)者

作為庫的開發(fā)者,你只要在庫中使用門面庫即可,將具體的日志庫交給用戶去選擇和綁定:

use log::{info, trace, warn};
pub fn deal_with_something() {
    // 開始處理

    // 記錄一些日志
    trace!("a trace log");
    info!("a info long: {}", "abc");
    warn!("a warning log: {}, retrying", err);

    // 結(jié)束處理
}

應(yīng)用開發(fā)者

如果是應(yīng)用開發(fā)者,就需要去選擇一個具體的日志庫了。

目前已經(jīng)有了不少日志庫實現(xiàn),官方在 github 上也推薦了一些 ,主要分為以下幾類:

  • 簡單的最小記錄器,如 env_logger 等
  • 復(fù)雜的可配置框架,如 log4rs 等
  • 其他設(shè)施的適配器,如 syslog、db_logger 等
  • 對于 WebAssembly 二進制文件:console_log
  • 對于動態(tài)庫:需要在日志上構(gòu)造一個 FFI 安全包裝器,以便在庫中進行初始化。
  • 實用程序,如 alterable_logger 等

log 還提供了 set_logger 函數(shù)用于設(shè)置日志庫,set_max_level 用于設(shè)置最大日志級別。但是選用的具體日志庫往往會提供更高級的 API,無需手動調(diào)用這兩個函數(shù)。

日志庫開發(fā)者

對于日志庫開發(fā)者而言,自然要實現(xiàn)自己的 Log 特征:

use log::{Record, Level, Metadata};
struct SimpleLogger;
impl log::Log for SimpleLogger {
    fn enabled(&self, metadata: &Metadata) -> bool {
        metadata.level() <= Level::Info
    }
    fn log(&self, record: &Record) {
        if self.enabled(record.metadata()) {
            println!("{} - {}", record.level(), record.args());
        }
    }
    fn flush(&self) {}
}

除此之外,還需要包裝下 set_logger 和 set_max_level:

use log::{SetLoggerError, LevelFilter};
static LOGGER: SimpleLogger = SimpleLogger;
pub fn init() -> Result<(), SetLoggerError> {
    log::set_logger(&LOGGER)
        .map(|()| log::set_max_level(LevelFilter::Info))
}

然后再main函數(shù)里面設(shè)置全局記錄器:

use log::{info, warn,error,trace};

fn main() {
    //設(shè)置日志
    init();
    // 記錄日志
    info!("This is an info message");
    warn!("This is a warning message");
    error!("This is an error message");
    trace!("This is an trace message");
}

運行后終端輸出如下,因為設(shè)置日志等級為Info,所以沒有輸出Trace等級日志:

INFO - This is an info message
WARN - This is a warning message
ERROR - This is an error message

使用 log4rs

log4rs 是一個高度可配置的日志框架,以 Java 的 Logback 和 log4j 庫為模型。

添加依賴

為項目添加 log4rs 依賴:

cargo add log4rs

配置文件

在項目根目錄下,創(chuàng)建一個 log4rs.yaml 配置文件,并添加以下內(nèi)容:

refresh_rate: 30 seconds

appenders:
  stdout:
    kind: console
    encoder:
      pattern: "{d(%Y-%m-%d %H:%M:%S.%f)} [{l}] {t} - {m}{n}"
  
  rolling_file:
    kind: rolling_file
    path: logs/test.log
    append: true 
    encoder:
      pattern: "{d(%Y-%m-%d %H:%M:%S.%f)} [{l}] {t} - {m}{n}"
    policy:
      kind: compound
      trigger:
        kind: size
        limit: 10 mb
      roller:        
        kind: fixed_window
        pattern: logs/test.{}.log
        base: 1
        count: 5
        
root:
  level: info 
  appenders:
    - stdout
    - rolling_file

上面配置文件設(shè)定日志輸出到控制臺、文件,文件按10 mb大小滾動,只保留最近五個文件。各個配置字段的具體含義可以參考配置

  • refresh_rate:用于確定 log4rs 掃描配置文件以查找更改的頻率,如果發(fā)現(xiàn)更改,記錄器將自動重新配置
  • appender: 負責(zé)將日志收集到文件、控制臺或系統(tǒng)日志, 可配置多個
  • stdout、rolling_file:追加器的唯一標(biāo)識字符串,自己隨便定義,它的 kind 字段只支持console、filerolling_file 三種實現(xiàn)
  • encoder: 負責(zé)將 log 信息轉(zhuǎn)換為合適的格式, 如固定格式的平文本或json
  • pattern:編碼模板,格式可配置,具體格式詳見pattern
  • policy:策略字段,策略必須具有 kind 字段,默認(且僅受支持)策略為 kind: compound
  • trigger:觸發(fā)器字段用于指示何時滾動日志文件,支持 size 和 time 兩種類型,這里使用的是按大小

運行項目

修改main.rs內(nèi)容如下:

use log::*;
use log4rs;

fn main() {
    log4rs::init_file("log4rs.yaml", Default::default()).unwrap();

    for i in 1..=1000 {
        info!("This is loop iteration {}", i);
    }
}

運行結(jié)果:

2024-04-01 15:43:28.596832500 [INFO] hello_world - This is loop iteration 1

到此這篇關(guān)于使用Rust實現(xiàn)日志記錄功能的文章就介紹到這了,更多相關(guān)Rust日志記錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Rust文件 launch.json作用大全

    Rust文件 launch.json作用大全

    launch.json 是 Visual Studio Code(VSCode)中的一個配置文件,主要用于配置調(diào)試器,本文給大家介紹Rust文件 launch.json 有什么用,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • 淺談Rust?+=?運算符與?MIR?應(yīng)用

    淺談Rust?+=?運算符與?MIR?應(yīng)用

    這篇文章主要介紹了Rust?+=?運算符與?MIR?應(yīng)用,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • Rust中的Struct使用示例詳解

    Rust中的Struct使用示例詳解

    這篇文章主要介紹了Rust中的Struct使用示例,代碼分為結(jié)構(gòu)體和實例化與訪問,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • rust 一個日志緩存記錄的通用實現(xiàn)方法

    rust 一個日志緩存記錄的通用實現(xiàn)方法

    本文給出了一個通用的設(shè)計模式,通過建造者模式實例化記錄對象,可自定義格式化器將實例化后的記錄對象寫入到指定的緩存對象中,這篇文章主要介紹了rust 一個日志緩存記錄的通用實現(xiàn)方法,需要的朋友可以參考下
    2024-04-04
  • Rust使用Sqlx連接Mysql的實現(xiàn)

    Rust使用Sqlx連接Mysql的實現(xiàn)

    數(shù)據(jù)庫在編程中是一個很重要的環(huán)節(jié),本文主要介紹了Rust使用Sqlx連接Mysql的實現(xiàn),記錄rust如何操作數(shù)據(jù)庫并以mysql為主的做簡單的使用說明,感興趣的可以了解一下
    2024-03-03
  • Rust語言之結(jié)構(gòu)體和枚舉的用途與高級功能詳解

    Rust語言之結(jié)構(gòu)體和枚舉的用途與高級功能詳解

    Rust 是一門注重安全性和性能的現(xiàn)代編程語言,其中結(jié)構(gòu)體和枚舉是其強大的數(shù)據(jù)類型之一,了解結(jié)構(gòu)體和枚舉的概念及其高級功能,將使你能夠更加靈活和高效地處理數(shù)據(jù),本文將深入探討 Rust 中的結(jié)構(gòu)體和枚舉,并介紹它們的用途和高級功能
    2023-10-10
  • Rust處理命令行參數(shù)

    Rust處理命令行參數(shù)

    在Rust中,命令行參數(shù)是程序從命令行接收的輸入,它們?yōu)槌绦蛱峁┝诉\行時配置和數(shù)據(jù)的靈活性,本文就來介紹一下Rust處理命令行參數(shù),具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • Rust在寫庫時實現(xiàn)緩存的操作方法

    Rust在寫庫時實現(xiàn)緩存的操作方法

    Moka是一個用于Rust的高性能緩存庫,它提供了多種類型的緩存數(shù)據(jù)結(jié)構(gòu),包括哈希表、LRU(最近最少使用)緩存和?支持TTL(生存時間)緩存,這篇文章給大家介紹Rust在寫庫時實現(xiàn)緩存的相關(guān)知識,感興趣的朋友一起看看吧
    2024-01-01
  • Rust個人學(xué)習(xí)小結(jié)之Rust的循環(huán)

    Rust個人學(xué)習(xí)小結(jié)之Rust的循環(huán)

    這篇文章主要介紹了Rust個人學(xué)習(xí)小結(jié)之Rust的循環(huán),今天主要了解了Rust語言的3種循環(huán)方法:?loop、while、for,本文結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • Rust的泛型、Traits與生命周期用法及說明

    Rust的泛型、Traits與生命周期用法及說明

    本文通過一個尋找列表中最大值的示例,展示了如何從重復(fù)代碼中提取函數(shù),再利用泛型實現(xiàn)代碼復(fù)用,主要步驟包括:識別重復(fù)邏輯;抽象提取;泛型應(yīng)用;進一步擴展,通過不斷抽象和泛化,我們不僅能減少代碼重復(fù),還能寫出更通用、健壯和可維護的代碼
    2025-02-02

最新評論