google 的一个 c++ 开源日志系统
安装
git clone https://github.com/google/glog.git
mkdir build && cd build
cmake -DGFLAGS_NAMESPACE=google -DCMAKE_CXX_FLAGS=-fPIC …
make && sudo make install
开启或关闭
1. 使用glog之前必须初始化:
google::InitGoogleLogging(argv[0]);
2. 结束glog时必须关闭库:
google::ShutdownGoogleLogging();
输出
1. 设置日志文件保存目录(目录必须存在)
方法1:必须在初始化库之前调用
FLAGS_log_dir = "/home/ubuntu/Desktop/log";
指定log文件在/home/ubuntu/Desktop/log目录下,此时不同级别的日志保存在不同文件中(应用名.日志保存路径.日志级别.年月日-时分秒)
方法2:(此方法会覆盖方法1)
google::SetLogDestination(google::INFO, "/home/ubuntu/Desktop/log/log_"); //INFO级别的日志目录
google::SetLogDestination(google::ERROR,"/home/ubuntu/Desktop/log/log_"); //ERROR级别的日志目录
google::SetLogDestination(google::WARNING,"/home/ubuntu/Desktop/log/log_");//WARNING级别的日志目录
指定log文件在/home/ubuntu/Desktop/log目录下,并且日志文件名以log_开头,可以指定不同级别的日志到一个文件中(前缀年月日-时分秒)
注意:
a. 当日志输出时才创建文件
b. 每运行一次应用都会重新创建一个日志文件(原来的文件不删除)
2. 输出到终端
google::SetStderrLogging(google::INFO); //大于INFO级别的都输出到标准输出的时候
3. 错误级别
enum SeverityLevel { google::INFO = 0, google::WARNING = 1, google::ERROR = 2, google::FATAL = 3, };
4. 日志输出
LOG(INFO) << "info test" << "hello world!"; //输出一个Info日志
LOG(WARNING) << "warning test"; //输出一个Warning日志
LOG(ERROR) << "error test"; //输出一个Error日志
LOG(FATAL) << "fatal test"; //输出一个Fatal日志,这是最严重的日志并且输出之后会中止程序
5. 条件输出
//当条件满足时输出日志
LOG_IF(INFO, 1 > 0) << "LOG_IF";
//每N次输出当前日志(输出1,1+N,1+2N ……的日志,其它的忽略)
LOG_EVERY_N(INFO, N) << google::COUNTER << " LOG_EVERY_N";
//条件满足并且每N次输出当前日志
LOG_IF_EVERY_N(INFO, (1 > 0), N) << google::COUNTER << " LOG_IF_EVERY_N";
//只输出前N条日志,后面的都不输出
LOG_FIRST_N(INFO, N) << google::COUNTER << " LOG_FIRST_N";
6. 参数设置
FLAGS_logtostderr = false; //设置日志消息是否转到标准输出而不是日志文件
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; //设置是否在磁盘已满时避免日志记录到磁盘
示例
#include <glog/logging.h>
int main(int argc, char *argv[])
{
FLAGS_logtostderr = false; //设置日志消息是否转到标准输出而不是日志文件
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; //设置是否在磁盘已满时避免日志记录到磁盘
//初始化
google::InitGoogleLogging(argv[0]);
//指定目录下
google::SetLogDestination(google::INFO, “/home/ubuntu/Desktop/log/log_”); //INFO级别的日志目录
google::SetLogDestination(google::ERROR,"/home/ubuntu/Desktop/log/log_"); //ERROR级别的日志目录
google::SetLogDestination(google::WARNING,"/home/ubuntu/Desktop/log/log_");//WARNING级别的日志目录
google::SetStderrLogging(google::INFO); //大于INFO级别的都输出到标准输出的时候
LOG(INFO) << “info test” << “hello world!”;//输出一个Info日志
LOG(WARNING) << “warning test”; //输出一个Warning日志
LOG(ERROR) << “error test”; //输出一个Error日志
//LOG(FATAL) << “fatal test”; //输出一个Fatal日志,这是最严重的日志并且输出之后会中止程序
for(int i=0; i< 10;i++){
//当条件满足时输出日志
LOG_IF(INFO, 1 > 0) << “LOG_IF”;
//每2次输出当前日志(输出1,3,5……的日志)
LOG_EVERY_N(INFO, 2) << google::COUNTER << " LOG_EVERY_N";
//条件满足并且每2次输出当前日志
LOG_IF_EVERY_N(INFO, (1 > 0), 2) << google::COUNTER << " LOG_IF_EVERY_N";
//只输出前两条日志,后面的都不输出
LOG_FIRST_N(INFO, 2) << google::COUNTER << " LOG_FIRST_N";
}
QApplication a(argc, argv);
MainWindow w;
w.show();
google::ShutdownGoogleLogging(); //关闭
return a.exec();
}