编程语言
首页 > 编程语言> > 分叉/加入JavaEE应用程序?

分叉/加入JavaEE应用程序?

作者:互联网

我知道在JavaEE应用程序中分离线程是一个很大的禁忌.但是,我有一个应用程序是Java’s fork/join mechanism的完美候选.但是,由于线程不应该在应用程序中创建,有没有办法在我的EJB中使用它?我知道在WebSphere应用程序中,异步bean功能提供了这一功能.但是,我的应用程序部署在JBoss EAP 6.1上,所以这不是一个选项.

在JavaEE应用程序中是否有“合法”的方法来完成fork / join?

解决方法:

现在最好的答案是Java EE 7规范中的Concurrency Utils API.您有ManagedExecutors和ManagedThreadPools.由于这些托管线程功能和托管任务由应用程序服务器控制,因此请确保您的fork连接计算使用这些资源,然后您可以确保包含线程而不是孤立线程.

最后,您可能必须编写一个“Managed”的ForkJoinPool版本才能获得最佳解决方案.但是它应该是可能的,因为作为第一步,将使用托管版本替换线程池执行程序.

PS:Java SE 8必须在Java SE 8发布时解决这个问题!

标签:java,multithreading,java-ee,ejb,fork-join
来源: https://codeday.me/bug/20190728/1564269.html