自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Spring Cloud構建微服務架構:消息驅(qū)動的微服務(入門)【Dalston版】

開發(fā) 開發(fā)工具
我們通過簡單的配置和注解就能實現(xiàn)向RabbitMQ中生產(chǎn)和消費消息。實際上我們使用的對RabbitMQ的starter就是通過Spring Cloud Stream中對RabbitMQ的支持來實現(xiàn)的。下面我們就通過本文來了解一下Spring Cloud Stream。

之前在寫Spring Boot基礎教程的時候?qū)戇^一篇《Spring Boot中使用RabbitMQ》。在該文中,我們通過簡單的配置和注解就能實現(xiàn)向RabbitMQ中生產(chǎn)和消費消息。實際上我們使用的對RabbitMQ的starter就是通過Spring Cloud Stream中對RabbitMQ的支持來實現(xiàn)的。下面我們就通過本文來了解一下Spring Cloud Stream。

[[214020]]

Spring Cloud Stream是一個用來為微服務應用構建消息驅(qū)動能力的框架。它可以基于Spring Boot來創(chuàng)建獨立的、可用于生產(chǎn)的Spring應用程序。它通過使用Spring Integration來連接消息代理中間件以實現(xiàn)消息事件驅(qū)動的微服務應用。Spring Cloud Stream為一些供應商的消息中間件產(chǎn)品提供了個性化的自動化配置實現(xiàn),并且引入了發(fā)布-訂閱、消費組以及消息分區(qū)這三個核心概念。簡單的說,Spring Cloud Stream本質(zhì)上就是整合了Spring Boot和Spring Integration,實現(xiàn)了一套輕量級的消息驅(qū)動的微服務框架。通過使用Spring Cloud Stream,可以有效地簡化開發(fā)人員對消息中間件的使用復雜度,讓系統(tǒng)開發(fā)人員可以有更多的精力關注于核心業(yè)務邏輯的處理。由于Spring Cloud Stream基于Spring Boot實現(xiàn),所以它秉承了Spring Boot的優(yōu)點,實現(xiàn)了自動化配置的功能幫忙我們可以快速的上手使用,但是目前為止Spring Cloud Stream只支持下面兩個著名的消息中間件的自動化配置:

  • RabbitMQ
  • Kafka

快速入門

下面我們通過構建一個簡單的示例來對Spring Cloud Stream有一個初步認識。該示例主要目標是構建一個基于Spring Boot的微服務應用,這個微服務應用將通過使用消息中間件RabbitMQ來接收消息并將消息打印到日志中。所以,在進行下面步驟之前請先確認已經(jīng)在本地安裝了RabbitMQ,具體安裝步驟請參考此文。

