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;
}

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

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

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

相关推荐
楼田莉子3 分钟前
C++20新特性:Range库
开发语言·c++·后端·学习·c++20
字节高级特工4 分钟前
【Linux】深入理解C语言命令行参数与环境变量
linux·c++·人工智能·后端
linux开发之路8 分钟前
C++项目推荐:eBPF+调度器性能分析框架
linux·c++·ebpf·火焰图·调度器
愿天垂怜14 分钟前
【C++脚手架】ffmpeg 库的介绍与使用
linux·服务器·开发语言·c++·ide·git·ffmpeg
并不喜欢吃鱼15 分钟前
从零开始 C++-----十一【C++ 数据结构】红黑树全解析:从定义到工程实现(一文搞定,十分详细)
开发语言·数据结构·c++
不会C语言的男孩17 分钟前
C++ Primer Plus 第7章:函数——C++的编程模块
开发语言·c++
kebeiovo22 分钟前
C++与 Lua的交互
c++·lua
John_ToDebug1 小时前
Chromium Settings 自启动开关:三种 pref 同步方案深度对比
c++·chrome·ai
还在点灯@1 小时前
基于visual studio的MFC上位机实现界面切换
c++·visualstudio·mfc
视图猿人1 小时前
ROS2 JAZZY+Gazebo harmonic小车机器人建模、激光雷达使用、图像传感器使用、构建导航地图、SLAM自动导航仿真
c++·机器人