首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于资源稀缺性的背压观测

基于资源稀缺性的背压观测
EN

Stack Overflow用户
提问于 2016-11-09 15:07:02
回答 1查看 49关注 0票数 0

在RxJava 1/ RxScala中,如何在以下情况下观察到节气门/背压源?

代码语言:javascript
复制
def fast: Observable[Foo] // Supports backpressure

def afterExpensiveOp: Observable[Bar] = 
    fast.flatMap(foo => Observable.from(expensiveOp(foo))

// Signature and behavior is out of my control
def expensiveOp(foo: Foo)(implicit ec: ExecutionContext): Future[Bar] = {
   if(noResources()) Future.failed(new OutOfResourcesException())
   else Future { Bar() }
}

一个可能的解决办法就是阻止直到。它可以工作,但这是非常不优雅的,可以防止多个同时进行的请求:

代码语言:javascript
复制
def afterExpensiveOp: Observable[Bar] = fast.flatMap(foo => 
   Observable.just(Observable.from(expensiveOp(foo)).toBlocking.head)
)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-15 09:25:37

flatMap有一个参数来限制并发订阅者的数量。如果你使用这个,flatMap会照顾你的背压。

代码语言:javascript
复制
def afterExpensiveOp = fast.flatMap(safeNumberOfConccurrentExpensiveOps, x => Observable.from(expensiveOp(x)))
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40510116

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档