easylogging++日志库使用手册
admin
2024-05-11 21:10:34
0

Easylogging++是通过源码文件来集成的跨平台日志库,使用起来非常方便,优点是使用方便,速度快,线程安全,可配置。EasyLogging++日志库只有两个文件,一个头文件一个代码文件拷贝到项目工程中就可以使用。

Easylogging++的项目地址如下所示:
https://github.com/amrayn/easyloggingpp
项目库只有两个文件分别为easylogging++.h和easylogging++.cc

配置Easylogging++

将库文件拷贝到项目中之后我们就可以使用easylogging++库了,在使用库之前我们需要对库进行配置,配置方式支持代码配置和配置文件配置下面分别介绍两种配置方法的使用。

代码配置

#include "easylogging++.h"
//初始化日志库
INITIALIZE_EASYLOGGINGPP
//通过定义宏启动线程安全配置
#define ELPP_THREAD_SAFE
static void ConfigEasyLogging()
{el::Configurations conf;// 启用日志conf.setGlobally(el::ConfigurationType::Enabled, "true");//设置日志文件目录以及文件名conf.setGlobally(el::ConfigurationType::Filename, "log\\log_%datetime{%Y%M%d %H%m%s}.log");//设置日志文件最大文件大小conf.setGlobally(el::ConfigurationType::MaxLogFileSize, "1920000");//是否写入文件conf.setGlobally(el::ConfigurationType::ToFile, "true");//是否输出控制台conf.setGlobally(el::ConfigurationType::ToStandardOutput, "true");//设置日志输出格式conf.setGlobally(el::ConfigurationType::Format, "[%datetime] [%loc] [%level] : %msg");//设置日志文件写入周期,每10条刷新到输出流中conf.setGlobally(el::ConfigurationType::LogFlushThreshold, "10");//加载配置el::Loggers::reconfigureAllLoggers(conf);
}

日志格式支持如下的配置:

%logger	        日志ID
%thread	        线程ID
%thread_name	线程名称
%level	        日志级别
%levshort	    日志级别 缩写显示
%vlevel	        详细日志级别
%datetime	    日志时间
%user	        当前用户
%host	        当前的主机名称
%file*	        输出日志的源码文件的名称
%fbase*	        不包含源码文件扩展名的文件名
%line*	        代码的行号
%func*	        函数名称
%loc*	        文件名称和行号
%msg	        日志消息
%	            转义特殊字符

时间格式

%d	日格式(01~31)
%a	周几英文简写(Mon, Tue, Wed, Thu, Fri, Sat, Sun)
%A	周几英文全拼(Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday)
%M	月份(01~12)
%b	月份简拼(Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec)
%B	月份全拼(January, February, March, April, May, June, July, August, September, October, November, December)
%y	两位的年份(13, 14 etc)
%Y	四位的年份(2013, 2014 etc)
%h	小时 (12-hour format)
%H	小时 (24-hour format)
%m	分钟 (zero-padded)
%s	秒钟 (zero-padded)
%F	AM/PM 设置

配置文件配置

除了使用代码来进行配置之外,我们还可以通过配置文件来进行配置,配置文件的格式如下所示:
config.conf

* GLOBAL:FORMAT                  =   "[%datetime] | [%level] | %msg"FILENAME                =   "log/log_%datetime{%Y%M%d}.log"ENABLED                 =   trueTO_FILE                 =   trueTO_STANDARD_OUTPUT      =   falseSUBSECOND_PRECISION     =   3PERFORMANCE_TRACKING    =   falseMAX_LOG_FILE_SIZE       =   209715200 ## Throw log files away after 2097152 2MB / 209715200 200MB / 4398046511104 1GBLOG_FLUSH_THRESHOLD     =   0
* INFO:FILENAME                =   "log/info_%datetime{%Y%M%d}.log"
* VERBOSE:FORMAT                  =   "[%datetime] | [%level-%vlevel] | %msg"
* WARNING:FILENAME                =   "log/warn_%datetime{%Y%M%d}.log"TO_STANDARD_OUTPUT      =   true
* ERROR:FILENAME                =   "log/error_%datetime{%Y%M%d}.log"TO_STANDARD_OUTPUT      =   true
* FATAL:FILENAME                =   "log/fatal_%datetime{%Y%M%d}.log"TO_STANDARD_OUTPUT      =   true
* DEBUG:FILENAME                =   "log/debug_%datetime{%Y%M%d}.log"
##    ENABLED                 =   false
* TRACE:
##    FILENAME                =   "log/trace_%datetime{%Y%M%d}.log"FORMAT                  =   "[%datetime] | [%level] %loc %func | %msg"
##    ENABLED                 =   false

配置文件放在对应的目录下,在使用的时候通过加载生效,加载方式如下

