ubuntu 下使用glog管理日志

文章目录

安装

  • 更新包列表,安装glog
ssh 复制代码
sudo apt-get update
sudo apt-get install libgoogle-glog-dev

配置

  • 采用cmakelist的话,直接在target_link_libraries中加入glog即可,无需多做处理。

使用

cpp 复制代码
#include "glog/logging.h"

void initGlog(const char *arg)
{
    auto ErrorCallback = [](const char *data, int size)
    {    std::string ss(data, size - 1);
    LOG(ERROR) << ss; };
    google::InitGoogleLogging(arg);               // 函数来初始化glog
    google::InstallFailureSignalHandler();        // 当程序遇到如SIGSEGV(段错误)这样的致命信号时,glog会打印出当前的堆栈跟踪。
    google::InstallFailureWriter(ErrorCallback);  // 当程序失败时,ErrorCallback 将被调用,从而记录错误信息。
    FLAGS_alsologtostderr = true;                 // 除了将日志信息写入文件之外,还会将日志信息输出到标准错误(stderr)。
    FLAGS_colorlogtostderr = true;                // 让输出到标准错误的日志信息带有颜色,便于区分不同的日志级别。
    FLAGS_logbuflevel = google::INFO;             // 日志缓冲区中的日志级别至少为INFO,低于INFO级别的日志将被立即输出,而INFO及以上级别的日志可能会被缓冲。
    mkdir("./logs", S_IRWXU | S_IRWXG | S_IRWXO); // 使用 mkdir 系统调用创建一个名为 logs 的目录,用于存放日志文件
    FLAGS_log_dir = "./logs";                     // 设置 FLAGS_log_dir 标志,指定日志文件的存放目录为 ./logs
}

int main(int argc, char* argv[])
{
  initGlog(argv[0]);
  // 输出日志
  LOG(INFO) << "This is an info message";
  LOG(WARNING) << "This is a warning message";
  LOG(ERROR) << "This is an error message";
  google::ShutdownGoogleLogging();
  return 0;
}
相关推荐
❀搜不到几秒前
ubuntu 更新cmake
linux·运维·ubuntu
Mr_pyx1 分钟前
TypeScript 完全入门指南:从基础到项目配置
linux·运维·ubuntu
来恩10032 分钟前
jQuery对Ajax的支持
前端·ajax·jquery
KaMeidebaby5 分钟前
卡梅德生物技术快报|抗体的制备与纯化:分子实验实操:番茄 sHSP 重组表达与抗体的制备与纯化工艺
前端·数据库·人工智能·其他·算法·百度·新浪微博
IT_陈寒7 分钟前
Vite热更新把我整不会了,原来还要这样配!
前端·人工智能·后端
恋猫de小郭7 分钟前
AI 时代,谷歌都在 Android 官方做了哪些支持?
android·前端·flutter
zzqssliu16 分钟前
跨境独立站多端适配开发:多语言+多货币+跨平台同步技术实战
前端·javascript·php
Chengbei1117 分钟前
AI赋能Chrome MCP × JS逆向Skill自动化JS逆向助力挖洞与绕过实战(小白也能学会)
javascript·人工智能·chrome·网络安全·自动化·系统安全·安全架构
怕浪猫20 分钟前
Electron 开发实战(五):文件系统与本地数据持久化全解
前端·javascript·electron
云水一下42 分钟前
HTML5 从入门到精通:语义为王——结构标签让网页会“说话”
前端·html5