<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 閱讀(394) 評論(0)  編輯  收藏 所屬分類: SPRING INTERGRATIONSPRING CLOUDEVEN DRIVEN ARCHITECT

    主站蜘蛛池模板: 黄页网站在线视频免费| 免费一级毛片在线播放| 中文字幕高清免费不卡视频| 亚洲乱码一二三四区麻豆| 国产亚洲情侣一区二区无码AV| 最近2019中文字幕mv免费看| 可以免费观看的毛片| 免费人成再在线观看网站| 国产成人精品日本亚洲网址| 亚洲国产精品无码一线岛国| 亚洲精品无码日韩国产不卡?V| 好大好深好猛好爽视频免费| 在线a免费观看最新网站| 久久精品国产免费一区| 一本一道dvd在线观看免费视频| 亚洲精品无AMM毛片| 亚洲日本在线播放| 亚洲国产精品自在线一区二区| 亚洲人成色77777在线观看大| 国产色婷婷精品免费视频| 免费AA片少妇人AA片直播| 99精品视频免费在线观看| 免费a级毛片无码a∨免费软件| 成人a毛片视频免费看| 国产精品亚洲专区在线播放| 亚洲日本一线产区和二线| 亚洲冬月枫中文字幕在线看| 亚洲视频在线不卡| 久久综合亚洲色HEZYO社区 | 欧洲亚洲国产清在高| 四虎亚洲国产成人久久精品| 免费黄网在线观看| 女人与禽交视频免费看| 无码专区永久免费AV网站| 在线看片免费不卡人成视频| 国拍在线精品视频免费观看| 999久久久免费精品国产| 99在线精品免费视频九九视| 亚洲免费福利在线视频| 成人免费视频77777| 黄页免费的网站勿入免费直接进入|