- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Project Reactor
对于我正在写的新服务。我正在使用 Spring 5
与 Netty
.我正在与一堆不同的服务和关系数据库进行交互。所有这些服务都有一个阻塞的客户端和 JDBC
也在阻拦。所以基本上这些网络调用都没有返回发布者。
我的问题是使用所有阻塞 API 时的最佳做法应该是什么。目前我所做的是将所有阻塞 API 代码包装到 Mono.callable
中。并使用了subscribeOn(Scheduler.elastic())
.所以基本上所有的阻塞工作都是在一个弹性线程池上完成的。
问题1。我应该创建一个专用的线程池执行器而不是使用弹性吗?如果是,那为什么?或者我应该为每个不同的服务创建一个专用的弹性池?
问题2。当阻塞方法返回结果时,我应该使用publishOn
吗?以便主线程再次开始处理?
如果是,我怎样才能获得主线程(netty 事件循环线程?)引用?
问题3。如果我在多个不同的运算符中调用多个阻塞调用(一些在链接时,一些在使用 zip()
调用时)然后使用 subscribe
publish
又一次subscribe
publish
不会做很多上下文切换吗?
这些问题中的大多数都与最佳实践有关。
最佳答案
Most of these questions are related to what should be the best practices.
All of these services have a client that is blocking.
JDBC is also blocking
Shall I create a dedicated thread pool executor rather than using elastic?
boundedElastic()
然而,相反,因为这对调度程序中的事件线程数量设置了上限,这可以减少造成背压问题的线程数失控。此调度程序专门设计用于与遗留的阻塞 IO 库接口(interface)。
shall I create a dedicate elastic pool for each of different service?
boundedElastic()
中会更相关。如果您想要为不同的服务单独(或不同)绑定(bind),调度程序。 (仅仅创建一个这样你就可以“给它一个相关的名字”并不是一个足够好的理由恕我直言。)
When blocking method return result, shall I use publishOn so that main thread picks up processing again?
how can I get main thread reference back?
publishOn(Schedulers.immediate())
可用于在您调用的当前线程上发布。
If I’m calling multiple blocking calls in multiple different operators (some while chaining, some while using zip() call) then using subscribe publish and again subscribe publish wouldn’t make a lot of context switching?
关于spring-webflux - 使用 subscribeOn 和 publishOn 时的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54964422/
我希望缓存Mono(仅在成功的情况下),这是WebClient调用的结果。 通过阅读项目 react 堆插件文档,我觉得CacheMono不太适合,因为它也存储了我不想要的错误。 因此,我没有使用Ca
我用 webflux 与 网易和 jdbc ,所以我以下一种方式包装阻塞 jdbc 操作: static Mono fromOne(Callable blockingOperation) {
有人可以告诉我或使用 提供现成的 CRUD 示例吗? WebFlux、RScoket 和 Spring(或 SpringBoot) ? 我研究了 RSocket 文档, WebFlux ,也写了我的简
我正在通过代理连接使用ssl服务测试webclient,但是使用安全ssl连接时出现以下错误。 你知道是什么问题吗? 堆栈跟踪: {"timestamp":"2019-10-29T18:35:43.5
public Mono filter(ServerWebExchange exchange, GatewayFilterChain chain) { Flux body = exchange.
我创建了一个过滤器,我可以在其中访问有效负载的主体并对其执行一些逻辑(现在假设我记录主体)。在最后一步中,我返回了 Mono,但是当请求通过 Controller 继续发送到服务时,它会抛出请求正文丢
上次我在考虑在我们的应用程序中正确使用记录器。例如,我有一个返回用户流的 Controller ,但在日志中,我看到“获取用户”日志正在被另一个线程而不是处理管道上的线程记录,但这是一个好方法吗? @
我正在使用带有 Netty 的 Spring Webflux (2.0.3.RELEASE) 并尝试了解服务器和 Web 客户端如何使用线程。我用 WebClient 编写了一些带有 http 调用链
我面临一个问题。我正在使用 Spring Webflux 并行调用一些 API。如果任何子线程面临任何问题,它需要记录请求。现在的问题是,用于记录一个普通的 POJO 类,其中有一个静态方法通过 Ap
我试图用 JSP 配置 Spring WebFlux。我在 Spring WebFlux 中没有看到任何支持 JSTL View 的 View 类。这是否意味着我们不能使用 Spring WebFlu
我正在寻找一种在响应式(Reactive) API 中使用计划任务的方法。 我知道它使用线程池,所以它与 webflux 组件不太兼容。 你有同等的人来做这项工作吗? 非常感谢 萨维留 最佳答案 有几
我曾经调用 HttpServletRequest.getRemoteAddr() 来获取客户端 ip。 我想知道如何通过 ServerWebExchange 获得它。 我最好的猜测是: serve
我想使用 spring webflux 以 react 方式流式传输文件。 我的端点应该看起来更具体什么是对象的类型? @GetMapping("/file") Flux file() { /
我无法让我的响应式(Reactive)代码以一种常见的方式处理错误。理想的方式是使用可重用的组件,我可以将其作为依赖项添加到其他项目中。 过去,我们使用 @RestControllerAdvise 通
我们正在尝试对 Webflux 使用react。我们将 Jaegar 与 Istio 用于检测目的。 Jaegar 非常了解 Spring MVC 端点,但似乎对 WebFlux 根本不起作用。 我正
我是响应式(Reactive)编程和 Spring WebFlux 的新手。我想让我的 App 1 通过 Flux 发布 Server Sent 事件,我的 App 2 持续监听它。 我希望 Flux
我正在我的项目中尝试新的 ReactiveQuerydslPredicateExecutor 但我找不到 findAll(Predicate, Pageable) 的方法,就像我在 QueryDslP
我正在使用 Spring WebFlux webclient 进行 REST 调用。我已经在 3000 上配置了连接超时毫秒,相应地: WebClient webClient = WebClient.
我想测量使用 WebFlux 进行的一些异步调用的长度。我一直在阅读各种来源,据我所知,@Timed 注释与 AspectJ 一起工作,基本上只是在方法调用之前启动一个计时器,然后停止它。这显然不适用
我有一个 Reactor Kafka 应用程序,它无限期地使用来自主题的消息。我需要公开一个健康检查 REST 端点,它可以指示此过程的健康状况——主要是想知道 Kafka 接收器通量序列是否已终止,
我是一名优秀的程序员,十分优秀!