Different boost log sinks for every class

走远了吗. 提交于 2019-12-22 09:51:02

问题


I am new to boost log.

My algorithm has 4 main steps and I want the logging for every step in one file. So that I have 4 sinks. My idea is that I can change the sink on every step. Is that possible?

At the moment I have my looger.h with a global logger

#ifndef LOGGER_H_
#define LOGGER_H_

#include <boost/shared_ptr.hpp>
#include <boost/make_shared.hpp>
#include <boost/thread/thread.hpp>
#include <boost/log/core.hpp>
#include <boost/log/sinks/sync_frontend.hpp>
#include <boost/log/sinks/text_ostream_backend.hpp>
#include <boost/log/sources/record_ostream.hpp>
#include <boost/log/support/date_time.hpp>
#include <boost/log/common.hpp>
#include <boost/log/expressions.hpp>
#include <boost/log/attributes.hpp>
#include <boost/log/sinks.hpp>
#include <boost/log/sources/logger.hpp>
#include <boost/log/utility/setup/common_attributes.hpp>
#include <boost/log/utility/setup/common_attributes.hpp>
#include <boost/log/utility/setup/formatter_parser.hpp>
#include <boost/log/sources/severity_logger.hpp>
#include <boost/log/sources/severity_feature.hpp>
#include <fstream>

namespace logging = boost::log;
namespace attrs = boost::log::attributes;
namespace src = boost::log::sources;
namespace sinks = boost::log::sinks;
namespace expr = boost::log::expressions;
namespace keywords = boost::log::keywords;

enum sign_severity_level {
  trace,
  debug,
  info,
  warning,
  error,
  fatal,
  report
};

void InitLog()
{
    typedef sinks::synchronous_sink<sinks::text_ostream_backend> TextSink;

    // init sink1
    boost::shared_ptr<sinks::text_ostream_backend> backend1 = boost::make_shared<sinks::text_ostream_backend>();
    backend1->add_stream(boost::shared_ptr<std::ostream>(new std::ofstream("sign.log")));
    backend1->auto_flush(true);
    boost::shared_ptr<TextSink> sink1(new TextSink(backend1));
    sink1->set_formatter(
            expr::format("[%1%]<%2%>(%3%): %4%") % expr::format_date_time < boost::posix_time::ptime
                    > ("TimeStamp", "%Y-%m-%d %H:%M:%S") % expr::attr < sign_severity_level > ("Severity") % expr::attr
                    < attrs::current_thread_id::value_type > ("ThreadID") % expr::smessage);
    sink1->set_filter(expr::attr < sign_severity_level > ("Severity") >= warning);
    logging::core::get()->add_sink(sink1);

    logging::add_common_attributes();
    logging::core::get()->add_global_attribute("ThreadID", attrs::current_thread_id());
}
BOOST_LOG_INLINE_GLOBAL_LOGGER_DEFAULT(my_logger, src::severity_logger_mt<sign_severity_level>)


#endif /* LOGGER_H_ */ 

Is it possible to change the sink after every step?


回答1:


You need to change only stream of a sink:

void set_log_file(const char* filename) {
  backend_->remove_stream(current_stream_);
  current_stream_.reset(new std::ofstream(filename));
  backend_->add_stream(current_stream_);
}

Usage:

manager.set_log_file("log_1.txt");
BOOST_LOG_SEV(log, error) << "This will go to log_1";
BOOST_LOG_SEV(log, error) << "And this one";

manager.set_log_file("log_2.txt");
BOOST_LOG_SEV(log, error) << "This will go to log_2";

manager.set_log_file("log_3.txt");
BOOST_LOG_SEV(log, error) << "This will go to log_3";

Result:

> cat log_1.txt
[...]<4>(0x00007fe742977780): This will go to log_1
[...]<4>(0x00007fe742977780): And this one
> cat log_2.txt
[...]<4>(0x00007fe742977780): This will go to log_2
> cat log_3.txt
[...]<4>(0x00007fe742977780): This will go to log_3
  • Full example: http://pastebin.com/e3qDQ8tT


来源:https://stackoverflow.com/questions/24037206/different-boost-log-sinks-for-every-class

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!