spdlog 日志库部分源码说明——让你可以自定义的指定自动切换日志时间

本文涉及的产品
图片翻译,图片翻译 100张
文档翻译,文档翻译 1千页
日志服务 SLS,月写入数据量 50GB 1个月
简介: spdlog 日志库部分源码说明——让你可以自定义的指定自动切换日志时间

前言

针对 网络上spdlog日志库目前存在的使用方式固定,不能发挥这个库本身应有价值的情况,这里对一些支持场景进行说明,以供初学者省去阅读源码的时间,直接上手使用

涉及源码

在说明过程中使用spdlog库自身提供的使用说明示例,进行介绍。

源码路径:spdlog-1.x/example/example.cpp

让日志文件可以每日定时切换 daily_logger_mt()

template<typename Factory = spdlog::synchronous_factory>
inline std::shared_ptr<logger> daily_logger_mt(const std::string &logger_name, const filename_t &filename, int hour = 0, int minute = 0,
    bool truncate = false, uint16_t max_files = 0, const file_event_handlers &event_handlers = {})
{
    return Factory::template create<sinks::daily_file_sink_mt>(logger_name, filename, hour, minute, truncate, max_files, event_handlers);
}

介绍:涉及文件:/usr/local/include/spdlog/sinks/daily_file_sink.h 这里是已经安装完成之后的路径。


接口介绍:

// 使用给定的工厂类创建一个每日日志记录器
// 如果没有提供工厂类,则默认为spdlog::synchronous_factory
template<typename Factory = spdlog::synchronous_factory>
inline std::shared_ptr<logger> daily_logger_mt(
    const std::string &logger_name,     // 日志记录器的名称
    const filename_t &filename,         // 每日日志文件的名称模式
    int hour = 0,                        // 每天轮换日志文件的时间(小时),默认为0
    int minute = 0,                      // 每天轮换日志文件的时间(分钟),默认为0
    bool truncate = false,               // 如果为true,当日志文件存在时,将其截断;否则,追加到现有文件,默认为false
    uint16_t max_files = 0,              // 保存的最大日志文件数量,默认为0(无限制)
    const file_event_handlers &event_handlers = {} // 文件事件处理器
)
{
    // 使用提供的工厂类创建一个每日日志记录器,并返回其共享指针
    return Factory::template create<sinks::daily_file_sink_mt>(logger_name, filename, hour, minute, truncate, max_files, event_handlers);
}

使用方式:

#include "spdlog/sinks/daily_file_sink.h"  // 如果以自己解决方案安装时使用
// #include <spdlog/sinks/daily_file_sink.h> // 如果以默认方式安装时使用
void daily_example()
{
    // Create a daily logger - a new file is created every day on 2:30am.
    auto daily_logger = spdlog::daily_logger_mt("daily_logger", "logs/daily.txt", 2, 30);
}

分享一个有趣的 学习链接:https://xxetb.xet.tech/s/HY8za



相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
2月前
|
消息中间件 运维 监控
智能运维,由你定义:SAE自定义日志与监控解决方案
通过引入 Sidecar 容器的技术,SAE 为用户提供了更强大的自定义日志与监控解决方案,帮助用户轻松实现日志采集、监控指标收集等功能。未来,SAE 将会支持 istio 多租场景,帮助用户更高效地部署和管理服务网格。
298 51
|
3月前
|
消息中间件 运维 监控
智能运维,由你定义:SAE自定义日志与监控解决方案
SAE(Serverless应用引擎)是阿里云推出的全托管PaaS平台,致力于简化微服务应用开发与管理。为满足用户对可观测性和运维能力的更高需求,SAE引入Sidecar容器技术,实现日志采集、监控指标收集等功能扩展,且无需修改主应用代码。通过共享资源模式和独立资源模式,SAE平衡了资源灵活性与隔离性。同时,提供全链路运维能力,确保应用稳定性。未来,SAE将持续优化,支持更多场景,助力用户高效用云。
186 2
|
3月前
|
JSON API Go
基于责任链与策略模式的轻量级PHP日志库设计
项目日志乱成一团,bug 时好时坏,服务器问题难以复现?我写了个 PHP 日志系统,第一时间发现问题,避免跑路。实现了责任链模式+策略模式,让日志存储更灵活,支持多种输出方式。
|
6月前
|
JSON 安全 API
.net 自定义日志类
在.NET中,创建自定义日志类有助于更好地管理日志信息。示例展示了如何创建、配置和使用日志记录功能,包括写入日志文件、设置日志级别、格式化消息等。注意事项涵盖时间戳、日志级别、JSON序列化、线程安全、日志格式、文件处理及示例使用。请根据需求调整代码。
91 13
|
7月前
|
JSON Java 数据库
SpringBoot项目使用AOP及自定义注解保存操作日志
SpringBoot项目使用AOP及自定义注解保存操作日志
126 1
|
10月前
|
前端开发 C语言 开发者
领导被我的花式console.log吸引了!直接写入公司公共库!
【8月更文挑战第23天】领导被我的花式console.log吸引了!直接写入公司公共库!
84 2
领导被我的花式console.log吸引了!直接写入公司公共库!
|
10月前
|
开发框架 .NET Docker
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
124 1
|
9月前
|
存储 运维 监控
超级好用的C++实用库之日志类
超级好用的C++实用库之日志类
112 0
|
9月前
|
Shell Python
salt自定义模块内使用日志例子
salt自定义模块内使用日志例子
|
10月前
|
Linux API
在Linux中,程序产生了库日志虽然删除了,但磁盘空间未更新是什么原因?
在Linux中,程序产生了库日志虽然删除了,但磁盘空间未更新是什么原因?

热门文章

最新文章