Подтвердить что ты не робот

Boost.Log - как настроить бэкэнд для потокового текста для добавления к повернутым файлам

У меня есть раковина sinks::text_file_backend. Скажем, у меня уже есть несколько файлов с проверенными журналами:

myLog001.log, myLog002.log и т.д.

Я хочу, чтобы раковина продолжала писать последний повернутый файл - myLog002.log, добавляйте его содержимое и продолжайте вращение оттуда.

Мне удалось найти keywords::open_mode = append, но это только добавляет поверх существующих файлов myLogX, делая их более крупными и, конечно же, очень трудными для чтения.

Можно ли это сделать в Boost.Log?

4b9b3361

Ответ 1

Эта функциональность встроена в текстовую раковину, а в документации приведен пример установки шаблона имени файла и правил для поворота на определенные размеры и время:

// The function registers file sink in the logging library
void init_logging()
{
    boost::shared_ptr< logging::core > core = logging::core::get();

    boost::shared_ptr< sinks::text_file_backend > backend =
        boost::make_shared< sinks::text_file_backend >(
            // file name pattern
            keywords::file_name = "file_%5N.log",
            // rotate the file upon reaching 5 MiB size...
            keywords::rotation_size = 5 * 1024 * 1024,
            // ...or at noon, whichever comes first
            keywords::time_based_rotation = sinks::file::rotation_at_time_point(12, 0, 0)
        );

    // Wrap it into the frontend and register in the core.
    // The backend requires synchronization in the frontend.
    typedef sinks::synchronous_sink< sinks::text_file_backend > sink_t;
    boost::shared_ptr< sink_t > sink(new sink_t(backend));

    core->add_sink(sink);
}

По-видимому, нет способа сделать библиотеку прикрепленной к существующим файлам с этой настройкой. Вы должны называть backend->scan_for_files(); до построения sink, как показано в заголовке "Управление вращающимися файлами" в документации, но это только предотвращает переписывание библиотеки предыдущими журналами до того, как они будут вызваны для очистки.

Когда эта тема возникла в списке рассылки разработки в феврале 2013 года, автор библиотеки объяснил, что добавление поддержки для добавления будет нетривиальным изменением, не может быть выполнено в соответствии с текущим проектом.

Ответ 2

Вы должны указать open_mode перед использованием текстового файла. По умолчанию Boost.Log будет использовать std:: ios_base:: trunc | std:: ios_base:: out как открытый режим, который, очевидно, обрезает старый файл журнала.

Вы можете создать экземпляр text_file_backend со следующими параметрами:

    {
        boost::shared_ptr<sinks::text_file_backend> backend =
            boost::make_shared<sinks::text_file_backend>(
                keywords::file_name = logger_file_path,
                keywords::open_mode = std::ios_base::app|std::ios_base::out,
                keywords::rotation_size = 5 * 1024 * 1024,
                keywords::time_based_rotation = sinks::file::rotation_at_time_point(12, 0, 0));
        // Wrap it into the frontend and register in the core.
        // The backend requires synchronization in the frontend.
        typedef sinks::synchronous_sink<sinks::text_file_backend> sink_t;
        boost::shared_ptr<sink_t> sink(new sink_t(backend));
        sink->set_formatter(logFmt);
        core->add_sink(sink);
    }