glog单行 30000 字节限制问题

起因

偶然打印了一个超长的单行日志,发现glog进行了截断,后续的没有打印.

排查

排查后,发现是在源码里写死的.

可以在logging.cc 源文件里找到这个变量 kMaxLogMessageLen

cpp 复制代码
// An arbitrary limit on the length of a single log message.  This
// is so that streaming can be done more efficiently.
const size_t LogMessage::kMaxLogMessageLen = 30000;

struct LogMessage::LogMessageData  {
  LogMessageData();

  int preserved_errno_;      // preserved errno
  // Buffer space; contains complete message text.
  char message_text_[LogMessage::kMaxLogMessageLen+1];

const 的哦

解决

1.方案1: 修改代码后重新编译.

当然,可以解决问题,但是吧,有以下问题.

  • 多长算够呢 ?
  • 而且还要重新编译,现在用的动态库的话,还要替换库.

2.方案2: 自定义一个多次输出的处理函数

大概是这个意思,就是自己分成多条进行输出.

当然,还有更好的实现方式,暂时这样就行,只是一个处理思路.

cpp 复制代码
string log_str;//超长的日志
constexpr int kMaxChunkSize = google::LogMessage::kMaxLogMessageLen - 100;
const size_t len = log_str.length();
const size_t total = (len + kMaxChunkSize - 1) / kMaxChunkSize;  // 向上取整

for (size_t i = 0, pack = 1; i < len; i += kMaxChunkSize, ++pack) {
    LOG(INFO) << "[" << pack << "/" << total << "] " << std::string_view(log_str.data() + i, std::min<size_t>(kMaxChunkSize, len - i));
    // 标准低于C++17的话,考虑下substr
    //LOG(INFO) << "[" << pack_i << "/" << total_packets << "]"  << log_str.substr(i, max_length) << std::endl;
}

应该还有更好的处理方式,暂时不想深入这个库的原理.

其它具体形式优化上,推荐 宏定义形式的函数.

但是,最好别搞成普通调用函数,不然,输出的行号和实际日志位置就不一样了.

相关推荐
clint4561 天前
C++进阶(1)——前景提要
c++
夜悊2 天前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴2 天前
CMake 021: IF 条件判据详诠
c++·cmake
_wyt0012 天前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp
玖玥拾2 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
один but you2 天前
constexpr函数
c++
凡人叶枫2 天前
Effective C++ 条款41:了解隐式接口和编译期多态
java·开发语言·c++·effective c++
凡人叶枫2 天前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++
小胖xiaopangss2 天前
BRpc使用
c++·rpc
-森屿安年-2 天前
63. 不同路径 II
c++·算法·动态规划