tklog是rust高性能结构化日志库,支持同步日志,异步日志,支持自定义日志的输出格式,支持按时间,按文件大小分割日志文件,支持日志文件压缩备份,支持官方日志库标准API,支持mod独立参数设置,支持日志level独立参数设置
set_console_body_fmt
可以设置日志内容在控制台的显示格式,与 set_body_fmt
类似,不同的是 set_body_fmt
对控制台信息与文件信息均有效。示例:
fn testlog2() {
LOG.set_console(true).set_cutmode_by_size("028test2.log", 1 << 20, 0, false).set_level(LEVEL::Trace).set_attr_format(|fmt| {
fmt.set_console_body_fmt(|level, body| {
//处理body的末尾换行符
let trimmed_body = if body.ends_with('
') { format!("{}{}", body.as_str()[..body.len() - 1].to_string(), "[0m
") } else { format!("{}{}", body, "[0m
") };
match level {
LEVEL::Trace => format!("{}{}", "[34m", trimmed_body), //蓝色
LEVEL::Debug => format!("{}{}", "[36m", trimmed_body), //青色
LEVEL::Info => format!("{}{}", "[32m", trimmed_body), //绿色
LEVEL::Warn => format!("{}{}", "[33m", trimmed_body), //黄色
LEVEL::Error => format!("{}{}", "[31m", trimmed_body), //红色
LEVEL::Fatal => format!("{}{}", "[41m", trimmed_body), //背景红
LEVEL::Off => "".to_string(),
}
});
fmt.set_body_fmt(|level, body| {
//处理body的末尾换行符
let trimmed_body = if body.ends_with('
') { format!("{}{}", body.as_str()[..body.len() - 1].to_string(), "[0m
") } else { format!("{}{}", body, "[0m
") };
match level {
LEVEL::Trace => format!("{}{}", "[44m", trimmed_body), //背景蓝色
LEVEL::Debug => format!("{}{}", "[46m", trimmed_body), //背景青色
LEVEL::Info => format!("{}{}", "[42m", trimmed_body), //背景绿色
LEVEL::Warn => format!("{}{}", "[43m", trimmed_body), //背景黄色
LEVEL::Error => format!("{}{}", "[41m", trimmed_body), //背景红色
LEVEL::Fatal => format!("{}{}", "[45m", trimmed_body), //背景紫色
LEVEL::Off => "".to_string(),
}
});
});
trace!("trace!", "this is sync log");
debug!("debug!", "this is sync log");
info!("info!", "this is sync log");
warn!("warn!", "this is sync log");
error!("error!", "this is sync log");
fatal!("fata!", "this is sync log");
thread::sleep(Duration::from_secs(1))
}
说明:示例对控制台日志进行独立设置
可以看到,当 调用 set_console_body_fmt
设置控制台日志时,控制台与文件将分别输出设置的日志格式。
方法一:使用 cargo add
命令
cargo add tklog
方法二:手动编辑 Cargo.toml
tklog = "0.2.8"
测试用例
use tklog::{trace,debug, error, fatal, info,warn}
fn testlog() {
trace!("trace>>>>", "aaaaaaaaa", 1, 2, 3, 4);
debug!("debug>>>>", "bbbbbbbbb", 1, 2, 3, 5);
info!("info>>>>", "ccccccccc", 1, 2, 3, 5);
warn!("warn>>>>", "dddddddddd", 1, 2, 3, 6);
error!("error>>>>", "eeeeeeee", 1, 2, 3, 7);
fatal!("fatal>>>>", "ffffffff", 1, 2, 3, 8);
}
Tklog 有极高的性能,特别是在linux环境中,具体测试参考文章
在linux环境中,tklog比同类型的日志库性能高10倍以上,在windows环境中,性能则为同类型日志库2倍左右
详细使用方法请参考 readme.md