《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) 

 

附件是VS2010的工程,C++日志类,谷歌的东西,很好用,也很强大哦! glog简介 Google glog是一个基于程序级记录日志信息的c++库,编程使用方式与c++的stream操作类似,例: LOG(INFO) << "Found " << num_cookies << " cookies"; “LOG”宏为日志输出关键字,“INFO”为严重性程度。 主要支持功能: 1, 参数设置,以命令行参数的方式设置标志参数来控制日志记录行为; 2, 严重性分级,根据日志严重性分级记录日志; 3, 可有条件地记录日志信息; 4, 条件中止程序。丰富的条件判定宏,可预设程序终止条件; 5, 异常信号处理。程序异常情况,可自定义异常处理过程; 6, 支持debug功能。可只用于debug模式; 7, 自定义日志信息; 8, 线程安全日志记录方式; 9, 系统级日志记录; 10, google perror风格日志信息; 11, 精简日志字符串信息。 开源代码托管 开源代码地址:https://github.com/google/glog 其实官方开源代码已经有大量demo可以参考了,也提供了VS可以直接打开编译的项目。 如何使用 1:把glog文件夹拷贝到源代码目录 2:在工程设置中添加附加包含目录(glog\include;)和附加库目录(glog\lib;),在附件依赖项中添加对应lib文件,一一对应关系如下: MDd libglog32MDd.lib MD libglog32MD.lib MTd libglog32MTd.lib MT libglog32MT.lib 建议使用MDd和MD方式,带上对应的dll(在glog\bin目录,需要时拷贝到bin文件输出目录)可以避免使用MTd,MT引起的内存泄露是值得的。 #include #include using namespace std; //包含glog头文件,建议放在stdafx.h中 //#define GOOGLE_GLOG_DLL_DECL // 使用静态库的时候用这个,不过我测试静态库有内存泄露,所以不推荐使用静态库 #define GLOG_NO_ABBREVIATED_SEVERITIES #include "glog/logging.h" //获取当前程序的运行目录 string GetAppPathA() { char szExePath[MAX_PATH] = {0}; GetModuleFileNameA(NULL,szExePath,MAX_PATH); char *pstr = strrchr(szExePath,'\\'); memset(pstr+1,0,1); string strAppPath(szExePath); return strAppPath; } void main() { //glog初始化 google::InitGoogleLogging("重签程序"); string strLogPath = GetAppPathA().append("LogInfo\\"); CreateDirectoryA(strLogPath.c_str(),NULL); google::SetLogDestination(google::GLOG_INFO,strLogPath.c_str()); //功能测试 LOG(INFO)<<"log start...";//普通日志 LOG(WARNING)<<"Warning log";//警告日志 LOG(ERROR)<<"Error log";//错误日志 int i = 4; LOG_IF(INFO,i == 4)<<"Log if Test"; //以上就是我常用的几个日志函数了,当然还有很多更加强大的日志相关函数,大家如有有兴趣,可以参照官方给的示例使用, //开源代码地址:https://github.com/google/glog MessageBoxA(NULL,"Test Over",":)",MB_ICONINFORMATION); } 测试程序中,我使用的动态链接库方式。(Debug模式中代码生成为MDd,Release为MD)。lib是截止现在2015-11-04-21:35是最新的。采用VS2010编译,MTd,MT,MDd,MD方式编译在测试项目中都有提供。 博文地址: http://blog.csdn.net/sunflover454/article/details/49643625
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值