将手工系统移植到 libcaf

Port handcraft systems to libcaf

我目前有一个使用手工制作演员的应用程序。我的计划是将它移植到 libcaf。

当前状态是: 我有一个大的全局消息队列,我的系统(又名演员)订阅以获取他们的消息。他们向该全局队列响应消息。

整个系统是一个运行在Linux rt-preempt内核上的实时应用程序。 GUI 线程本身就是一个系统(参与者),但它不具有 RT 优先级。

现在我的系统不需要知道他们消息的接收者,因为接收者会注册他们想要的消息。

我的移植思路是这样的:我用一个全局actor代替我的全局消息队列,它负责消息的注册。这样,我可以轻松获得用于调试目的的消息日志,而且我不需要让所有参与者都知道所有可能的目标。

我有一个 IO 系统 (canbus) 可以处理与现实世界的联系。

在我当前的系统中,我生成了 GUI 线程 + 系统。它等待 RT 初始化。生成 gui 线程后,我切换到 RT Preempt 优先级并创建其他系统,预置堆栈等。当所有设置完成后,我通知 gui RT 已启动。现在我的系统已经初始化。

当发生一些致命的事情或系统需要关闭时,我会发送一条消息,所有系统都会关闭,所有线程都会加入。

我的问题是: 我如何将 GUI actor/thread 与 libcaf 中的 RT 线程分开? 您会建议在单独的进程中分叉 GUI 吗? 我可以在不同的 RT 优先级线程上生成 actor 吗?

编辑:我找到 spawn 选项 detached。生成的演员(独立演员的孩子)是否在同一个线程上?

The current state is: I have one big global message queue where my systems (aka actors) subscribe to get their messages. They respond with messages to that global queue.

Right now my systems don't need to know the receivers of their messages, because the receivers register for their wanted ones.

CAF 有 publish/subscribe 个小组似乎很适合这里。消费者只需加入一个知名的群组,然后生产者发送给它。这为您提供了您正在寻找的发送者和接收者的解耦。

When some fatal things happens or the system Needs to shut down, i send a message and all systems shut down and all threads get joined.

有两种方法可以轻松实现这一点。一种是使用组,但这要求在检测到致命系统状态时所有参与者都订阅它。或者,您可以使用单个“根”actor 来生成所有其他 actor,并在生成期间始终使用 linked 标志。这样,杀掉root actor就会递归杀掉它的children。

How can i seperate the GUI actor/thread from the RT thread in libcaf? Would you recommend to fork the GUI in a seperate process?

在 0.14 中,您必须将 GUI 移动到它自己的进程中,然后通过 remote_actor 连接到它。作为副作用,这将 GUI 与应用程序逻辑分离,并且 GUI 中的崩溃不会影响系统的其他部分。当然,在这种情况下,您需要为 localhost 通信和序列化付费。

在即将发布的 0.15 中,您还可以使用不同的 actor_system 实例和单独的调度程序。这可以为您节省一些开销,但我仍然更愿意将 GUI 移动到它自己的进程中。

顺便说一下,您不需要实际使用 fork。您可以简单地 运行 您的应用程序,publish 一个参与者到一个端口,然后通过 remote_actor.

连接您的 GUI

I find the spawn option detached. Are the spawned actors (childs of a detached actor) on the same thread?

分离的 actor 将始终 运行 在其自己的线程中。

Can i spawn actors on different RT priority threads?

简答:没有。 CAF使用std::thread接口,可移植但根本不支持RT优先级。在分离 actor 时添加优先级标志是可行的,但像这样的特定于平台的功能不在我们的待办事项列表中。

话虽如此,我们当然会接受添加 RT 优先级支持的 CAF 补丁。