- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我已经使用 编写了一个大型 HTTP 服务器,但是当并发请求数增加时出现此错误
WARNING: Thread Thread[vert.x-eventloop-thread-1,5,main] has been blocked for 8458 ms, time limit is 1000
io.vertx.core.VertxException: 线程阻塞
这是我的完整代码:
public class MyVertxServer {
public Vertx vertx = Vertx.vertx(new VertxOptions().setWorkerPoolSize(100));
private HttpServer server = vertx.createHttpServer();
private Router router = Router.router(vertx);
public void bind(int port){
server.requestHandler(router::accept).listen(port);
}
public void createContext(String path,MyHttpHandler handler){
if(!path.endsWith("/")){
path += "/";
}
path+="*";
router.route(path).handler(new Handler<RoutingContext>() {
@Override
public void handle(RoutingContext ctx) {
String[] handlerID = ctx.request().uri().split(ctx.currentRoute().getPath());
String suffix = handlerID.length > 1 ? handlerID[1] : null;
handler.Handle(ctx, new VertxUtils(), suffix);
}
});
}
}
我怎么调用它:
ver.createContext("/getRegisterManager",new ProfilesManager.RegisterHandler());
ver.createContext("/getLoginManager", new ProfilesManager.LoginHandler());
ver.createContext("/getMapcomCreator",new ItemsManager.MapcomCreator());
ver.createContext("/getImagesManager", new ItemsManager.ImagesHandler());
ver.bind(PORT);
我怎么没发现 eventbus() 对于处理发送/接收文件的 http 服务器有用,因为你需要在消息中发送 RoutingContext 是不可能的。
你能给我指明正确的方向吗?谢谢
添加了一些处理程序代码:
class ProfileGetter implements MyHttpHandler{
@Override
public void Handle(RoutingContext ctx, VertxUtils utils, String suffix) {
String username = utils.Decode(ctx.request().headers().get("username"));
String lang = utils.Decode(ctx.request().headers().get("lang"));
display("profile requested : "+username);
Profile profile = ProfileManager.FindProfile(username,lang);
if(profile == null){
ctx.request().response().putHeader("available","false");
utils.sendResponseAndEnd(ctx.response(),400);
return;
}else{
ctx.request().response().putHeader("available","true");
utils.writeStringAndEnd(ctx, new Gson().toJson(profile));
}
}
}
此处 ProfileManager.FindProfile(username,lang) 在同一线程上执行长时间运行的数据库作业
...
基本上我所有的进程都发生在主线程上,因为如果我使用执行器,我会在 Vertx 中得到奇怪的异常和空指针,让我觉得 Vertx 中的请求处理器是并行的
最佳答案
考虑到问题中的少量代码,让我们同意问题出在线上:
Profile profile = ProfileManager.FindProfile(username,lang);
假设这是在内部进行一些阻塞 JDBC 调用,这是 Vert.x 中的反模式,您可以通过多种方式解决这个问题。
假设您可以完全重构 IMO 最好的 ProfileManager
类,然后您可以将其更新为响应式(Reactive),因此您的代码将如下所示:
ProfileManager.FindProfile(username,lang, res -> {
if (res.failed()) {
// handle error, sent 500 back, etc...
} else {
Profile profile = res.result();
if(profile == null){
ctx.request().response().putHeader("available","false");
utils.sendResponseAndEnd(ctx.response(),400);
return;
}else{
ctx.request().response().putHeader("available","true");
utils.writeStringAndEnd(ctx, new Gson().toJson(profile));
}
}
});
现在在幕后发生的事情是您的 JDBC 调用不会阻塞(这很棘手,因为 JDBC 本质上是阻塞的)。因此,要解决此问题,并且您很幸运能够使用 MySQL 或 Postgres,那么您可以针对 async-client 编写 JDBC 代码。如果您受困于其他 RDBMS 服务器,那么您需要使用 jdbc-client这反过来将使用线程池从事件循环线程中卸载工作。
现在假设您不能更改 ProfileManager
代码,那么您仍然可以通过将代码包装在 executeBlocking
block 中将其卸载到线程池:
vertx.executeBlocking(future -> {
Profile profile = ProfileManager.FindProfile(username,lang);
future.complete(profile);
}, false, res -> {
if (res.failed()) {
// handle error, sent 500 back, etc...
} else {
Profile profile = res.result();
if(profile == null){
ctx.request().response().putHeader("available","false");
utils.sendResponseAndEnd(ctx.response(),400);
return;
}else{
ctx.request().response().putHeader("available","true");
utils.writeStringAndEnd(ctx, new Gson().toJson(profile));
}
}
});
关于java - Vertx http 服务器线程已被阻塞 xxxx 毫秒,时间限制为 2000,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39474808/
我尝试在我的 Vertx 项目中实现 Junit5。 只需添加 junit5 就可以正常工作,但是将 vertx-junit5 模块添加到项目后,测试引擎在查找测试时遇到问题 build.gradle
本文整理了Java中com.jetdrone.vertx.yoke.Yoke.vertx()方法的一些代码示例,展示了Yoke.vertx()的具体用法。这些代码示例主要来源于Github/Stack
我试图测试 vertx munity web 客户端提供的响应式(Reactive) web 客户端。 我按照官方指南Quarkus - Getting Started with Reactive .
我一直在尝试将服务迁移到 java 9,尽管我可以编译并运行 fat.jar,但我无法在 Intellij 上运行它,原因是库 vertx 的拆分包问题- hk2 和 vertx.jersey,因为两
我的 Maven 项目中有以下代码: package hello; import org.vertx.java.core.Handler; import org.vertx.java.core.htt
我只是想创建一个 html 页面来获取字符串并在同一页面中再次显示它。我的index.html, Insert title here Create
我遇到了需要纵向扩展的情况,所以我最终得到了一个具有 20 核 和 5GB 的虚拟机。 问题是,当我加载大量数据时,我看不到 CPU 只使用了一个内核。我希望看到 20 个内核 以并行 运行。 我尝试
我已经加入了其中一位 Vertx 爱好者,但是单线程主机可能不适合我,因为在我的服务器中可能同时有 50 个文件下载请求,作为解决方案,我创建了这个类 public abstract T onRun(
我正在VertX中创建cookie,并希望在用户注销后再次将其删除。 AccountController.handleLogin(vertx, router.post("/login")) ... f
我正在尝试在 Vert.x 中创建自己的异步自定义方法,类似于他们的代码: // call the external service WebClient client = WebClient.crea
我正在尝试按照 official vert.x site 上的说明进行操作与通过传递 jvm arg 优雅地启动/停止 vertx verticle 相关 You can also start an
我有 2 个与 Vertx 相关的问题线程模型。 The documentation提及: 默认情况下,Vert.x 实例维护 N 个事件循环线程(其中 N 默认为 core*2)。 对于许多现代应用
我正在生成一个值(使用 uuid java 的 6 个字母数字字母)并检查数据库是否该值已存在。如果该值已存在于数据库中,我会生成新值并再次检查该值是否存在(依此类推)。以同步方式(java),我可以
我希望在应用程序范围变量中设置自定义对象,以便 vertx 可以跨所有微服务请求访问它。我在 Vertx 文档中找不到任何内容。在 Java EE Servlet 中,类似功能的代码是 getServ
我创建了一个 webClient 作为: WebClientOptions options = new WebClientOptions(); WebClient client = WebClient
我正在尝试启动 Vertx.io 服务器的初始测试,但收到以下错误消息: 线程“main”中出现异常 java.lang.NoClassDefFoundError: org/vertx/java/co
我正在尝试使用 dynamoDB 和 lombok 注释运行 vertx 服务器,但无法使其正常工作。我已将 vertx、dynamoDB 和 lombok 的 .jar 文件添加到我的类路径中。一切
操作系统:Linux Vert.x 版本:3.3.3 机器:两台不同的机器同一子网内的不同IP 我想为一个简单的乒乓应用程序启用指标监控,我可以在其中观察两个节点之间发送了多少数据包。 测量的指标应通
我正在开发数据报服务器,它监听特定端口上的消息,我们正在使用 Vertx Java 框架来实现相同的 .如果我在启动垂直时仅在部署选项中指定一个实例,则一切正常。一旦我指定了多个实例,我就会收到套接字
如何将数据追加到文件末尾(或开头)?我尝试使用 list.forEach(str -> { vertx.fileSystem().writeFile(path, Buffer.
我是一名优秀的程序员,十分优秀!