構建一個Spring Cloud Stream消費者

  • 創(chuàng)建一個基礎的Spring Boot工程,命名為:stream-hello
  • 編輯pom.xml中的依賴關系,引入Spring Cloud Stream對RabbitMQ的支持,具體如下:
  1. <parent> 
  2.     <groupId>org.springframework.boot</groupId> 
  3.     <artifactId>spring-boot-starter-parent</artifactId> 
  4.     <version>1.5.9.RELEASE</version> 
  5.     <relativePath/> <!-- lookup parent from repository --> 
  6. </parent> 
  7.  
  8. <dependencies> 
  9.     <dependency> 
  10.         <groupId>org.springframework.boot</groupId> 
  11.         <artifactId>spring-boot-starter-test</artifactId> 
  12.         <scope>test</scope> 
  13.     </dependency> 
  14.  
  15.     <dependency> 
  16.         <groupId>org.springframework.cloud</groupId> 
  17.         <artifactId>spring-cloud-starter-stream-rabbit</artifactId>      
  18.     </dependency> 
  19. </dependencies> 
  20.  
  21. <dependencyManagement> 
  22.     <dependencies> 
  23.         <dependency> 
  24.             <groupId>org.springframework.cloud</groupId> 
  25.             <artifactId>spring-cloud-dependencies</artifactId> 
  26.             <version>Dalston.SR4</version> 
  27.             <type>pom</type> 
  28.             <scope>import</scope> 
  29.         </dependency> 
  30.     </dependencies> 
  31. </dependencyManagement> 
  • 創(chuàng)建用于接收來自RabbitMQ消息的消費者SinkReceiver,具體如下:
  1. @EnableBinding(Sink.class) 
  2. public class SinkReceiver { 
  3.  
  4.     private static Logger logger = LoggerFactory.getLogger(SinkReceiver.class); 
  5.  
  6.     @StreamListener(Sink.INPUT) 
  7.     public void receive(Object payload) { 
  8.         logger.info("Received: " + payload); 
  9.     } 
  10.  
  • 創(chuàng)建應用主類,這里同其他Spring Boot一樣,沒有什么特別之處,具體如下:
  1. @SpringBootApplication 
  2. public class SinkApplication { 
  3.  
  4.     public static void main(String[] args) { 
  5.         SpringApplication.run(SinkApplication.class, args); 
  6.     } 
  7.  

到這里,我們快速入門示例的編碼任務就已經(jīng)完成了。下面我們分別啟動RabbitMQ以及該Spring Boot應用,然后做下面的試驗,看看它們是如何運作的。

手工測試驗證

  • 我們先來看一下Spring Boot應用的啟動日志。
  1. ... 
  2. INFO 16272 --- [main] o.s.c.s.b.r.RabbitMessageChannelBinder   : declaring queue for inbound: input.anonymous.Y8VsFILmSC27eS5StsXp6A, bound to: input 
  3. INFO 16272 --- [main] o.s.a.r.c.CachingConnectionFactory       : Created new connection: SimpleConnection@3c78e551 [delegate=amqp://guest@127.0.0.1:5672/] 
  4. INFO 16272 --- [main] o.s.integration.channel.DirectChannel    : Channel 'input.anonymous.Y8VsFILmSC27eS5StsXp6A.bridge' has 1 subscriber(s). 
  5. INFO 16272 --- [main] o.s.i.a.i.AmqpInboundChannelAdapter      : started inbound.input.anonymous.Y8VsFILmSC27eS5StsXp6A 
  6. ... 

從上面的日志內(nèi)容中,我們可以獲得以下信息:

  • 使用guest用戶創(chuàng)建了一個指向127.0.0.1:5672位置的RabbitMQ連接,在RabbitMQ的控制臺中我們也可以發(fā)現(xiàn)它。

  • 聲明了一個名為input.anonymous.Y8VsFILmSC27eS5StsXp6A的隊列,并通過RabbitMessageChannelBinder將自己綁定為它的消費者。這些信息我們也能在RabbitMQ的控制臺中發(fā)現(xiàn)它們。

下面我們可以在RabbitMQ的控制臺中進入input.anonymous.Y8VsFILmSC27eS5StsXp6A隊列的管理頁面,通過Publish Message功能來發(fā)送一條消息到該隊列中。

此時,我們可以在當前啟動的Spring Boot應用程序的控制臺中看到下面的內(nèi)容:

  1. INFO 16272 --- [C27eS5StsXp6A-1] com.didispace.HelloApplication           : Received: [B@7cba610e 

我們可以發(fā)現(xiàn)在應用控制臺中輸出的內(nèi)容就是SinkReceiver中receive方法定義的,而輸出的具體內(nèi)容則是來自消息隊列中獲取的對象。這里由于我們沒有對消息進行序列化,所以輸出的只是該對象的引用,在后面的小節(jié)中我們會詳細介紹接收消息后的處理。

在順利完成上面快速入門的示例后,我們簡單解釋一下上面的步驟是如何將我們的Spring Boot應用連接上RabbitMQ來消費消息以實現(xiàn)消息驅(qū)動業(yè)務邏輯的。

首先,我們對Spring Boot應用做的就是引入spring-cloud-starter-stream-rabbit依賴,該依賴包是Spring Cloud Stream對RabbitMQ支持的封裝,其中包含了對RabbitMQ的自動化配置等內(nèi)容。從下面它定義的依賴關系中,我們還可以知道它等價于spring-cloud-stream-binder-rabbit依賴。

  1. <dependencies> 
  2.     <dependency> 
  3.         <groupId>org.springframework.cloud</groupId> 
  4.         <artifactId>spring-cloud-stream-binder-rabbit</artifactId> 
  5.     </dependency> 
  6. </dependencies> 

接著,我們再來看看這里用到的幾個Spring Cloud Stream的核心注解,它們都被定義在SinkReceiver中:

  • @EnableBinding,該注解用來指定一個或多個定義了@Input或@Output注解的接口,以此實現(xiàn)對消息通道(Channel)的綁定。在上面的例子中,我們通過@EnableBinding(Sink.class)綁定了Sink接口,該接口是Spring Cloud Stream中默認實現(xiàn)的對輸入消息通道綁定的定義,它的源碼如下:
  1. public interface Sink { 
  2.  
  3.     String INPUT = "input"
  4.  
  5.     @Input(Sink.INPUT) 
  6.     SubscribableChannel input(); 
  7.  

它通過@Input注解綁定了一個名為input的通道。除了Sink之外,Spring Cloud Stream還默認實現(xiàn)了綁定output通道的Source接口,還有結合了Sink和Source的Processor接口,實際使用時我們也可以自己通過@Input和@Output注解來定義綁定消息通道的接口。當我們需要為@EnableBinding指定多個接口來綁定消息通道的時候,可以這樣定義:@EnableBinding(value = {Sink.class, Source.class})。

  • @StreamListener:該注解主要定義在方法上,作用是將被修飾的方法注冊為消息中間件上數(shù)據(jù)流的事件監(jiān)聽器,注解中的屬性值對應了監(jiān)聽的消息通道名。在上面的例子中,我們通過@StreamListener(Sink.INPUT)注解將receive方法注冊為對input消息通道的監(jiān)聽處理器,所以當我們在RabbitMQ的控制頁面中發(fā)布消息的時候,receive方法會做出對應的響應動作。

編寫消費消息的單元測試用例

上面我們通過RabbitMQ的控制臺完成了發(fā)送消息來驗證了消息消費程序的功能,雖然這種方法比較low,但是通過上面的步驟,相信大家對RabbitMQ和Spring Cloud Stream的消息消費已經(jīng)有了一些基礎的認識。下面我們通過編寫生產(chǎn)消息的單元測試用例來完善我們的入門內(nèi)容。

  • 在上面創(chuàng)建的工程中創(chuàng)建單元測試類:
  1. @RunWith(SpringRunner.class) 
  2. @EnableBinding(value = {SinkApplicationTests.SinkSender.class}) 
  3. public class SinkApplicationTests { 
  4.  
  5.     @Autowired 
  6.     private SinkSender sinkSender; 
  7.  
  8.     @Test 
  9.     public void sinkSenderTester() { 
  10.         sinkSender.output().send(MessageBuilder.withPayload("produce a message :http://blog.didispace.com").build()); 
  11.     } 
  12.  
  13.     public interface SinkSender { 
  14.  
  15.         String OUTPUT = "input"
  16.  
  17.         @Output(SinkSender.OUTPUT
  18.         MessageChannel output(); 
  19.  
  20.     } 
  21.  
  • 在應用了上面的消息消費者程序之后,運行這里定義的單元測試程序,我們馬上就能在消息消費者的控制臺中收到下面的內(nèi)容:
  1. INFO 50947 --- [L2W-c2AcChb2Q-1] com.didispace.stream.SinkReceiver        : Received: produce a message :http://blog.didispace.com 

在上面的單元測試中,我們通過@Output(SinkSender.OUTPUT)定義了一個輸出通過,而該輸出通道的名稱為input,與前文中的Sink中定義的消費通道同名,所以這里的單元測試與前文的消費者程序組成了一對生產(chǎn)者與消費者。到這里,本文的內(nèi)容就次結束,如果您能夠獨立的完成上面的例子,那么對于Spring Cloud Stream的基礎使用算是入門了。但是,Spring Cloud Stream的使用遠不止于此,在近期的博文中,我講繼續(xù)更新這部分內(nèi)容,幫助他們來理解和用好Spring Cloud Stream來構建消息驅(qū)動的微服務!

 【本文為51CTO專欄作者“翟永超”的原創(chuàng)稿件,轉(zhuǎn)載請通過51CTO聯(lián)系作者獲取授權】

戳這里,看該作者更多好文

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2017-08-10 11:15:05

Spring Clou微服務架構

2017-08-09 15:50:47

Spring Clou微服務架構

2017-09-09 23:15:20

Spring Clou微服務架構路由

2017-09-15 23:29:53

Spring Clou微服務架構過濾器

2018-07-19 14:58:14

Spring Clou微服務架構

2017-06-26 09:06:10

Spring Clou微服務架構

2018-03-02 16:11:29

Spring Clou分布式服務跟蹤

2017-09-04 16:15:44

服務網(wǎng)關架構

2017-07-03 09:50:07

Spring Clou微服務架構

2021-01-07 07:40:31

驅(qū)動微服務消息

2018-07-09 09:27:10

Spring Clou微服務架構

2017-06-25 13:33:25

Spring Clou微服務架構

2017-07-04 17:35:46

微服務架構Spring Clou

2018-04-09 13:56:13

微服務架構分布式

2018-03-13 16:42:26

分布式服務跟蹤

2018-04-02 15:01:31

微服務架構分布式服務

2018-04-16 14:56:56

微服務架構分布式服務

2018-04-18 16:07:49

Spring Clou微服務分布式

2017-07-28 16:41:53

Spring Clou微服務架構

2017-09-05 14:05:11

微服務spring clou路由
點贊
收藏

51CTO技術棧公眾號