【问题标题】:Hitting a wall when Using CompletableFuture with EJb将 CompletableFuture 与 EJb 一起使用时碰壁
【发布时间】:2020-03-17 10:27:05
【问题描述】:

我正在尝试将 CompletableFuture 与在 WildFly 上运行的 EBJ bean 一起使用。

我可以看到调试器到达远程 Ejb 并成功检索结果,但在 Wayback to caller 类中我遇到了异常

java.lang.ClassNotFoundException:没有可用的类加载器

CompletableFuture<Void> future = CompletableFuture.supplyAsync(() -> {
    dnsRecords = ipaFacadeService.fetchDnsRecords();
    return dnsRecords;

     }).thenAccept(result -> {
        if (result.size() > 0) {
            //do more stuff with the result 
        }
    });

   future.get();

当我堆栈跟踪异常时,我发现它与 CompletableFuture.supplyAsync() 使用的 ForkJoin 相关

[org.jboss.ejb.client.EJBInvocationHandler.doInvoke(EJBInvocationHandler.java:238),
org.jboss.ejb.client.EJBInvocationHandler.doInvoke(EJBInvocationHandler.java:183),
org.jboss.ejb.client.EJBInvocationHandler.invoke(EJBInvocationHandler.java:146),
com.sun.proxy.$Proxy107.fetchDnsRecords(Unknown Source), no.lyse.tele.prov.struts2.action.network.DnsAction.lambda$list$1(DnsAction.java:150), 
java.util.concurrent.CompletableFuture$AsyncSupply.run(CompletableFuture.java:1590),
java.util.concurrent.CompletableFuture$AsyncSupply.exec(CompletableFuture.java:1582),
java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289),
java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1056),
java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1692),
java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:157)]

【问题讨论】:

  • 发布完整的堆栈跟踪,包括 caused by 堆栈

标签: java jakarta-ee wildfly ejb-3.0 completable-future


【解决方案1】:

我想这与使用默认 ForkJoinPool 的事实有关。基本上在 JEE 服务器内部创建非托管线程并不是一个好主意(甚至被规范禁止)。 一种可能是使用 JEE 的 ManagedExecutorService 并像这样注入它:

@Resource
private ManagedExecutorService mes;

然后您可以将其用作 supplyAsync 调用的第二个参数:

final CompletableFuture<Void> future =
    CompletableFuture.supplyAsync(() -> {
        //...
    }, mes).thenAccept//...

另见:

Which thread executes CompletableFuture's tasks and callbacks?

Java 8 CompletableFuture Example

【讨论】:

  • 感谢@Laertes,我会尝试并告诉你
  • 在这里工作。 WildFly 17。谢谢!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-05-15
  • 1970-01-01
  • 2011-01-15
  • 2016-06-20
  • 1970-01-01
  • 2011-08-26
相关资源
最近更新 更多