#include "easylogging++.h"
INITIALIZE_EASYLOGGINGPP
//通过定义宏启动线程安全配置
#define ELPP_THREAD_SAFE
int main(int argc, char *argv[])
{//加载配置文件并生效el::Configurations conf("config.conf");el::Loggers::reconfigureAllLoggers(conf);//致命错误不关闭程序el::Loggers::addFlag(el::LoggingFlag::DisableApplicationAbortOnFatalLog);
}

日志库的使用

加载完毕日志库之后,我们就可以使用对应的日志库了,日志库的使用方法示例如下所示:

#include "easylogging++.h"
INITIALIZE_EASYLOGGINGPP
#define ELPP_THREAD_SAFE
int main(int argc, char *argv[])
{//配置日志库el::Configurations conf("configlog.conf");el::Loggers::reconfigureAllLoggers(conf);el::Loggers::addFlag(el::LoggingFlag::DisableApplicationAbortOnFatalLog);//设置日志输出级别el::Loggers::setLoggingLevel(el::Level::Trace);//设置详细级别就是通过数字大小来区分日志级别el::Loggers::setVerboseLevel(9);int verboseLevel = el::Loggers::verboseLevel();LOG(INFO) << "Verbose Level = " << verboseLevel;LOG(INFO) << "this is info log";LOG(WARNING) << "this is waring log";LOG(ERROR) << "this is error log";LOG(FATAL) << "this is fatal log";LOG(DEBUG) << "this is debug log";LOG(TRACE) << "this is trace log";VLOG(0) << "this is level 0 log";VLOG(1) << "this is level 1 log";return a.exec();
}

相关内容

热门资讯

2025年我国农村网络零售额首... 央视新闻客户端消息(新闻联播):记者从商务部了解到,随着县域经济不断发展,农民收入持续增长,农村消费...
原创 春... 过年买黄金水太深! 888元买的“压岁金钞”,黄金可能只值50块。 春节临近,金钞、生肖钞摆满银行和...
过年惊艳全靠医美?丨“医”锤定... □全媒体记者 孙倩文 实习生 陈俐颖 春节临近,大家都盼着以精致状态奔赴节日相聚。不少人想通过医美快...
于东来宣布正式退休 执掌胖东来... 2月11日,胖东来商贸集团创始人于东来突然宣布:“农历新年后将正式退休、转为集团顾问,后续工作由胖东...
原创 金... 北方小年的这天,黄金价格突然闹腾起来,像是有人猛地拧了一下阀门,市场立马热闹了。伦敦金、沪金,还有国...
手握6吨黄金,却还不起2.5亿... 在黄金价格一路上行的背景下,珠宝行业本应是最容易吃到行情的赛道之一。但现实却给了市场一个反直觉的样本...
又一家城商行成立研究院,银行“... 每经记者|李玉雯 每经编辑|廖丹 从大行到中小银行,一场以研究能力为核心的竞赛正在银行业悄然展开。...
有基民浮亏60%!国投白银LO... 本文时代周报 作者:李茜楠、卢泳志 图虫创意 国投瑞银白银LOF基金事件持续发酵。 2月10日最新...
原创 暴... 就在不久前,2025年的海关数据一公布,立刻在国际金融圈引发了一场不小的地震:中国从俄罗斯进口的实物...
原创 C... 2026年2月9日,A股市场出现了一道奇观。 CPO概念板块午盘涨幅直接冲到了9.6%,接近涨停。 ...
原创 农... 鲁网2月11日讯近日,中国农业银行临沂开源支行大厅里迎来了一位特殊的顾客,一段特殊的服务故事正悄然温...
广州产投、工银投资、增城产投合... 天眼查APP显示,广州产投工融东进创新投资合伙企业(有限合伙)(以下简称“产投工融东进基金”)近日在...
原创 特... 美国在2025年12月启动关键矿产领域的新合作框架。那时,美国与几个国家代表共同签署一份声明,参与方...
网易CEO丁磊谈AI对游戏影响... 快科技2月12日消息,昨日,网易发布2025年Q4及全年财报,Q4营收275亿元,全年营收1126亿...
原创 3... 395:2!美国踩下金融核弹引信,中国去美元化进入读秒阶段 老铁们,2月9日这天,美国国会山那帮老爷...
国开行2025年发放超1.6万... 新华社北京2月11日电(记者张千千)记者2月11日从国家开发银行获悉,2025年,国开行发挥服务基础...
特斯拉副总裁等多名骨干离职、x... 当地时间2月9日,特斯拉副总裁拉吉·杰加纳坦在LinkedIn上宣布离职,结束了13年的特斯拉生涯。...
重庆A股34家上涨 国际复材、... 2月11日,79家重庆A股上市公司中有34家上涨,2家平收,下跌43家。 同花顺iFinD数据显示,...
央行:继续实施好适度宽松的货币... 中国人民银行2月10日发布《2025年第四季度中国货币政策执行报告》(下称《报告》)。对于下一阶段货...
原创 黄... 金价这轮过山车,表面是市场疯了,实质是体系在抖。黄金不是普通商品,它一旦“失控”,就等于有人在质疑美...