在并行环境中使用boost ::登录
Using boost::log in parallel environment
我用两个进程运行以下代码。在输出中,只有一个条目。我每次都会得到不同的排名。似乎每个过程覆盖文件。如何在不覆盖的情况下进行所有进程来记录消息?
预期结果(顺序可能不同(:
0
1
实际结果:
0 // and sometimes 1
代码:
#include <boost/log/trivial.hpp>
#include <boost/log/utility/setup/file.hpp>
#include <boost/mpi.hpp>
int main()
{
boost::mpi::environment env;
boost::mpi::communicator world;
boost::log::add_file_log("sample.log");
BOOST_LOG_TRIVIAL(info) << world.rank();
return 0;
}
Boost日志没有这种机制,但是您可以使用单独的过程来记录同一文件中的数据并在外部提供对此过程的访问。为了实现这种方法,您可以使用Boost插座或Syslog后端
除了建议的 arturx64 外,您还可以使用Interconcess queue sink在多个工作过程中发布日志记录。这些记录可以通过单独的接收器进程接收,然后可以将日志记录写入文件。这里有一个例子。
相关文章:
- 理解boost::asio-async_read在无需读取内容时的行为
- boost::进程间消息队列引发错误
- 如何运行位于boost/libs/python/example/tutorial目录中的hello.cpp和Jamfil
- cmake如何在fedora工作站中找到boost静态库包
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- Boost Graph Library,修复节点大小
- 什么是"#include <boost/functional/hash.hpp> "?
- 基于boost的程序的静态链接——zlib问题
- C++:如何在CLion IDE中安装Boost
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 如何在boost beast http请求中设置http头
- Boost Spirit,获取迭代器内部语义动作
- boost::asio::steady_timer()与sleep()我应该使用哪一个
- boost::asio如何生成多个协同程序,然后加入它们
- 当我尝试使用 sstream 和分面将 Boost Time_duration转换为字符串时,我没有得到所需的格式
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- 如何使用boost::具有嵌套结构和最小代码更改的序列化
- 在并行环境中使用boost ::登录
- 使用Homebrew的Boost::登录OSX El Capitan的链接错误
- Boost.Log:如何转发登录源