一、简介
Google Glog 是一个C++语言的应用级日志记录框架,提供了 C++ 风格的流操作和各种助手宏。
二、下载
git clone https://github.com/google/glog.git
cd glog
./autogen.sh
./configure --prefix=path(install)
make
make install
三、glog用法
1、级别
enum SeverityLevel
{
INFO,
WARNING,
ERROR,
FATAL
};
2、日志输出:
LOG(INFO) <<"info test";//输出一个Info日志
LOG(WARNING) <<"warning test";//输出一个Warning日
LOG(ERROR) <<"error test";//输出一个Error日志
LOG(FATAL) <<"fatal test";//输出一个Fatal日志,这是最严重的日志并且输出之后会中止程序
3、条件输出
LOG_IF(INFO, num_cookies >10) <<"Got lots of cookies";//当条件满足时输出日志
LOG_EVERY_N(INFO,10) <<"Got the "<< google::COUNTER <<"th cookie";//google::COUNTER 记录该语句被执行次数,从1开始,在第一次运行输出日志之后,每隔 10 次再输出一次日志信息
LOG_IF_EVERY_N(INFO, (size >1024),10) <<"Got the "<< google::COUNTER <<"th big cookie";//上述两者的结合,不过要注意,是先每隔 10 次去判断条件是否满足,如果滞则输出日志;而不是当满足某条件的情况下,每隔 10 次输出一次日志信息。
LOG_FIRST_N(INFO,20) <<"Got the "<< google::COUNTER <<"th cookie";//当此语句执行的前 20 次都输出日志,然后不再输出
4、常用函数
google::SetLogDestination(google::GLOG_INFO,"log/prefix_");//设置特定严重级别的日志的输出目录和前缀。第一个参数为日志级别,第二个参数表示输出目录及日志文件名前缀。
google::SetLogFilenameExtension("logExtension");//在日志文件名中级别后添加一个扩展名。适用于所有严重级别。
google::SetStderrLogging(google::GLOG_INFO);//大于指定级别的日志都输出到标准输出
5、常用参数设置
FLAGS_logtostderr =true;//设置日志消息是否转到标准输出而不是日志文件
FLAGS_alsologtostderr =true;//设置日志消息除了日志文件之外是否去标准输出
FLAGS_colorlogtostderr =true;//设置记录到标准输出的颜色消息(如果终端支持)
FLAGS_log_prefix =true;//设置日志前缀是否应该添加到每行输出
FLAGS_logbufsecs =0;//设置可以缓冲日志的最大秒数,0指实时输出
FLAGS_max_log_size =10;//设置最大日志文件大小(以MB为单位)
FLAGS_stop_logging_if_full_disk =true;//设置是否在磁盘已满时避免日志记录到磁盘
三、例子
main.cpp
#include "gloghelper.h"
using namespace std;
int main()
{
GLogHelper loghelper;
loghelper.InitLogger();
LOG(ERROR)<<"log test";
return 0;
}
gloghelper.cpp
#include "gloghelper.h"
void CoreDumped(const char *data, int size)
{
std::string str = std::string(data,size);
LOG(ERROR)<<str;
}
GLogHelper::GLogHelper()
{
}
GLogHelper::~GLogHelper()
{
google::ShutdownGoogleLogging();
}
/**
* @brief:
* @param: const char *program --程序名称
* @param: uint32_t log_level --需要输出到日志等级包括:(INFO、WARNING、ERROR)
* @param: const char *log_dir --存放日志到目录
* @return: void
* @date:
* @autor:
*/
void GLogHelper::InitLogger(const char *program, const uint32_t log_level, const char* log_dir)
{
if(access(log_dir,F_OK))
{
mkdir(log_dir,S_IRWXU | S_IRWXG | S_IXOTH);
}
//初始化应用进程名
google::InitGoogleLogging(program);
char info_path[100];
char warning_path[100];
char error_path[100];
snprintf(info_path,sizeof(info_path),"%s%s",log_dir,"/INFO_");
snprintf(warning_path,sizeof(warning_path),"%s%s",log_dir,"/WARNING_");
snprintf(error_path,sizeof(error_path),"%s%s",log_dir,"/ERROR_");
//取消默认链接文件(链接文件为最新到日志输出)
google::SetLogSymlink(google::GLOG_INFO,"");
google::SetLogSymlink(google::GLOG_WARNING,"");
//google::SetLogSymlink(google::GLOG_ERROR,"");
//google::SetLogSymlink(google::GLOG_FATAL,"");
//将段错误详细信息输出到日志文件
google::InstallFailureSignalHandler();
google::InstallFailureWriter(CoreDumped);
//是否将日志输出到标准错误而不是日志文件
FLAGS_logtostderr = false;
//是否同时将日志发送到标准错误和日志文件中
FLAGS_alsologtostderr = false;
//当日志级别大于此级别时,自动将此日志输出到标准错误中
FLAGS_stderrthreshold = google::WARNING;
//当日志级别大于此级别时会马上输出,而不缓存
FLAGS_logbuflevel = google::ERROR;
//实时刷新日志到硬盘,默认是会缓存
FLAGS_logbufsecs = 0;
//日志大小大于30M时,创建新到日志
FLAGS_max_log_size = 30;
//当磁盘满时,停止输出日志文件
FLAGS_stop_logging_if_full_disk = true;
//如果未指定日志输出等级,glog不会输出日志
//设置错误级别大于等于多少时输出到文件
//参数2为日志存放到目录和日志文件前缀
if(log_level == google::GLOG_INFO)
{
google::SetLogDestination(google::INFO,info_path);
}
else if(log_level == google::GLOG_WARNING)
{
google::SetLogDestination(google::GLOG_WARNING,warning_path);
}
else if(log_level == google::GLOG_ERROR)
{
google::SetLogDestination(google::ERROR,error_path);
}
else
{
google::ShutdownGoogleLogging();
}
}
gloghelper.h
#ifndef GLOGHELPER_H
#define GLOGHELPER_H
#include<glog/logging.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<stdio.h>
#include<stdlib.h>
#include <iostream>
#include <string>
#include <sstream>
#include <cstdlib>
#include <time.h>
enum SeverityLevel
{
INFO,
WARNING,
ERROR,
FATAL
};
class GLogHelper
{
public:
GLogHelper();
~GLogHelper();
/**
* @brief:
* @param: const char *program --程序名称
* @param: uint32_t log_level --需要输出到日志等级包括:(INFO、WARNING、ERROR)
* @param: const char *log_dir --存放日志到目录
* @return: void
* @date:
* @autor:
*/
void InitLogger(const char* program="ARHUD", const uint32_t log_level = google::ERROR, const char* log_dir="log");
private:
};
#endif // GLOGHELPER_H
makefile
CXX = g++ #编译工具
SOURCES = *.cpp #资源文件
OBJECTS = $(SOURCES:.cpp=.o)#目标文件
TARGET = app #可执行文件
LIBS += -lglog -lpthread #glog库
$(TARGET):$(OBJECTS)
$(CXX) -o $(TARGET) $(OBJECTS) $(LIBS)
$(OBJECTS):$(SOURCES)
$(CXX) -c $(SOURCES) $(INCLUDE)
# 编译规则 $@代表目标文件 $< 代表第一个依赖文件
%.o:%.cpp
$(CXX) -o $@ -c $<
#清除编译过程中产生的文件
clean:
$(RM) $(OBJECTS) $(TARGET)