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();
}

相关内容

热门资讯

海南自贸港“样板间”抢抓开放机... 中新网海口5月16日电 (记者 王子谦)洋浦经济开发区是海南自贸港“样板间”,也是外界观察自贸港建设...
净利增速2.98%,违规频发!... 近期,中信银行2025年年报与2026年一季报接连公布,报告显示,中信银行总资产站稳10万亿元台阶,...
原创 放... 全网的人几乎都在挤破头往海外大都市扎,可有一个女博主,却偏偏反着来。她拥有五百多万粉丝,本可以继续在...
原创 在... 在中国,买卖虚拟货币,到底行不行? 这个问题,很多人心里都犯嘀咕。有人说,法无禁止即可为;也有人说,...
龙粤慈善事业高质量发展与互联网... 近日,为加快培育数字慈善新生态,助力“善行边疆”活动走深走实,“龙粤慈善事业高质量发展与互联网公开募...
黄金大局已定:不出意外的话,2... 在投资领域,贵金属一直是备受关注的资产类别,尤其是黄金,其价格走势和投资价值牵动着无数投资者的心。随...
后巴菲特时代,伯克希尔哈撒韦新... 【导读】伯克希尔哈撒韦最新持仓公布!清仓亚马逊,建仓达美航空 中国基金报记者 张舟 伯克希尔哈撒韦“...
布朗46分胡金秋20+8 广厦... 【搜狐体育战报】北京时间5月16日CBA季后赛,主场作战的浙江浙商证券以111-102击败深圳马可波...
美联储任命鲍威尔担任临时主席 美国联邦储备委员会理事会5月15日发布公告,任命杰罗姆·鲍威尔担任美联储临时主席,直至凯文·沃什宣誓...
李从悠:白癜风患者,夏季防汗疹... 夏季高温多雨,白癜风患者皮肤屏障受损,出汗后汗液无法及时蒸发,易堵塞毛孔,诱发汗疹(热疹),汗疹引发...
最低涨价60元!4款非标茅台酒... 在飞天茅台涨价之后,部分非标茅台酒也提了价。 5月16日早间,贵州茅台自营渠道i茅台发布公告,宣布对...
邯郸10亿共享智造基金落地,撬... 图片为AI生成 据天眼查App显示,近日邯郸市共享智造股权投资基金(有限合伙)正式登记成立,总出资额...
AI制药行业深度:行业概况、市... 一、AI制药行业概况 1、AI药物研发概述 AI制药是指将NLP、深度神经网络,生成模型等AI技...
世界杯在即:国产彩电的出海故事... 球还没看,彩电先破防了 撰文/ 孟会缘 编辑/ 陈邓新 排版/ Annalee 国产彩电品牌,正深陷...
医疗健康领域投融资日报(5月1... 据亿欧数据统计,昨日(2026年5月15日)共披露16起投融资事件,涉及15家国内企业,1家国外企业...
深圳中创商业咨询携手海旗控股集... 海旗控股集团旗下宁波锦曼程新材料有限公司,自创立以来始终深耕高分子材料领域,秉承推动行业创新与可持续...
原创 关... 前言 大家好,我是老金。 国际地缘博弈的棋盘上,从来没有绝对的秘密,只有刻意或无意的战略试探,近期...
原创 欧... 今天来给大家聊一下最近的欧盟,自从特朗普说要来访华,欧洲的动作有点让人看不懂。从四月中旬到五月初,欧...
心系投资者 携手共行动 ——人... 为落实监管工作要求,切实维护金融消费者合法权益,在 “5・15 全国投资者保护宣传日” 当天,人保寿...
黄仁勋打卡蜜雪冰城 同款产品销... 财联社5月16日讯(记者 沈娇娇)5月15日上午,英伟达CEO黄仁勋现身北京南锣鼓巷,并且进入一家蜜...