Автоматический выключатель Monix с Http-запросом

Я изо всех сил пытаюсь заставить автоматический выключатель Monix работать асинхронно с некоторым запросом, который я получаю в своем сервисе, и который не выполняется, поэтому он должен активировать автоматический выключатель, и даже когда он разомкнут, он должен выполнить запрос.

Вот мой код

 @GET
  def XXXX(@Suspended asyncResponse: AsyncResponse): Unit = {
    val circuitBreaker = breaker.doOnOpen(eval.Task {
      logger.error(null, "Circuit breaker change state to open")
      asyncResponse.resume(Response.status(Response.Status.SERVICE_UNAVAILABLE.getStatusCode))
    })
      .doOnHalfOpen(eval.Task(logger.error(null, "Circuit breaker change state to half-open")))
      .doOnClosed(eval.Task(logger.error(null, "Circuit breaker change state to close")))
    val staticToggleProgram: ZIO[Any, Throwable, Boolean] =
      (for {
        staticToggle <- toggleService.getStaticToggle()
        state <- renderResponse(asyncResponse, staticToggle)
      } yield state).catchAll(t => {
        logger.error(null, s"Toggle Error handler. Unhandled effect $t")
        asyncResponse.resume(Response.status(Response.Status.INTERNAL_SERVER_ERROR.getStatusCode))
        ZIO.fail(t)
      })
    val task = eval.Task(main.unsafeRun(staticToggleProgram))
    circuitBreaker.protect(task).runAsync
  }

Кажется, когда асинхронный AsyncResponse который используется в обратном вызове выключателя, когда он открыт, переопределяется следующим поступающим запросом, а затем моя служба застревает, и больше не может поступить запрос.

Пока единственное решение состоит в том, чтобы запустить его Sync, но это не вариант, так как это должен быть NIO

circuitBreaker.protect(task).runSyncMaybe

0 ответов

Другие вопросы по тегам