- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 Vertx 还很陌生,并且一直在我的应用程序中尝试使用 Vertx 3。到目前为止,它在某些场景中似乎确实有用。但我确实有一个问题想要得到全面的解答,因为文档和 Google 没有提供任何相关信息。
(根据我的观察)似乎在不使用集群 vertx 的简单应用程序中,部署的每个 verticle 都由单独的线程维护。但目前我的应用程序(即使用其他框架的Web应用程序)并没有一直使用vertx,(这意味着很多业务逻辑不涉及vertx,并且部署的verticle并不总是繁忙,并且仅以相对不频繁的方式执行操作)。我想知道在这种情况下,当 verticle 部署但空闲时,vertx 是否会释放线程,并且仅在接收事件时使用线程?或者它们会占用线程并且不允许应用程序的非顶点部分使用它们吗?
提前致谢
最佳答案
实际上,这部分内容已经涵盖得很好:http://vertx.io/docs/vertx-core/java/#_reactor_and_multi_reactor
Vert.x works differently here. Instead of a single event loop, each Vertx instance maintains several event loops. By default we choose the number based on the number of available cores on the machine, but this can be overridden.
你错误的地方是绑定(bind)到线程的verticle是占用线程的verticle。假设您有 4 个 CPU 和 1 个 verticle。 VertX 将为其 EventLoop 分配 4 个线程。你开始100个顶点? VertX 仍将使用 4 个线程。
但是,如果 Verticle34(比方说)在 Thread2 上启动,然后被挂起,它将始终在同一线程上恢复。
<小时/>现在让我们看一些代码:
public class EventLoopExample {
static Map<String, AtomicInteger> threadCounts = new ConcurrentHashMap<>();
public static void main(String[] args) {
printActive("Before starting VertX");
Vertx vertx = Vertx.vertx();
printActive("After starting VertX");
for (int i = 0; i < 1000; i++) {
vertx.deployVerticle(new MyVerticle());
printActive("Regular verticle deployed");
}
printActive("Before deploying worker verticles");
for (int i = 0; i < 1000; i++) {
vertx.deployVerticle(new MyVerticle(), new DeploymentOptions().setWorker(true));
printActive("Worker verticle deployed");
}
printActive("After everything deployed");
System.out.println(new TreeMap(threadCounts));
AtomicInteger count = new AtomicInteger(0);
threadCounts.forEach((key, value) -> {
count.addAndGet(value.get());
});
System.out.println(count.get());
}
private static void printActive(String message) {
System.out.println(message);
System.out.println(Thread.activeCount());
}
static class MyVerticle extends AbstractVerticle {
@Override
public void start() {
threadCounts.putIfAbsent(Thread.currentThread().getName(), new AtomicInteger(0));
threadCounts.get(Thread.currentThread().getName()).incrementAndGet();
}
@Override
public void stop() throws Exception {
System.out.println("Stopped");
}
}
}
注意:在 VertX 启动之前,您有 2 个线程处于 Activity 状态
即使您没有部署 verticle,VertX 的启动也会添加 2 个线程
EventLoop 线程的数量由核心数量定义。由于我有 8 个核心,VertX 最多创建 8 个线程。
工作池默认为 20 个线程。
因此,除非您创建更多 WorkerPools 或以其他方式使用配置,否则 VertX 不会使用超过 32 个线程。
关于java - 顶点 : resource allocation when verticles are idle?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47246757/
我正在寻找外行人对计算机硬件和组织的介绍。以下是我想讨论的一些主题。 Brief intro to electronics. Gates and state machines, intro to re
有没有人在 Visual Basic 2010 中看到过这个错误,如果有的话......关于如何解决它的任何想法? 错误是 module 'Resources' and module 'Resourc
这个问题在这里已经有了答案: Why ?attr/colorAccent dose not work below lollipop version? (2 个答案) 关闭 5 年前。 我收到以下错误
我正在尝试通过 ring 学习 clojure 网络开发和 compojure我有点不清楚 compojure.route/resources 和 ring.middleware.resource/w
是否必须放置内部 try-with-resources 或其中一个 try-with-resources 中的所有内容都会自动关闭? try (BasicDataSource ds = Bas
我有一本包含多个食谱的 Chef 食谱,用于安装服务。 Chef-client 的工作方式是每 15 分钟(或其他固定时间间隔)重新收敛一次。现在我的食谱的第一步是停止服务,所以服务将每 15 分钟停
我有资源组“MyResources”,其中包含 4 个资源: AppService - 我的服务器, AppServicePlan - MyServerWestEuFarm, ApplicationI
我有资源组“MyResources”,其中包含 4 个资源: AppService - 我的服务器, AppServicePlan - MyServerWestEuFarm, ApplicationI
我有一个返回 ResponseEntity 的休息终点. 需要检查如何在 Swagger 规范中创建这种类型的响应。这里包中的资源是 org.springframework.core.io.Resou
In my azure portal I have 6 separate applications, I have to list all of the employed resources u
In my azure portal I have 6 separate applications, I have to list all of the employed resources u
我有一个问题,设计师不会显示表单。它失败,错误 Designer 给出警告,如下所示: 我该如何解决这个问题? 最佳答案 您似乎缺少在应用程序中加载此表单所需的项目 资源 . 您可以访问 资源右键单击
我是 angularJS 世界的新手,我可能误解了一些东西。 我的应用程序使用 Controller 、指令和服务,所有这些都运行完美,直到我使用带有 $resource 的服务,然后出现“冲突”或其
我在 Unity3D 工作。 我使用 Resources.LoadAll(path);加载文件夹和子文件夹中的所有项目。执行此操作后,我想获取对象的子文件夹名称或完整路径。这可能吗? 并且不建议使用
我需要监控每个客户端环境(一个订阅、多个资源组)的 Azure 支出。在我的研究中,我发现了 2 个可以使用的 API: 资源费率卡( https://msdn.microsoft.com/fr-fr
在 RDF 1.1 XML 语法文档中 rdf:resource 在定义 Empty Property Elements 时用作缩写形式: When a predicate arc in an RDF
这是一种常见的情况,我们需要在用户更新/创建一些数据后向用户显示错误/成功消息,我们如何在 AngularJS 中实现它? 我想添加回调但找不到解决方案。使用 $http.post().success
我正在使用 android studio 作为 IDE 开发一个 android 应用程序。 我的问题是: 如何在构建APK过程中排除某个目录下的某些文件? 在我的例子中,我想从构建中排除一些图像,因
在编译我的 Visual Studio C# 项目时,出现以下错误: 在“Resources”参数中多次指定项目“obj\Debug\SampleProject.Forms.MDIMain.resou
使用 CoffeeScript、Angular 和 $resource,我创建了以下工厂: angular.module('myapp', ['ngResource']).factory 'MyObj
我是一名优秀的程序员,十分优秀!