<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    paulwong

    EVEN DRIVEN - SPRING CLOUD STREAM 3.x - Functional Programming Model

    SPRING CLOUD STREAM 3.x 版本時,之前的一些編程模式,如@Enablebindding,@StreamListenner等注釋被廢棄了,這是由于一些框架的代碼必需由用戶編寫,如配置框架用的Input MessageChannel,Output  MessageChannel,連接MessageHandler與MessageChannel等,被視為不必要的動作。為了簡化用戶代碼,于是推出Functional Programming Model。

    引入了新名詞:Supplier、Function與Consumer。實際上這幾個類可視為Adapter,如果之前已經有存在的Service類,且方法名為各種各樣,可以重新包裝成Supplier、Function與Consumer,并在固定的方法名:apply/get/accept中調用Service的方法。

    Supplier

    當在配置文件中注入此類型的Bean,并在spring.cloud.stream.function.definition加入此Bean的名稱,SPRING CLOUD STREAM就會幫你生成一個Output  MessageChannel,并連接上此Bean,后續只需要在BINDDING中加入對應的Destination Name,即可向BROKER發消息了。

    Consumer

    當在配置文件中注入此類型的Bean,并在spring.cloud.stream.function.definition加入此Bean的名稱,SPRING CLOUD STREAM就會幫你生成一個Input  MessageChannel,并連接上此Bean,后續只需要在BINDDING中加入對應的Destination Name,即可收到BROKER推送關于此Destination的消息了。

    Function

    當在配置文件中注入此類型的Bean,并在spring.cloud.stream.function.definition加入此Bean的名稱,SPRING CLOUD STREAM就會幫你生成一個Input和Output  MessageChannel,并連接上此Bean,后續只需要在BINDDING中分別對Input和Output MessageChannel加入對應的Destination Name1/Name2,即可收到BROKER推送關于此Destination的消息,也可以向BROKER發消息了。

    與SPRING INTEGRATION的整合

    如果要對消息進行復雜處理,如拆分消息、聚合消息、IF ELSE消息等,就要借助SPRING INTEGRATION了。

    @Bean
        public IntegrationFlow upperCaseFlow(LoanService loanService) {
            return IntegrationFlows
                        //turn this IntegrationFlow as a gateway, here is a Function interface 
                        
    //with loadCheckerFunction as bean name
                        .from(LoadCheckerFunction.class, gateway -> gateway.beanName("loadCheckerFunction"))
                        .handle(loanService, "check")
                        .logAndReply(LoggingHandler.Level.WARN);
        }

        public interface LoadCheckerFunction extends Function<Loan, Loan>{

        }

    IntegrationFlows.from(Class<?> serviceInterface)是可以將本IntegrationFlow包裝成serviceInterface的實現類,如果調用此接口,最終會返回IntegrationFlow最后一個步驟的實體,如果這個serviceInterface是Function的話,剛好和SPRING CLOUD STREAM對接上。

    后續在spring.cloud.stream.function.definition加入此Bean的名稱loadCheckerFunction,SPRING CLOUD STREAM就會幫你生成一個Input和Output  MessageChannel,并連接上此Bean,再在BINDDING中分別對Input和Output MessageChannel加入對應的Destination Name1/Name2,即可收到BROKER推送關于此Destination的消息,也可以向BROKER發消息。

    application.yaml
    # This setting can increase or decrease the rate of message production (1000 = 1s)
    # spring.cloud.stream.poller.fixed-delay=1000

    # This setting can control which function method in our code will be triggered if there are multiple
    # spring.cloud.function.definition=supplyLoan

    # Give the autogenerated binding a friendlier name

    spring:
       application:
          name: loan-check-rabbit
       banner:
          location: classpath:/banner-rabbit.txt
       cloud:
          stream:
             function.definition: loadCheckerFunction
             #BindingProperties
             bindings:
                loadCheckerFunction-in-0:
                   destination: queue.pretty.log.messages
                   binder: local_rabbit
                loadCheckerFunction-out-0:
                   destination: queue.pretty.approved.messages
                   binder: local_rabbit
             #BinderProperties
             binders:
                local_rabbit:
                   type: rabbit
                   environment:
                      spring:
                         rabbitmq:
                            host: 10.80.27.69
                            port: 5672
                            username: guest
                            password: guest
                            virtual-host: my-virtual-host

    Reference

    https://spring.io/blog/2019/10/25/spring-cloud-stream-and-spring-integration

    posted on 2021-11-10 15:10 paulwong 閱讀(395) 評論(0)  編輯  收藏 所屬分類: SPRING INTERGRATIONSPRING CLOUDEVEN DRIVEN ARCHITECT

    主站蜘蛛池模板: 久久精品国产亚洲麻豆| 亚洲精品无码永久在线观看男男| 人妻无码久久一区二区三区免费| 亚洲AV无码成人专区| 国产一级一片免费播放| 日韩视频免费在线观看| 亚洲欧美黑人猛交群| 亚洲综合熟女久久久30p| 91网站免费观看| 一个人看的免费观看日本视频www| 老汉色老汉首页a亚洲| 四虎免费在线观看| 秋霞人成在线观看免费视频| 日本亚洲免费无线码 | 国产精品久久亚洲不卡动漫| 亚洲av无码乱码在线观看野外 | 男人的天堂亚洲一区二区三区| 成年网在线观看免费观看网址| 亚洲综合成人网在线观看| 国产精品另类激情久久久免费 | 亚洲免费观看在线视频| 亚洲国模精品一区 | 亚洲成A人片在线观看WWW| 日本免费电影一区| 97在线视频免费播放| 国产精品美女久久久免费 | 91精品全国免费观看含羞草| 老外毛片免费视频播放| 亚洲avav天堂av在线网爱情| 亚洲男同帅GAY片在线观看| 四虎永久免费地址在线观看| 99久久久精品免费观看国产| 久久国产一片免费观看| 国产精品亚洲一区二区在线观看 | 国产va免费精品观看精品 | 无人影院手机版在线观看免费| a级精品九九九大片免费看| 亚洲AV无码专区在线厂| 亚洲妇女水蜜桃av网网站| 国产V亚洲V天堂A无码| 亚洲日本在线观看视频|