响应akka http

时间:2017-03-27 04:17:53

标签: scala akka-http

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

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

在本地试运行。

这是服务器代码;

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 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)

1 个答案:

答案 0 :(得分:1)

您包含的客户端代码不会使用响应的实体,这可能会导致您遇到的问题。您需要使用整个响应实体或丢弃它。有关此问题以及如何解决此问题的进一步说明,请here