【问题标题】:How do I make 10 http requests simultaneously?如何同时发出 10 个 http 请求?
【发布时间】:2020-04-02 04:43:14
【问题描述】:

我有 10 个请求

  val reqTemplate = quickRequest.post(uri"http://localhost:8280/delay/1")
  val requests = for {i <- 1 to 10} yield {
    reqTemplate.body(s"{test:$i}")
  }

如何同时发送这些请求?

我试过了


  val responseTasks = reqs.map(SttpClient.send)
  val allResponsesTask: Task[List[Response[String]]] = ZIO.collectAllPar(responseTasks)

  val appLogic: Task[Unit] = for {
    resps <- allResponsesTask
    resp <- resps
    _ <- putStrLn(resp.toString())
    _ <- putStrLn("Done")
  } yield ()

  Runtime.default.unsafeRunAsync(appLogic)

但这给了我各种有趣的编译错误。

Error:(18, 74) type mismatch;
 found   : scala.collection.immutable.IndexedSeq[zio.ZIO[sttp.client.asynchttpclient.zio.SttpClient,Throwable,sttp.client.Response[String]]]
    (which expands to)  scala.collection.immutable.IndexedSeq[zio.ZIO[zio.Has[sttp.client.SttpBackend[zio.Task,Nothing,sttp.client.asynchttpclient.WebSocketHandler]],Throwable,sttp.client.Response[String]]]
 required: Iterable[zio.ZIO[Any,Throwable,sttp.client.Response[String]]]
  val allResponsesTask: Task[List[Response[String]]] = ZIO.collectAllPar(responseTasks)
Error:(23, 7) type mismatch;
 found   : zio.ZIO[zio.console.Console,Nothing,Unit]
    (which expands to)  zio.ZIO[zio.Has[zio.console.Console.Service],Nothing,Unit]
 required: scala.collection.GenTraversableOnce[?]
    _ <- putStrLn(response.toString())
Error:(22, 14) type mismatch;
 found   : List[Nothing]
 required: zio.ZIO[Any,Throwable,Unit]
    response <- responses

【问题讨论】:

    标签: scala zio sttp


    【解决方案1】:

    问题是你已经声明了一个 Sttp 依赖但你没有提供它。

    如果您对responsesTask 进行注释,您会看到它实际上是Seq[ZIO[SttpClient, Throwable, Response[String]]] 类型,这意味着您需要提供一个客户端以满足依赖关系。

    我会把它改成这样的:

      val allResponsesTask: Task[List[Response[String]]] = 
        ZIO.collectAllPar(responseTasks)
          .provideLayer(AsyncHttpClientZioBackend.layer())
    

    请注意,为了简单起见,我在此处添加了层,但通常您希望在应用程序的边缘添加所有层,因为创建层不是免费的。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-10-05
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多