spdlog库使用
https://zsyyblog.com/2772901e.html
为了让 spdlog
实现在程序运行时同时将日志实时打印到终端(控制台)和写入到文件中,你可以使用 多重接收器(multisink),即将日志输出到多个目标(例如控制台和文件)。spdlog
支持将日志发送到多个接收器,通过 spdlog::sinks::sink
实现。
具体步骤如下:
- 创建控制台和文件日志接收器。
- 使用
spdlog::logger
组合多个接收器。 - 设置日志等级和刷新策略,确保日志实时写入。
以下是一个完整的示例,演示如何实现同时将日志输出到终端和文件:
#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;
}
代码说明:
- 控制台接收器 (
stdout_color_sink_mt
):- 创建了一个彩色控制台接收器,用于将日志输出到终端,并设置日志等级为
info
,即只显示info
及以上的日志。 - 使用
set_pattern()
设置日志的显示格式,这里%T
代表时间,%^%l%$
代表彩色等级,%v
代表日志消息内容。
- 创建了一个彩色控制台接收器,用于将日志输出到终端,并设置日志等级为
- 文件接收器 (
basic_file_sink_mt
):- 创建了一个文件接收器,将日志写入
logs/logfile.log
文件中,并设置日志等级为debug
,即所有日志都会被记录。 - 文件接收器的日志格式和控制台略有不同,没有彩色信息。
- 创建了一个文件接收器,将日志写入
- 多重接收器的 Logger:
- 通过
std::vector<spdlog::sink_ptr>
将控制台和文件接收器组合在一起,传递给spdlog::logger
。 - 设置默认的 Logger,并确保所有日志同时输出到终端和文件。
- 通过
- 日志刷新策略:
spdlog::flush_on(spdlog::level::info)
设置日志刷新条件,当输出info
及以上级别的日志时,日志会立即刷新到文件中。spdlog::flush_every()
可以定时刷新日志,这里设置为每秒刷新一次,确保日志不会滞后于实际输出。
实现效果:
- 日志将同时输出到终端并记录到文件
logs/logfile.log
中。 - 控制台输出彩色日志,文件输出标准日志。
- 日志实时刷新,确保信息及时写入文件。