Mono链的Webflow超时
我正在使用Spring Webflow,并尝试理解Monos链的超时概念。
例如,有一系列Mono调用:
myService.firstOperation()
.then(myService.secondOperation())
...
.then(myService.nOperation())
.timeout(3000L)
如何应用超时:
1)一般操作(操作总时间)
2)用于ECH操作(每次操作不应超过超时)
3)仅用于最后一次操作(n操作)
?
我几乎可以肯定,超时适用于最后一个发布者。如果是,如何将超时应用于操作总数?
解决方案
超时运算符测量从订阅时间到超时运算符观察到的onNext/onComplete信号之间经过的时间。
考虑以下示例:
Mono.delay(Duration.ofMillis(1000))
.then(Mono.delay(Duration.ofMillis(1000)))
.then(Mono.delay(Duration.ofMillis(1000)))
.timeout(Duration.ofMillis(2500))
.block();
如果语句2(两次操作之间测量的时间)或3(仅上次操作的持续时间计数)正确,则上面的代码不会引发任何错误。
但是,超时操作测量的是上游所有操作的持续时间,因此语句1(测量的所有操作的总和)是正确的。
在本例中,所有操作的总和(1000+1000+1000=3000ms)大于配置的超时时间(2500ms),因此代码会导致错误。
相关文章