http://www.cnblogs.com/tianyajuanke/archive/2013/02/22/2921850.html
上述连接可以领进门
接下来还有一些需要注意
glog的典型用法
LOG(INFO) << "Found " << num_cookies << " cookies"; 是线程安全的,宏展开后会等价于新建一个LogMessage对象,然后就是c++ stream的输出,LogMessage实现里面会用锁保证写log那一步是多线程安全的, 另外还有RAW log 的那个头文件里面宏,说是可以写log的过程中都不会发生内存分配(不会依赖外部的其他锁),可以非常非常安全的,甚至在malloc函数里面使用。
http://gmd20.blog.163.com/blog/static/168439232015022112242552/
glog功能强大自然不必多说,C++下的iostream对象在格式很多的情况下使用非常不方便。cout<< xxx << “str1″ << yyyy <<“str2″…想着就头疼。由于项目中一直用glog来大日志,所以就开始思考如何用glog打印格式化的日志,glog里面有raw_logging.h的文件支持RAW_LOG(serverty,format_string, var1, var2 …),但细细的看了注释和实际体验之后存在一些问题(itlogs straight and ONLY to STDERR w/o buffering):只支持打印到stderr,由于server程序通常都是守护进程形式运行,终端标准输出和标准错误的描述符都是被关闭了的,使用这个宏就根本打不出日志。于是乎就封装了一层新packString的小接口。
使用的时候,形如:LOG(INOF)<< pack_string(“xxx”, int1, “yyy”, str2 …..)
http://ju.outofmemory.cn/entry/144616
另外可以修改输出格式:
在src/logging.cc中的init中修改mmdd=>yyyy/mm/dd,basename_=> filename相对日志输出文件夹的路径的函数调用所在之处