spdlog使用

spdlog库使用

https://zsyyblog.com/2772901e.html

为了让 spdlog 实现在程序运行时同时将日志实时打印到终端(控制台)和写入到文件中,你可以使用 多重接收器(multisink),即将日志输出到多个目标(例如控制台和文件)。spdlog 支持将日志发送到多个接收器,通过 spdlog::sinks::sink 实现。

具体步骤如下:

  1. 创建控制台和文件日志接收器
  2. 使用 spdlog::logger 组合多个接收器
  3. 设置日志等级和刷新策略,确保日志实时写入。

以下是一个完整的示例,演示如何实现同时将日志输出到终端和文件:

#include <spdlog/spdlog.h>
#include <spdlog/sinks/stdout_color_sinks.h>  // For colored console logs
#include <spdlog/sinks/basic_file_sink.h>     // For file logging
#include <memory>

int main() {
    try {
        // 创建控制台(终端)接收器
        auto console_sink = std::make_shared<spdlog::sinks::stdout_color_sink_mt>();
        console_sink->set_level(spdlog::level::info);  // 设置控制台日志等级
        console_sink->set_pattern("[%T] [%^%l%$] %v"); // 设置日志格式

        // 创建文件接收器
        auto file_sink = std::make_shared<spdlog::sinks::basic_file_sink_mt>("logs/logfile.log", true);
        file_sink->set_level(spdlog::level::debug);    // 设置文件日志等级
        file_sink->set_pattern("[%T] [%l] %v");        // 设置日志格式

        // 创建一个多重接收器的 logger
        std::vector<spdlog::sink_ptr> sinks {console_sink, file_sink};
        auto logger = std::make_shared<spdlog::logger>("multi_sink", sinks.begin(), sinks.end());

        // 设置全局 logger
        spdlog::set_default_logger(logger);

        // 设置全局日志等级为 debug,所有日志都会输出
        spdlog::set_level(spdlog::level::debug);

        // 开启日志刷新
        spdlog::flush_on(spdlog::level::info);

        // 示例日志
        spdlog::info("这是一个信息日志 (info)");
        spdlog::warn("这是一个警告日志 (warn)");
        spdlog::error("这是一个错误日志 (error)");
        spdlog::debug("这是一个调试日志 (debug)");

        // 手动刷新日志,确保写入到文件
        spdlog::flush_every(std::chrono::seconds(1));  // 每秒刷新日志

    } catch (const spdlog::spdlog_ex &ex) {
        std::cout << "日志初始化失败: " << ex.what() << std::endl;
        return 1;
    }

    return 0;
}

代码说明:

  1. 控制台接收器 (stdout_color_sink_mt)
    • 创建了一个彩色控制台接收器,用于将日志输出到终端,并设置日志等级为 info,即只显示 info 及以上的日志。
    • 使用 set_pattern() 设置日志的显示格式,这里 %T 代表时间,%^%l%$ 代表彩色等级,%v 代表日志消息内容。
  2. 文件接收器 (basic_file_sink_mt)
    • 创建了一个文件接收器,将日志写入 logs/logfile.log 文件中,并设置日志等级为 debug,即所有日志都会被记录。
    • 文件接收器的日志格式和控制台略有不同,没有彩色信息。
  3. 多重接收器的 Logger
    • 通过 std::vector<spdlog::sink_ptr> 将控制台和文件接收器组合在一起,传递给 spdlog::logger
    • 设置默认的 Logger,并确保所有日志同时输出到终端和文件。
  4. 日志刷新策略
    • spdlog::flush_on(spdlog::level::info) 设置日志刷新条件,当输出 info 及以上级别的日志时,日志会立即刷新到文件中。
    • spdlog::flush_every() 可以定时刷新日志,这里设置为每秒刷新一次,确保日志不会滞后于实际输出。

实现效果:

  • 日志将同时输出到终端并记录到文件 logs/logfile.log 中。
  • 控制台输出彩色日志,文件输出标准日志。
  • 日志实时刷新,确保信息及时写入文件。
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值