gpt4 book ai didi

java - 发送多个 singleRequest 时出现 Akka BufferOverflowException

转载 作者:行者123 更新时间:2023-12-01 06:22:21 26 4
gpt4 key购买 nike

这是我的代码

Future.sequence((2 to firstPage.pages).map
{ count =>
getCommentPage(av, count)
}).map(//do something)

getCommentPage中,使用一个Http().singleRequest来获取数据,如下所示:

val responseFuture: Future[HttpResponse] =
Http(system).singleRequest(HttpRequest(GET, uri = requestUri))
responseFuture
.map(_.entity)
.flatMap(_.toStrict(10 seconds)(materializer))
.map(_.data)
.map(_.utf8String)
.map((jsonString: String) => {
//do something to extract data
}

小的firstPage.pages会很好地工作,但是当firstPage.pages很大(大约50或更大)时,就会出现异常:

akka.stream.BufferOverflowException: Exceeded configured max-open-requests value of [32]. This means that the request queue of this pool (HostConnectionPoolSetup(api.bilibili.cn,80,ConnectionPoolSetup(ConnectionPoolSettings(4,0,5,32,1,30 seconds,ClientConnectionSettings(Some(User-Agent: akka-http/10.0.9),10 seconds,1 minute,512,None,<function0>,List(),ParserSettings(2048,16,64,64,8192,64,8388608,256,1048576,Strict,RFC6265,true,Full,Error,Map(If-Range -> 0, If-Modified-Since -> 0, If-Unmodified-Since -> 0, default -> 12, Content-MD5 -> 0, Date -> 0, If-Match -> 0, If-None-Match -> 0, User-Agent -> 32),false,akka.stream.impl.ConstantFun$$$Lambda$244/19208387@4780bf,akka.stream.impl.ConstantFun$$$Lambda$244/19208387@4780bf,akka.stream.impl.ConstantFun$$$Lambda$245/6903324@1d25a2e),None),TCPTransport),akka.http.scaladsl.HttpConnectionContext$@796a3e,akka.event.MarkerLoggingAdapter@1cc552a))) has completely filled up because the pool currently does not process requests fast enough to handle the incoming request load. Please retry the request later. See http://doc.akka.io/docs/akka-http/current/scala/http/client-side/pool-overflow.html for more information.

如何解决?

最佳答案

你可以尝试类似的事情

 val result = Source(1 to 10).mapAsyncUnordered(parallelism = 5) { count =>
getCommentPage(av, count)
}.runWith(Sink.seq)

请注意,并行度值应小于akka.http.host-connection-pool.max-connections

关于java - 发送多个 singleRequest 时出现 Akka BufferOverflowException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45704403/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com