当前位置: 首页 > wzjs >正文

怎么做网站导航外链外包做网站不付尾款

怎么做网站导航外链,外包做网站不付尾款,wordpress会员多语言,中国航空集团建设开发有限公司网站在Rust程序中记录日志,可以使用fast_log。 根据fast_log 的介绍,这是一个性能非常高的日志实现,还支持文件追加模式、压缩、切分与回滚等操作。 而且,这个库记录日志是异步的,即不会因为日志而影响程序的运行。只有当…

在Rust程序中记录日志,可以使用fast_log

根据fast_log 的介绍,这是一个性能非常高的日志实现,还支持文件追加模式、压缩、切分与回滚等操作。

而且,这个库记录日志是异步的,即不会因为日志而影响程序的运行。只有当必要的时候,才需要应用层手动调用log::logger().flush()刷到文件。

引入

使用cargo管理的项目,只要通过cargo的add命令即可引入fast_log,当然还需要log

cargo add fast_log
cargo add log

初始化

使用的方法也非常简单,只要通过它的init()函数进行初始化,之后就可以使用日志记录相关的宏了。

init()的参数为一个fast_log::config::Config结构。

这个结构使用了Builder模式,它的new()函数只是调用了它的default()函数,生成了一个默认的结构,之后就可以调用Build的函数进行自定义。

如以下代码,构造了一个输出到终端的Config。

use fast_log::{self, config::Config};fn main() {let config = Config::new().console();fast_log::init(config).expect("init log error");info!("test log info !!!");
}

Config支持各种日志输出。

如:

  • console() 输出到终端
  • file() 输出到文件
  • file_loop() 输出到循环的文件
  • file_split() 输出到回滚文件
  • custom() 自定义输出

输出到回滚文件

输出到回滚文件的时候,file_split()的原型如下:

pub fn file_split<  R: CanRollingPack + 'static,  K: Keep + 'static,  P: Packer + Sync + 'static,  
>(  self,  file_path: &str,  rolling: R,  keeper: K,  packer: P,  
) -> Self

其中,file_path是文件路径,CanRollingKeepPacker分别是三个特性。一般地,我们可以使用fast_log中预定义的结构就好。

如以下代码,定义了一个按照文件大小回滚的输出,每个文件200M,保存5个:

file_split("target/logs/",Rolling::new(RollingType::BySize(LogSize::MB(200))),KeepType::KeepNum(5),LogPacker {},))

以下代码,定义了一个按照日期回滚的输出,保存30天:

file_split("target/logs/",Rolling::new(RollingType::ByDate(DateType::Day)),KeepType::KeepNum(30),LogPacker {},))

自定义输出

自定义输出的时候,使用custom()方法,注册一个实现了LogAppender特性的结构。

LogAppender特定的定义如下:

pub trait LogAppender:Send {  /// Batch write log, or do nothing  fn do_logs(&mut self, records: &[FastLogRecord]);  
}

可以看到,就是实现do_logs方法。其中,records是一个FastLogRecord的数组。

FastLogRecord结构的定义如下:

#[derive(Clone, Debug)]  
pub struct FastLogRecord {  pub command: Command,  pub level: log::Level,  pub target: String,  pub args: String,  pub module_path: String,  pub file: String,  pub line: Option<u32>,  pub now: SystemTime,  pub formated: String,  
}

其中,level是日志的等级,file和line分别是相应的源代码文件与行数,now是日志时间,formated是日志信息。

以下的自定义输出,按照不同的等级,打印了不同格式的信息到标准输出:

struct CustomLog {}impl LogAppender for CustomLog {fn do_logs(&mut self, records: &[FastLogRecord]) {for record in records {let now = DateTime::from(record.now);let data;match record.level {Level::Warn | Level::Error => {data = format!("{} {} {} - {}  {}\n",now, record.level, record.module_path, record.args, record.formated);}_ => {data = format!("{} {} {} - {}\n",&now, record.level, record.module_path, record.args);}}print!("{}", data);}}
}

日志等级

fast_log::config::Config结构的构造方法里有一个level(),可以设置日志等级,参数类型是LevelFilter。

LevelFilter是一个enum。

#[repr(usize)]
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Debug, Hash)]
pub enum LevelFilter {Error = 1,Warn,Info,Debug,Trace,
}

以下代码设置了日志等级为Info:

let config = Config::new().console().level(LogLevel::Info);

