《Linux C++项目必备》glog日志管理

一、简介

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) 

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值