首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >scalaXB异步调度程序java.lang.IllegalStateException:无法创建子事件循环

scalaXB异步调度程序java.lang.IllegalStateException:无法创建子事件循环
EN

Stack Overflow用户
提问于 2017-08-21 01:39:01
回答 1查看 252关注 0票数 1

我正在使用ScalaXB调用SOAP Web服务。我使用以下命令针对WSDL生成了代码

我在一个循环中调用web服务。我注意到代码在一段时间内运行良好,但随后开始抛出以下错误

代码语言:javascript
复制
java.lang.IllegalStateException: failed to create a child event loop
        at io.netty.util.concurrent.MultithreadEventExecutorGroup.<init>(MultithreadEventExecutorGroup.java:68)
        at io.netty.channel.MultithreadEventLoopGroup.<init>(MultithreadEventLoopGroup.java:50)
        at io.netty.channel.nio.NioEventLoopGroup.<init>(NioEventLoopGroup.java:70)
        at io.netty.channel.nio.NioEventLoopGroup.<init>(NioEventLoopGroup.java:65)
        at io.netty.channel.nio.NioEventLoopGroup.<init>(NioEventLoopGroup.java:56)
        at org.asynchttpclient.netty.channel.ChannelManager.<init>(ChannelManager.java:173)
        at org.asynchttpclient.DefaultAsyncHttpClient.<init>(DefaultAsyncHttpClient.java:85)
        at dispatch.Http.client$lzycompute(execution.scala:16)
        at dispatch.Http.client(execution.scala:16)
        at dispatch.Http.client(execution.scala:11)
        at dispatch.HttpExecutor$class.apply(execution.scala:120)
        at dispatch.Http.apply(execution.scala:11)
        at dispatch.HttpExecutor$class.apply(execution.scala:115)
        at dispatch.Http.apply(execution.scala:11)
        at scalaxb.DispatchHttpClientsAsync$DispatchHttpClient$class.request(httpclients_dispatch_async.scala:22)
        at scalaxb.DispatchHttpClientsAsync$$anon$1.request(httpclients_dispatch_async.scala:7)
        at scalaxb.SoapClientsAsync$SoapClientAsync$class.soapRequest(soap12_async.scala:43)
        at scalaxb.SoapClientsAsync$$anon$1.soapRequest(soap12_async.scala:24)
        at scalaxb.SoapClientsAsync$SoapClientAsync$class.requestResponse(soap12_async.scala:63)
        at scalaxb.SoapClientsAsync$$anon$1.requestResponse(soap12_async.scala:24)
Caused by: io.netty.channel.ChannelException: failed to open a new selector
    at io.netty.channel.nio.NioEventLoop.openSelector(NioEventLoop.java:176)
    at io.netty.channel.nio.NioEventLoop.<init>(NioEventLoop.java:150)
    at io.netty.channel.nio.NioEventLoopGroup.newChild(NioEventLoopGroup.java:103)
    at io.netty.util.concurrent.MultithreadEventExecutorGroup.<init>(MultithreadEventExecutorGroup.java:64)
    ... 34 more
Caused by: java.io.IOException: Too many open files in system
        at sun.nio.ch.KQueueArrayWrapper.init(Native Method)
        at sun.nio.ch.KQueueArrayWrapper.<init>(KQueueArrayWrapper.java:98)
        at sun.nio.ch.KQueueSelectorImpl.<init>(KQueueSelectorImpl.java:88)
        at sun.nio.ch.KQueueSelectorProvider.openSelector(KQueueSelectorProvider.java:42)
        at io.netty.channel.nio.NioEventLoop.openSelector(NioEventLoop.java:174)
        ... 37 more
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-31 02:11:29

我找到了这个问题的答案。问题是我在循环内的代理对象上做了一个新的操作。

这些对象似乎创建了一个新的连接,并且没有得到清理,从而导致了上面的错误。

我将代理对象移出循环,只需在循环内调用webservice,问题就解决了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45785062

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档