使用Rust實(shí)現(xiàn)日志記錄功能
log 日志庫標(biāo)準(zhǔn)
log 是 Rust 的日志門面庫,由官方積極維護(hù)可以放心使用。它是Rust的日志門面,相應(yīng)的日志 API 已成為事實(shí)上的標(biāo)準(zhǔn)被其它日志框架所使用,有了日志門面開發(fā)者可以很方便切換自己的日志框架。
簡(jiǎn)單示例
創(chuàng)建一個(gè)名為 log_test 二進(jìn)制項(xiàng)目:
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"); }
運(yùn)行上面的示例,實(shí)際上看不到任何輸出。因?yàn)?nbsp;log 僅僅是日志門面庫,它并不具備完整的日志庫功能!
使用方法
因?yàn)?log 僅僅是日志門面庫,對(duì)于庫和應(yīng)用的開發(fā)者來說使用方法是有區(qū)別的,這也是 log 包這么設(shè)計(jì)的優(yōu)勢(shì)所在。
庫的開發(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ā)者,就需要去選擇一個(gè)具體的日志庫了。
目前已經(jīng)有了不少日志庫實(shí)現(xiàn),官方在 github 上也推薦了一些 ,主要分為以下幾類:
- 簡(jiǎn)單的最小記錄器,如 env_logger 等
- 復(fù)雜的可配置框架,如 log4rs 等
- 其他設(shè)施的適配器,如 syslog、db_logger 等
- 對(duì)于 WebAssembly 二進(jìn)制文件:console_log
- 對(duì)于動(dòng)態(tài)庫:需要在日志上構(gòu)造一個(gè) FFI 安全包裝器,以便在庫中進(jìn)行初始化。
- 實(shí)用程序,如 alterable_logger 等
log 還提供了 set_logger 函數(shù)用于設(shè)置日志庫,set_max_level 用于設(shè)置最大日志級(jí)別。但是選用的具體日志庫往往會(huì)提供更高級(jí)的 API,無需手動(dòng)調(diào)用這兩個(gè)函數(shù)。
日志庫開發(fā)者
對(duì)于日志庫開發(fā)者而言,自然要實(shí)現(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"); }
運(yùn)行后終端輸出如下,因?yàn)樵O(shè)置日志等級(jí)為Info,所以沒有輸出Trace等級(jí)日志:
INFO - This is an info message
WARN - This is a warning message
ERROR - This is an error message
使用 log4rs
log4rs 是一個(gè)高度可配置的日志框架,以 Java 的 Logback 和 log4j 庫為模型。
添加依賴
為項(xiàng)目添加 log4rs 依賴:
cargo add log4rs
配置文件
在項(xiàng)目根目錄下,創(chuàng)建一個(gè) 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è)定日志輸出到控制臺(tái)、文件,文件按10 mb大小滾動(dòng),只保留最近五個(gè)文件。各個(gè)配置字段的具體含義可以參考配置:
- refresh_rate:用于確定 log4rs 掃描配置文件以查找更改的頻率,如果發(fā)現(xiàn)更改,記錄器將自動(dòng)重新配置
- appender: 負(fù)責(zé)將日志收集到文件、控制臺(tái)或系統(tǒng)日志, 可配置多個(gè)
- stdout、rolling_file:追加器的唯一標(biāo)識(shí)字符串,自己隨便定義,它的 kind 字段只支持console、file、rolling_file 三種實(shí)現(xiàn)
- encoder: 負(fù)責(zé)將 log 信息轉(zhuǎn)換為合適的格式, 如固定格式的平文本或json
- pattern:編碼模板,格式可配置,具體格式詳見pattern
- policy:策略字段,策略必須具有 kind 字段,默認(rèn)(且僅受支持)策略為 kind: compound
- trigger:觸發(fā)器字段用于指示何時(shí)滾動(dòng)日志文件,支持 size 和 time 兩種類型,這里使用的是按大小
運(yùn)行項(xiàng)目
修改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); } }
運(yùn)行結(jié)果:
2024-04-01 15:43:28.596832500 [INFO] hello_world - This is loop iteration 1
到此這篇關(guān)于使用Rust實(shí)現(xiàn)日志記錄功能的文章就介紹到這了,更多相關(guān)Rust日志記錄內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談Rust?+=?運(yùn)算符與?MIR?應(yīng)用
這篇文章主要介紹了Rust?+=?運(yùn)算符與?MIR?應(yīng)用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01rust 一個(gè)日志緩存記錄的通用實(shí)現(xiàn)方法
本文給出了一個(gè)通用的設(shè)計(jì)模式,通過建造者模式實(shí)例化記錄對(duì)象,可自定義格式化器將實(shí)例化后的記錄對(duì)象寫入到指定的緩存對(duì)象中,這篇文章主要介紹了rust 一個(gè)日志緩存記錄的通用實(shí)現(xiàn)方法,需要的朋友可以參考下2024-04-04Rust使用Sqlx連接Mysql的實(shí)現(xiàn)
數(shù)據(jù)庫在編程中是一個(gè)很重要的環(huán)節(jié),本文主要介紹了Rust使用Sqlx連接Mysql的實(shí)現(xiàn),記錄rust如何操作數(shù)據(jù)庫并以mysql為主的做簡(jiǎn)單的使用說明,感興趣的可以了解一下2024-03-03Rust語言之結(jié)構(gòu)體和枚舉的用途與高級(jí)功能詳解
Rust 是一門注重安全性和性能的現(xiàn)代編程語言,其中結(jié)構(gòu)體和枚舉是其強(qiáng)大的數(shù)據(jù)類型之一,了解結(jié)構(gòu)體和枚舉的概念及其高級(jí)功能,將使你能夠更加靈活和高效地處理數(shù)據(jù),本文將深入探討 Rust 中的結(jié)構(gòu)體和枚舉,并介紹它們的用途和高級(jí)功能2023-10-10Rust在寫庫時(shí)實(shí)現(xiàn)緩存的操作方法
Moka是一個(gè)用于Rust的高性能緩存庫,它提供了多種類型的緩存數(shù)據(jù)結(jié)構(gòu),包括哈希表、LRU(最近最少使用)緩存和?支持TTL(生存時(shí)間)緩存,這篇文章給大家介紹Rust在寫庫時(shí)實(shí)現(xiàn)緩存的相關(guān)知識(shí),感興趣的朋友一起看看吧2024-01-01Rust個(gè)人學(xué)習(xí)小結(jié)之Rust的循環(huán)
這篇文章主要介紹了Rust個(gè)人學(xué)習(xí)小結(jié)之Rust的循環(huán),今天主要了解了Rust語言的3種循環(huán)方法:?loop、while、for,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01