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

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

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

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

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

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


person Leo    schedule 07.12.2011    source источник


Ответы (2)


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

// 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 г., автор библиотеки объяснил, что добавление поддержки добавления было бы нетривиальным изменением, которое нельзя было бы внести в текущем дизайне.

person Rob Kennedy    schedule 07.12.2011
comment
Я использую backend-›scan_for_files(); в моей программе, но программа дала сбой при запуске этого кода. Любая идея об этом? - person cookwhy; 25.06.2013
comment
Ротация работает, но как насчет добавления? Программа должна добавляться к последнему журналу для каждого последующего запуска программы, пока файл журнала не достигнет пределов ротации. Этот код создает новый файл журнала при каждом запуске, и добавление scan_for_files не имеет никакого эффекта. - person ixe013; 19.01.2014

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