运行 RxJS 块中的一组可观察对象
Running group of observables in chunks in RxJS
我正在尝试 运行 一个大块的 observables 池,并在它们之间添加一个间隔。我尝试了以下代码:
let i = 0;
from([].constructor(20)).pipe(
concatMap(a => of(i).pipe(delay(1000))), // add a delay
mergeMap(obj => of(i++), 5) // run 5 in parallel
).subscribe(res => {
console.log('done', new Date().toISOString(), res);
});
现在这增加了所有可观察到的延迟所以我得到的输出是:
done 2020-03-25T09:23:34.151Z 0
done 2020-03-25T09:23:35.151Z 1
done 2020-03-25T09:23:36.151Z 2
done 2020-03-25T09:23:37.151Z 3
done 2020-03-25T09:23:38.151Z 4
done 2020-03-25T09:23:39.151Z 5
done 2020-03-25T09:23:40.153Z 6
done 2020-03-25T09:23:41.155Z 7
done 2020-03-25T09:23:42.161Z 8
done 2020-03-25T09:23:43.163Z 9
done 2020-03-25T09:23:44.167Z 10
done 2020-03-25T09:23:45.170Z 11
done 2020-03-25T09:23:46.171Z 12
done 2020-03-25T09:23:47.177Z 13
done 2020-03-25T09:23:48.178Z 14
done 2020-03-25T09:23:49.182Z 15
done 2020-03-25T09:23:50.183Z 16
done 2020-03-25T09:23:51.186Z 17
done 2020-03-25T09:23:52.188Z 18
done 2020-03-25T09:23:53.192Z 19
如您所见,运行每一个都增加了 1 秒的延迟。我想要实现的是 运行 首先 5 个并行,然后添加 1 秒延迟,然后 运行 接下来五个,依此类推。
我什至尝试交换管道中的 mergeMap 和 concatMap 顺序,但结果相同。
关于如何做到这一点有什么想法吗?
您可以使用 bufferCount
创建批处理,然后 forkJoin
到 运行 并行创建:
let i = 0;
const createRequest = () => of(i++);
from([].constructor(20)).pipe(
bufferCount(5),
concatMap(chunk => forkJoin(chunk.map(createRequest))
.pipe(delay(1000)) // add a delay
),
).subscribe(res => {
console.log('done', new Date().toISOString(), res);
});
我正在尝试 运行 一个大块的 observables 池,并在它们之间添加一个间隔。我尝试了以下代码:
let i = 0;
from([].constructor(20)).pipe(
concatMap(a => of(i).pipe(delay(1000))), // add a delay
mergeMap(obj => of(i++), 5) // run 5 in parallel
).subscribe(res => {
console.log('done', new Date().toISOString(), res);
});
现在这增加了所有可观察到的延迟所以我得到的输出是:
done 2020-03-25T09:23:34.151Z 0
done 2020-03-25T09:23:35.151Z 1
done 2020-03-25T09:23:36.151Z 2
done 2020-03-25T09:23:37.151Z 3
done 2020-03-25T09:23:38.151Z 4
done 2020-03-25T09:23:39.151Z 5
done 2020-03-25T09:23:40.153Z 6
done 2020-03-25T09:23:41.155Z 7
done 2020-03-25T09:23:42.161Z 8
done 2020-03-25T09:23:43.163Z 9
done 2020-03-25T09:23:44.167Z 10
done 2020-03-25T09:23:45.170Z 11
done 2020-03-25T09:23:46.171Z 12
done 2020-03-25T09:23:47.177Z 13
done 2020-03-25T09:23:48.178Z 14
done 2020-03-25T09:23:49.182Z 15
done 2020-03-25T09:23:50.183Z 16
done 2020-03-25T09:23:51.186Z 17
done 2020-03-25T09:23:52.188Z 18
done 2020-03-25T09:23:53.192Z 19
如您所见,运行每一个都增加了 1 秒的延迟。我想要实现的是 运行 首先 5 个并行,然后添加 1 秒延迟,然后 运行 接下来五个,依此类推。
我什至尝试交换管道中的 mergeMap 和 concatMap 顺序,但结果相同。
关于如何做到这一点有什么想法吗?
您可以使用 bufferCount
创建批处理,然后 forkJoin
到 运行 并行创建:
let i = 0;
const createRequest = () => of(i++);
from([].constructor(20)).pipe(
bufferCount(5),
concatMap(chunk => forkJoin(chunk.map(createRequest))
.pipe(delay(1000)) // add a delay
),
).subscribe(res => {
console.log('done', new Date().toISOString(), res);
});