关于Scala:使用Akka http进行大型响应

Large response with akka http

我正在测试akka-http,平均响应大小约为156KB。如果我按顺序运行测试,我也可以在使用akka-http实现的客户端中得到响应。

但是如果我在端点上运行并发请求(8个请求),我只会得到前三个的响应。

在本地运行测试。

这是服务器代码;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
val text = Source.fromInputStream(getClass.getResourceAsStream("/data/data.txt")).mkString

  val route =
    path("build") {
      get {
        complete {
          Future {
            println("Finished")
            //HttpEntity.Strict(ContentTypes.`text/html(UTF-8)`, ByteString(text))
            HttpEntity(ContentTypes.`text/html(UTF-8)`, text)
          }

        }
      }
    }

这是客户端代码;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
(1 to 8).map { i =>
    val res = buildRequest.map { br =>
          println(br)
          TestResult(true, startTime, System.currentTimeMillis, d, None)
        }.recoverWith { case t =>
          println(t)
          Future.successful(TestResult(false, startTime, System.currentTimeMillis, d, Some(t.getMessage)))
        }
}

..
..

def buildRequest =  Source.single(HttpRequest(uri ="/build") -> 1)
  .via(poolClientFlow)
  .runWith(Sink.head)


您包含的客户端代码不会占用响应的实体,这可能会导致您遇到问题。您需要消耗整个响应实体或将其丢弃。有关此问题及其解决方法的进一步说明,请参见此处。