glog日志库,是谷歌开源的日志库。
由于前两天发生了一次生产事故,一个C++程序的日志里面记录了很多乱码以及其他模块中的数据,初步怀疑是内存管理异常造成的,最大的疑虑在于日志记录模块的多线程支持,原先的模块在单线程下没有任何问题,但是多线程下并没有经过稳定的压力测试,为了一了百了地解决,还是选用技术实例强劲的开源库吧,原先的库就留着开发测试小功能里面用用。
glog库,可以从github上下载。 https://github.com/google/glog
我的开发环境是windows10+vs2017,所以下载完成之后,解压缩,然后使用cmake-gui进行转换为vs2017的sln工程文件:
- 选择源代码为glog的目录,目标位置为glog目录下新建一个build-cmake,
- 在configure按钮点击,弹出窗口选择vs2017(这个都是默认会检测到电脑上的vs版本,如果要转换为64位的,则选择带有win64的,默认是32位,默认生成静态库)
- 点击generate,然后到build-cmake目录下就会生成vs2017的工程文件glog.sln,双击打开工程,分别在debug和release下编译,生成glogd.lib和glog.lib,这里我使用静态库。
现在glog的库文件已经有了,我同时编译了32位和64位两个版本。以及debug版本和release版本。
然后新建一个测试工程,我选用的是64位的工程,
- 添加glogd.lib和glog.lib以及build-cmake/glog下面的头文件到工程中去,添加glogd.lib和glog.lib,添加src/glog/log_severity.h。所有的添加操作都是拷贝。
- 在工程属性中,文件引入目录包含以上添加的文件目录,库引用目录也是如此。同时注意工程属性中C/C++->代码生成->运行库的参数,我选择的都是 “/MTd”,编译glog库工程和测试工程的这个选择要一致。
- 创建测试代码,需要在开头加上 GLOG_NO_ABBREVIATED_SEVERITIES和GOOGLE_GLOG_DLL_DECL,不然会报错。
- 然后就可以使用啦,可以参考如下我的测试代码,使用了两个线程同时写入,方便测试是否线程安全。可以参考我的github,
#pragma once #define GLOG_NO_ABBREVIATED_SEVERITIES #define GOOGLE_GLOG_DLL_DECL #include "logging.h" using namespace google; #ifdef _DEBUG #pragma comment(lib, "glogd.lib") #else #pragma comment(lib, "glog.lib") #endif // DEBUG void testGlog2() { char str[20] = "hello log!"; int i = 100000; while (i > 0) { // LOG(INFO) << str; LOG(INFO) << "2info 2test" << "2hello 2log!"; //输出一个Info日志 // LOG(WARNING) << "warning test"; //输出一个Warning日志 // LOG(ERROR) << "error test"; //输出一个Error日志 i--; } } void testGlog() { // Start google log system: FLAGS_log_dir = "E:\\logs"; google::InitGoogleLogging("loglog"); google::SetLogDestination(google::GLOG_INFO, "E:\\logs\\INFO_"); google::SetStderrLogging(google::GLOG_FATAL); google::SetLogFilenameExtension("log_"); FLAGS_colorlogtostderr = true; // Set log color FLAGS_logbufsecs = 0; // Set log output speed(s) FLAGS_max_log_size = 1024; // Set max log file size FLAGS_stop_logging_if_full_disk = true; // If disk is full thread *t = new thread(testGlog2); char str[20] = "hello log!"; int i = 100000; while (i > 0) { // LOG(INFO) << str; LOG(INFO) << "info test" << "hello log!"; //输出一个Info日志 // LOG(WARNING) << "warning test"; //输出一个Warning日志 // LOG(ERROR) << "error test"; //输出一个Error日志 i--; } t->join(); google::ShutdownGoogleLogging(); }