据我了解,每个 vert.x 实例都会被分配一个事件循环。事件循环处理该特定实例的所有请求和其他任务。我认为事件循环是一个线程。当部署了多个 vert.x 实例时,每个实例都有自己的事件循环,对吗?这意味着存在多个线程(多线程)。我是这样理解的。这个单线程概念让我非常头疼。任何帮助将不胜感激。
2 回答
Vert.x 不像 node.js 那样是单线程的。在 vert.x 中,您必须区分 Verticles 和 WorkerVerticles。一个 Vert.x 实例将创建多个事件循环(它们是线程),通常每个 CPU 核心一个。Verticles 将被分配给一个事件循环,并且总是由同一个线程执行,但前提是有工作要做。WorkerVerticles 将被分配给来自工作池的线程,并且可以由不同的线程执行。Vert.x 编程之所以有趣,是因为您可以“假装”它是单线程的。您不必关心并发性,因为您无法在 Verticle 之间共享变量。每个 Verticle 在自己的类加载器中运行,您只能通过事件总线共享数据。(还有一个共享地图,但在这种情况下会分散注意力。)
您现在可能已经弄清楚了,但是我正在为可能遇到此问题的其他人发布答案。
一个vert.x 实例将创建多个线程。在该vert.x 实例中,您有多个Verticle(更准确地说是 Verticle 实例)正在运行。它是一个分配了事件循环的Verticle 实例,但该事件循环并非专门分配给该 Verticle。
当您运行的 Verticle 数量超过线程数时,可能会发生重叠。在这种情况下,一些 Verticle 将被分配给与其他 Verticle 相同的事件循环。该事件循环将处理来自所有分配的 Verticle 的事件。
但是,一旦一个 Verticle 实例被启动并分配给一个事件循环/线程,它就会在它上面运行直到 Verticle 被终止。