22

sinks::text_file_backend流しがあります。すでにいくつかのローテーションされたログファイルがあるとします。

myLog001.log、myLog002.logなど

シンクが最後にローテーションされたファイル(myLog002.log)に書き込みを続け、その内容に追加して、そこからローテーションを続行するようにします。

私はなんとか見つけることkeywords::open_mode = appendができましたが、これは既存のmyLogXファイルの上に追加されるだけであり、それらを大きくし、もちろん非常に読みにくくします。

これはBoost.Logで実行できますか?

4

2 に答える 2

14

この機能はテキストシンクに組み込まれており、ドキュメントには、ファイル名のパターンと特定のサイズと時間で回転するためのルールを設定する例が含まれています。

// 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月に開発メーリングリストで取り上げられたとき、ライブラリの作成者は、追加のサポートを追加することは、現在の設計では行うことができない重要な変更になると説明しました。

于 2011-12-07T18:29:08.183 に答える
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);
    }
于 2017-01-19T17:44:40.200 に答える