par-методы процессы ещё живые?
А если не живые, то что?
Vector[(Daemon[F, A], Ref[(Instant, Info)])]
Ну например самое простое — вернуть 5хх и куб рестартанет сервис
Мсье разбирается в жрпс
Да, обычно не нужно явно мониторить. Но если реально надо, например, логгировать ситуации типа "уже 20 минут читаем", то в мире zio это можно сделать через комбинацию schedule и race. В кэтс, наверняка, тоже
Ну я на коленке вот так придумал: def withMonitoring[R, E, A](task: ZIO[R, E, A], tag: String, monitorInterval: Duration = 20.minutes): ZIO[R with Clock, E, A] = { zio.clock.nanoTime.flatMap(start => { val monitorOnce: ZIO[Clock, Nothing, Any] = zio.clock.nanoTime.flatMap(now => UIO { val dur = Duration.fromNanos(now - start) logger.info(s"$tag is running for ${dur.render} so far") } ) val runMonitoring = monitorOnce.delay(monitorInterval).forever task.raceFirst(runMonitoring) }) }
если у тебя стримы бесконечные, то мб просто нужен супервайзинг стримов?
рестартануть весь сервис, если умер 1 стрим? F
А их там оч мало и это основной функционал сервиса.
Обсуждают сегодня