记录日志的宏log!,第一个参数就是日志等级。当等级高于设置的级别时,不会被记录。

以上代码设置了Info级,则只有Error、Warn、Info会被记录,Debug和Trace等级的日志都被抛弃了。

相对应的,有几个宏可以替代log!宏,分别是:error!warn!info!debug!trace!

如果使用log!宏,就需要在第一个参数中指定日志级别,其它几个宏是log!的简化版。

名字空间

需要注意的是,fast_log的名字空间有点儿复杂 。

比如,file_split一个函数,就需要use几行东西。

其中,Rolling相关的、日期类型(DateType)、保存类型(KeepType)在fast_log::plugin::file_split里,LogSize在fast_log::consts里,而LogPacker又在fast_log::plugin::packer里。

use fast_log::plugin::file_split::{Rolling, RollingType, DateType, KeepType};  
use fast_log::plugin::packer::LogPacker;  
use fast_log::consts::LogSize;

而记录日志的过滤等级,又直接使用的log模块里的定义,配置Config的时候,需要:

use fast_log::config::Config;
use log::LevelFilter;let config = Config::new().level(LevelFilter::Info);

文章转载自:

http://wQniZCkl.rddLz.cn
http://ytF2KRnW.rddLz.cn
http://jwH5bwFk.rddLz.cn
http://9g5du4Kf.rddLz.cn
http://Xc3VXYmB.rddLz.cn
http://HXh0XWxo.rddLz.cn
http://tyePX7Nk.rddLz.cn
http://nN0qfYwB.rddLz.cn
http://8LdfQXJK.rddLz.cn
http://acgyPzSU.rddLz.cn
http://4RQtfqkP.rddLz.cn
http://fGUm5KSJ.rddLz.cn
http://afiQRAHu.rddLz.cn
http://9dnGH3fu.rddLz.cn
http://uyI6vNzf.rddLz.cn
http://QwwUXzkh.rddLz.cn
http://zqyel56w.rddLz.cn
http://QrFZAHq5.rddLz.cn
http://Bpyt4VhV.rddLz.cn
http://cC4dpIEs.rddLz.cn
http://x4fdDlU4.rddLz.cn
http://Mxf3u1h3.rddLz.cn
http://Isbwg4G1.rddLz.cn
http://pFyMd8O5.rddLz.cn
http://Ys1r9aoS.rddLz.cn
http://xJV9rJYK.rddLz.cn
http://Kqg0LkkO.rddLz.cn
http://RUKu7z5P.rddLz.cn
http://pyk2FeWM.rddLz.cn
http://Jomq8NZV.rddLz.cn
http://www.dtcms.com/wzjs/745846.html

相关文章:

  • 做网站会员登陆开县网站建设
  • wordpress增加视频播放西安seo黑
  • 套模版做的网站好优化吗网站建设费用还是网络专业
  • jsp和html做的招聘网站做国外直播网站
  • 地名网站建设方案wordpress分享到微博才能看到
  • 外贸网站建设哪个好昆明做网站公司哪家好
  • 温州做网站建设多少钱html5旅游网站
  • [ 1500元做网站_验收满意再付款! ]_沛县网络公司彩票网站开发周期
  • 泰州网站建设托管做网站的好处和坏处
  • 办公用纸网站建设网站的时间对齐应该怎么做
  • 专业网站优化制作公司新手如何做服装网站
  • 在阿里国际站做的网站申请域名网站价格
  • 网站图片设置方法网站建设专家有哪些
  • php网站的优点大型网站设计
  • 做最漂亮的网站睢宁网站建设xzqjwl
  • 网站创建一般创建哪种类型企业网站的优化建议
  • 惠州网站制作定制网站漂浮广告效果
  • 网站建设图片素材库网站怎么做企业
  • 营销网站更受用户欢迎的原因是做调研用到的大数据网站
  • 虚拟服务器建网站做优化网站建设
  • 金融网站cms多媒体网页设计
  • 网站建设需要知道什么做服装广告素材网站有哪些
  • led 网站建设产品软文是什么
  • 学网站开发多久小程序商城模板免费
  • 网站建设的技术亮点网站建设专家cms
  • 汽车城网站建设方案上海做原创网站
  • 国内买机票最便宜网站建设产品网站开发计划表
  • 做网站多久学会有网站源代码 怎么样建设网站
  • 建设银行瓶窑支行网站小工厂如何找外贸公司合作
  • 库尔勒网站cn.wordpress.org