@Bean
public RouterFunction<ServerResponse> route(CacheHandler cacheHandler) {
return RouterFunctions.route()
.GET("......", cacheHandler::xxxxxxx)
.build();
redissonReactiveClient 是 client
但是我如何在一个请求中查出所有数据呢,也就是 reactive 编程怎么搞个循环查询啊
所以这个该咋做啊 -
1
bleulucaswu OP 要做分页的原因是 redis search 这个是强制分页的 (ft.search index *)就你查询默认只给你 10 个
所以必须 (ft.search index * 0 100) 就是必须给个 offset count 参数 |
2
ZGame 36 天前
请求所有数据可以通过 merge ,zip 等操作符吧, 另外可以看看 hs-web ,用的就是响应式。响应式更多时候有点像函数式编程,看看你的操作能不能通过函数式的方式,关注入参出参,还有函数转换方法,尽量减少副作用和外部的变量直接传入,so.. 其实你会发现用不好比用命令式的方式写代码更难受
|
3
OctVan 36 天前
https://projectreactor.io/docs/core/release/reference/#sinks
可以用这个一直翻页,直到取完数据 |
4
spkingr 36 天前
遇事不决问 AI ,这种问题问 AI 最好,他都能给你写好。
编程式风格确实不推荐使用 for 循环,用 for 也是配合 yield 。 你这个 flatMap 按理来说应该是可以的,我复制你的问题给 AI ,AI 就简单的给了一个参考代码,你可以看看,看能不能改改用上: public Mono<SearchResult> searchWithPagination(int pageNumber, int pageSize) { return redissonReactiveClient.getSearch(StringCodec.INSTANCE) .search(SearchArgs(pageNumber, pageSize)) // 返回是 Mono<SearchResult>,有条数和页数吧 .flatMap(initialSearchResult -> { // flatMap 抽取结果 int totalPages = initialSearchResult.getTotal() / pageSize; // 修改一下,获取页数 if (pageNumber < totalPages) { // 这里继续查询并合并 return redissonReactiveClient.getSearch(StringCodec.INSTANCE) .search(SearchArgs(pageNumber, pageSize)) // map 则是转换结果 .map(nextSearchResult -> combineSearchResults(initialSearchResult, nextSearchResult)); } else { // 没有数据 return Mono.just(initialSearchResult); } }); } private SearchResult combineSearchResults(SearchResult initialResult, SearchResult nextResult) { List<Document> combinedDocuments = new ArrayList<>(initialResult.getDocuments()); combinedDocuments.addAll(nextResult.getDocuments()); SearchResult combinedResult = new SearchResult(); combinedResult.setTotal(initialResult.getTotal()); combinedResult.setDocuments(combinedDocuments); return combinedResult; } |
5
spkingr 36 天前
可以用 MD 吗:
``` public Mono<SearchResult> searchWithPagination(int pageNumber, int pageSize) { return redissonReactiveClient.getSearch(StringCodec.INSTANCE) .search(SearchArgs(pageNumber, pageSize)) // 返回是 Mono<SearchResult>,有条数和页数吧 .flatMap(initialSearchResult -> { // flatMap 抽取结果 int totalPages = initialSearchResult.getTotal() / pageSize; // 修改一下,获取页数 if (pageNumber < totalPages) { // 这里继续查询并合并 return redissonReactiveClient.getSearch(StringCodec.INSTANCE) .search(SearchArgs(pageNumber, pageSize)) // map 则是转换结果 .map(nextSearchResult -> combineSearchResults(initialSearchResult, nextSearchResult)); } else { // 没有数据 return Mono.just(initialSearchResult); } }); } private SearchResult combineSearchResults(SearchResult initialResult, SearchResult nextResult) { List<Document> combinedDocuments = new ArrayList<>(initialResult.getDocuments()); combinedDocuments.addAll(nextResult.getDocuments()); SearchResult combinedResult = new SearchResult(); combinedResult.setTotal(initialResult.getTotal()); combinedResult.setDocuments(combinedDocuments); return combinedResult; } ``` |
6
yazinnnn0 36 天前
|
7
bleulucaswu OP @spkingr 这样是没错 可是如果 search 操作不止就两次呢 就不止向 redis 请求两次 我主要想请教下 reative 风格的编程中 循环 x 操作该怎么做 且 x 是异步执行在循环之外的一个线程中 然后 Xn 的部分参数和 Xn-1 有关 然后就是如果 Xn 触发了某个条件 如何让 Xn+1 Xn+2 ... 全部取消 X1~Xn 都是异步无前后顺序执行的 该怎么做到有序的取消操作
|
8
bleulucaswu OP @yazinnnn0 兄弟 图裂了
|
9
spkingr 35 天前
@bleulucaswu 这个时候不得不提 CompletableFuture 大法好了!
thenCombine/thenCompose/thenApplyAsync 这些方法很好用,建议参考这篇文章: https://tech.meituan.com/2022/05/12/principles-and-practices-of-completablefuture.html |
10
bleulucaswu OP @yazinnnn0 请问下 如果 fold 里每次 search 操作都在一个额外的线程中进行,可以做到把结果 combine 到一起吗
然后你这是 0..<20 step 5 来做循环的,假设 index=10 那次循环,因为触发了某个条件将它强制停止,有什么办法让 index=15 的那次循环以及之后所有的循环全部停止不做了(如果有的话),因为每次循环都是多线程乱序的,这能做到吗用 mutiny reactive 编程我还不熟悉 感觉用起来太难了 |
11
bleulucaswu OP @yazinnnn0 就类似
(1..<all step 5).fold(initial) { 多线程操作 }.until( index > 10 ) 就 index>10 的所有多线程里的操作都停掉,until 中肯定会有更复杂的判断条件,这里就举个例子 |
12
bleulucaswu OP @yazinnnn0 ... 搞定了 reactor 有个 expand 方法很好用
|