paulwong

          EVEN DRIVEN - SPRING CLOUD STREAM - @PollableBean for Reactive Suppliers

          Supplier beans, or functions that only publish messages in Spring Cloud Stream, are a bit special in that they aren't triggered by the receiving of events like Function or Consumer beans. This means that you often need a way to trigger them to be executed periodically.

          For imperative functions the framework by default "polls" a Supplier function every 1 second, but that duration is configurable using the spring.cloud.stream.poller.fixed-delay property.

          However, for reactive functions supplying a Flux it is only triggered once by default. This is because a Flux itself is potentially an infinite stream of events so in many cases it will only need to be triggered once. But don't worry, if you want to periodically trigger a reactive Supplier because you are producing a finite stream of events you can still do so using @PollableBean. This annotation then allows you to configure how often the function is triggered using the same spring.cloud.stream.poller.fixed-delay property!

          One example use case here could be periodically querying a data store and publishing each entry/row as an event. The number of rows in your data store is a finite number at any given time.

          Example code:

          @PollableBean 
          public Supplier<Flux<String>> stringSupplier() { return () -> Flux.just("foo","bar","baz"); }


          Reference:
          https://solace.community/discussion/360/pollablebean-for-reactive-suppliers-in-spring-cloud-stream

          posted on 2021-11-23 10:03 paulwong 閱讀(249) 評(píng)論(0)  編輯  收藏 所屬分類: SPRING CLOUDEVEN DRIVEN ARCHITECT

          主站蜘蛛池模板: 万山特区| 颍上县| 紫云| 密云县| 延吉市| 长白| 京山县| 永清县| 正阳县| 晴隆县| 台东市| 沙河市| 家居| 班玛县| 鸡泽县| 湟中县| 怀柔区| 陇川县| 青神县| 长乐市| 阜城县| 麻栗坡县| 惠水县| 松阳县| 当雄县| 横峰县| 合水县| 池州市| 富源县| 集贤县| 台山市| 克什克腾旗| 英吉沙县| 封丘县| 南江县| 浪卡子县| 阿坝| 通城县| 钟祥市| 许昌市| 潢川县|