glog是google开发的c++环境的日志组件,具体信息请参考官网:https://code.google.com/p/google-glog/
下面备注下glog的安装和使用。
1 下载glog,下载地址为:https://code.google.com/p/google-glog/downloads/list,源文件就一个,版本为0.3.3。
2 解压,我这边是解压到/home/lclin/glog,执行./configure&make&make install,glog有些库是以动态库的形式存在,所以install时,会拷贝相应的库到系统目录下。
3 glog是以单列的形式存在的,初始化一次,即可在多个文件中使用,日志统一输出到初始化时指定的位置。
#include <glog/logging.h>
int initGlog(const char*cProgram, const char *logDir, uint32_t logLevel)
{
if (access(logDir, F_OK))//判断指定的logdir是否存在,如果不存在,创建相应的日志目录
{
std::cerr << "LogDir Not Exist,We Will Create!" << std::endl;
mkdir(logDir, S_IRWXU | S_IRWXG | S_IROTH | S_IXOTH);
std::cout << "LogDir Created,FilePath:" << logDir << ",Mode:"
<< (S_IRWXU | S_IRWXG | S_IROTH | S_IXOTH) << std::endl;
}
google::InitGoogleLogging(cProgram);//指定名称,进行初始化,通常去程序名称
char cInfoPath[100];
char cErrPath[100];
snprintf(cInfoPath, sizeof(cInfoPath), "%s%s", logDir, "/INFO_");
snprintf(cErrPath, sizeof(cErrPath), "%s%s", logDir, "/ERROR_");
FLAGS_logbufsecs = 0;//实时刷新日志到硬盘,默认是会缓冲的
FLAGS_max_log_size = 30;//日志大小大于30M时,创建新的日志
FLAGS_stop_logging_if_full_disk = true;
FLAGS_alsologtostderr = false;//关闭写日志到err。
//如果未指定日志输出路径,glog不会输出日志
if (logLevel == google::GLOG_INFO)
{
google::SetLogDestination(google::INFO, cInfoPath);//指定Info日志的路径
google::SetLogDestination(google::ERROR, cErrPath);//指定Error日志的路径
}
else if (logLevel == google::GLOG_ERROR)
{
google::SetLogDestination(google::ERROR, cErrPath);
}
else
{
glogClosed = true;
google::ShutdownGoogleLogging();
}
LOG(INFO)<<"INFO";//通过这种方式,输出INFO日志
LOG(ERROR)<<"ERROR";//通过这种方式,输出ERROR日志
return 0;
}
编译时,需要指定依赖的glog库。