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

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

myLog001.log, myLog002.log и т. Д.

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

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

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

Ответы [ 2 ]

14 голосов
/ 07 декабря 2011

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

// 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 голосов
/ 19 января 2017

Вы должны указать 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);
    }
...