- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想组合多个Flux
同一类型的在一起。在订阅时,它们应该并行执行。订阅方法应该能够限制请求数量。
我尝试过Flux.merge(..)
和Flux.concat(..)
。后者似乎强制执行顺序请求生产,即使在并行调度程序上发布时,第一个以急切的方式请求所有元素并且仅尊重 take(n)
方法onNext
事件但不适用于onRequest
Activity 。
我准备了一个最小的例子。三 Flux
这些都将在 Schedulers.boundedElastic()
上执行繁重的 I/O 工作。 。每个记录他们的 onRequest
Activity 。
Flux<String> f1 = Flux.just("1").publishOn(Schedulers.boundedElastic()).flatMap(i -> {
try {
//Long running, i/o task
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return Flux.just(i);
}).doOnRequest(s -> LOGGER.info("onRequest {}", 1));
Flux<String> f2 = Flux.just("2").publishOn(Schedulers.boundedElastic()).flatMap(i -> {
try {
//Long running, i/o task
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return Flux.just(i);
}).doOnRequest(s -> LOGGER.info("onRequest {}", 2));
Flux<String> f3 = Flux.just("3").publishOn(Schedulers.boundedElastic()).flatMap(i -> {
try {
//Long running, i/o task
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return Flux.just(i);
}).doOnRequest(s -> LOGGER.info("onRequest {}", 3));
Flux.concat
和take(2)
Flux.concat(f1, f2, f3).take(2)
.doOnNext(i -> LOGGER.info("onNext {}", i))
.subscribeOn(Schedulers.boundedElastic()).subscribe();
结果:
00:16:11.980 [oundedElastic-1] d.f.B.Application : onRequest 1
00:16:13.981 [oundedElastic-2] d.f.B.Application : onNext 1
00:16:13.981 [oundedElastic-2] d.f.B.Application : onRequest 2
00:16:15.982 [oundedElastic-3] d.f.B.Application : onNext 2
两个 onRequest
和两个onNext
事件被传播。请求延迟了两秒但与预期并行。
Flux.map
和take(2)
Flux.merge(f1, f2, f3).take(2)
.doOnNext(i -> LOGGER.info("onNext {}", i))
.subscribeOn(Schedulers.boundedElastic()).subscribe();
结果
00:21:58.301 [oundedElastic-1] d.f.B.Application : onRequest 1
00:21:58.302 [oundedElastic-1] d.f.B.Application : onRequest 2
00:21:58.302 [oundedElastic-1] d.f.B.Application : onRequest 3
00:22:00.303 [oundedElastic-4] d.f.B.Application : onNext 3
00:22:00.304 [oundedElastic-3] d.f.B.Application : onNext 2
三 onRequest
即使只有两个预期的事件也会被发出。 take(n)
方法只是限制了发出的 onNext
事件。执行按预期并行完成。
00:21:58.302 [oundedElastic-1] d.f.B.Application : onRequest 2
00:21:58.302 [oundedElastic-1] d.f.B.Application : onRequest 3
00:22:00.303 [oundedElastic-4] d.f.B.Application : onNext 3
00:22:00.304 [oundedElastic-3] d.f.B.Application : onNext 2
只有两个onRequest
事件已发出并完成
是否可以将这三个结合起来 Flux
以某种方式可以同时计算它们但在其请求行为中受到限制(take(n)
?)?在我的真实场景中,请求会导致 WebClient 调用 WebService,从而启动耗时的 I/O 任务。因此,即使我的应用程序只接收两个 onNext 事件,第三个发出的 onRequest 也会导致请求进入涅槃状态。
最佳答案
我也是项目 react 堆的新手,但我想出了这个解决方法,有些人可能会称之为黑客:
Flux.fromIterable(Lists.partition(Arrays.asList(f1, f2, f3), 2))
.take(1)
.flatMap(partition -> Flux.merge(partition)
.doOnNext(i -> LOGGER.info("onNext {}", i)))
.subscribeOn(Schedulers.boundedElastic())
.subscribe();
它为我打印了这个:
2020-04-17 01:07:37.658 INFO 59488 --- [oundedElastic-1] com.example.demo.SomeService1 : onRequest 1
2020-04-17 01:07:37.659 INFO 59488 --- [oundedElastic-1] com.example.demo.SomeService1 : onRequest 2
2020-04-17 01:07:39.664 INFO 59488 --- [oundedElastic-3] com.example.demo.SomeService1 : onNext 2
2020-04-17 01:07:39.667 INFO 59488 --- [oundedElastic-2] com.example.demo.SomeService1 : onNext 1
关于java - 如何并行调度多个 Flux 并限制 onNext 和 onRequest 事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61261192/
我有两个问题: 'bind(onNext:' 和 'subscribe(onNext:' 有什么区别? struct Info { var index: Int? var data:
在一个使用 RxJava 2 的 Android 项目中,我在初始 Activity 的 onCreate 中创建了一个像这样的 Flowable: Flowable.create(new MyFlo
我有一个函数可以从网络服务中获取一些信息: const rxjs = require('rxjs'); const request = require('request'); const moment
所以我有一个Observable。我想知道什么时候 每个 下游订阅者 onNext 调用将要进行,这既是为了测量每个下游订阅者花费的时间量,也是为了背压目的。 Observable.lift 让我完成
我是 Rx 的新手,我真的很感激在错误处理方面的一些帮助。我有以下代码,它基本上是预先输入的: var observable = Rx.Observable.fromEvent(searchField
有没有办法延迟某些值的onNext?,例如: let subject = new Rx.BehaviorSubject({value: 100}) subject.onNext({ value: 12
下面我有向两个 API 端点发出请求的代码。我正在寻找一种让 onNext() 函数仅触发一次的方法。现在,如果您运行下面的代码,您可以看到它 logs fire 1,然后是 fire 2。我只想让它
我有一个发出长值的可观察值。一旦我收到一个>0的长值,那么我只需要中断发出并点击onComplete。有没有比我所做的黑客方法更好的方法来做到这一点 long id = -1l; methodA()
我正在尝试使用 RxJava 创建模型的代理,该代理允许其他人订阅模型中的更改。 这是我的代理的简化版本: class MyModelProxy { private static MyMode
我正在用 Retrofit 调用一个 url,我不关心结果。无论如何要忽略 onNext 方法吗? 目前我正在使用: getRetrofit().create(UserAPI.class)
我正在使用 RxAndroid 库来处理使用订阅者/可观察模式的项目列表。我的问题是,当一个项目被处理时,有一个进度条需要更新。但是在处理了 16 个项目之后,似乎 observable 没有调用 o
我有一个创建新 Observable 的用例: Observable.create(new Observable.OnSubscribe() { @Override public void
PublishSubject 非常适合在观察者和可观察对象之间架起一座桥梁: Observable observable = Observable.just("string"); Pu
有没有更简洁的方法来执行以下操作? 我有一个 Android observable 可以消除请求。 onNext 它调用第二个可观察对象。 {// when creating the android
我想在调用 onNext 后 10 秒发出一个随机值。所以 onNext 将被调用 12345,10 秒后 onNext 应该被调用以获得一个随机数。使用 RxJava 实现此目的的最佳方法是什么?提
每隔一段时间我都会用特定的查询检索推文。这些推文必须传递给计算和操作这些推文的服务。所以这些服务订阅了我的出版商。所以 publisher.hasSubscribers() 返回 true。但是提交或
我正在尝试在我的 http 代码中使用一些 reactiveX。为此,我创建了一个主题,并尝试调用 onNext 函数,但我收到一条错误消息,指出 subject.onNext 不是一个函数。 htm
我有这个简单的 retrofit2 api 接口(interface),其中包含 interface Api { @GET(BuildConfig.END_POINT) Observable
有人可以告诉我这个插件是如何工作的 http://bootstraptour.com/api/ ?我有一个步骤,我想重定向到动态网址。所以我编写了 onNext 回调,如下所示的代码。重定向工作正常,
我在 GRPC 文档中找不到任何与此相关的内容。 GRPC 是否期望我的 StreamObserver.onNext() 实现是非阻塞的?如果 GRPC 确实阻塞(例如拒绝新请求、对新请求排队等),会
我是一名优秀的程序员,十分优秀!