如何在spdlog日常记录器中更改默认滚动时间?

时间:2015-02-02 14:32:38

标签: c++ logging spdlog

使用spdlog,如何更改每日记录器的默认滚动时间?

在以下示例中,滚动仅在午夜发生:

auto logger = spd::daily_logger_st("my_logger", "fl_log.txt");

1 个答案:

答案 0 :(得分:4)

目前没有直接的方法来更改每日记录器中的轮换时间 - 请打开问题here ..

快速解决方法是修改_calc_midnight_tp()函数以在daily_file_sink类中返回所需的轮换时间而不是午夜..

例如,在凌晨1点而不是午夜轮换:

static std::chrono::system_clock::time_point _calc_midnight_tp()
{
    using namespace std::chrono;
    auto now = system_clock::now();
    time_t tnow = std::chrono::system_clock::to_time_t(now);
    tm date = spdlog::details::os::localtime(tnow);
    date.tm_min = date.tm_sec = 0;
    date.tm_hour = 1;
    auto rotate_time = std::chrono::system_clock::from_time_t(std::mktime(&date));
    return system_clock::time_point(rotate_time + hours(24));
}

修改:我committed修复了此问题。现在,用户可以设置所需滚动时间的HH:MM