亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

rabbitmq結(jié)合spring實現(xiàn)消息隊列優(yōu)先級的方法

 更新時間:2017年02月16日 15:28:45   作者:安南0558  
本篇文章主要介紹了rabbitmq結(jié)合spring實現(xiàn)消息隊列優(yōu)先級的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

 1.1項目背景:做一個災(zāi)情預警的消息平臺,災(zāi)情檢查系統(tǒng)需要向消息平臺里面推送消息,這里是典型的異構(gòu)系統(tǒng)的消息傳遞,我們需要選擇一個中間件作為消息隊列,調(diào)研分析了rabbitmq,zeromq,activemq,kafka等消息中間件,綜合性能,安全,可持久化等角度果斷選擇了rabbitmq作為我們的消息中間件 (其實這里是因為rabbitmq 是spring官方支持的,開發(fā)起來方便)。需求上我們有多種類型的消息,這里有緊急推送的和一般的等區(qū)分,高并發(fā)時,就會有對消息進行優(yōu)先推送的情況出現(xiàn),于是rabbitmq消息隊優(yōu)先級的推送功能是我們需要解決的首個技術(shù)點.

1.2技術(shù)調(diào)研:這里一個概念需要說明,為什么說是消息隊列的優(yōu)先級而不是消息的優(yōu)先級,來看下消息隊列的工作原理

生產(chǎn)者生成消息打到交換機里面(如果沒有聲明交換機,會打到default exchange里面),交換機綁定一個或多個隊列,消息進入隊列里面,消費者一直在監(jiān)聽隊列,發(fā)現(xiàn)隊列里面有消息就開始消費,這里就是一個消息傳遞的過程,queue是一個棧隊列,棧是先進先出的,就是說消息來了依次排隊,一個隊列并不能實現(xiàn)消息的插隊和優(yōu)先推送的功能。但是如果說我們的多個隊列有不同的優(yōu)先級,不同優(yōu)先級的消息通過roatingkey進入不同的隊列,優(yōu)先級高的隊列消息被優(yōu)先消費,這樣也能形成一個相對意義上的優(yōu)先級,所以說這里不是消息的優(yōu)先級而是隊列的優(yōu)先級.

1.2.1 為什么說是相對意義上的優(yōu)先級

有并發(fā)才有優(yōu)先級,如果每個消息都能被瞬間處理也不會有消息優(yōu)先推送的需求,那我們看看消息會在哪里阻塞

1,queue,很明顯高并發(fā)的時候隊列里面是會存在很多消息的,2,eschange ,高并發(fā)的時候producer發(fā)送給exchange的時候也會產(chǎn)生阻塞。

第一種情況由于我們隊列已經(jīng)定義優(yōu)先級了,所以進入隊列的消息都是同種優(yōu)先級別的,并不需要插隊。而對于第二種情況,消息在exchange時阻塞時并不能實現(xiàn)消息優(yōu)先進入隊列,依然是一個依次處理的情景,但是由于exchang到queue的處理速度極快,所有我們忽略了這塊的優(yōu)先級。

1.2.3 代碼實現(xiàn)

在rabbitmq3.5版本之前,官方并沒有實現(xiàn)隊列優(yōu)先級的功能,但論壇里面有一些插件可以實現(xiàn)(末尾附鏈接),這里我們主要說3.5版本之后的實現(xiàn)

1.2.3.1 Java代碼

Connectionconn =RabbitMQConnectionUtil.getRabbitmqConnection();//創(chuàng)建連接 
    Channelchannel = conn.createChannel();//創(chuàng)建channel 
    Map<String,Object> arg = newHashMap<String, Object>();  
    arg.put("x-max-priority",10); //隊列的屬性參數(shù) 有10個優(yōu)先級別 
    // 聲明(創(chuàng)建)隊列 
    //channel.queueDeclare(QUEUE_NAME, false, false, false, null); 
    channel.queueDeclare(QUEUE_NAME,true,false, false, arg); 
    // 消息內(nèi)容 
    String message ="Hello World!"; 
    channel.basicPublish("",QUEUE_NAME, null, message.getBytes()); 
    BasicPropertiesprop =new BasicProperties(null, null, null, null, 1, 
    null, null, null, null, null, null, null, null,null);//消息的參數(shù),聲明該消息的優(yōu)先級是1 
    channel.basicPublish("",QUEUE_NAME, prop, message.getBytes()); //消息發(fā)布 
    System.out.println("[x] Sent '" + message + "'"); 
    //關(guān)閉通道和連接 
    channel.close(); 
    conn.close(); 

客戶端看下結(jié)果:

1.2.3.2結(jié)合spring實現(xiàn): 

1.2.3.2.1 xml配置: 

<beans xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:rabbit="http://www.springframework.org/schema/rabbit"  
  xsi:schemaLocation="http://www.springframework.org/schema/beans  
  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
  http://www.springframework.org/schema/rabbit 
  http://www.springframework.org/schema/rabbit/spring-rabbit-1.0.xsd" > 
  <description>rabbitmq 連接服務(wù)配置</description> 
  <!-- 連接配置 --> 
  <rabbit:connection-factory id="connectionFactory" host="${rabbit.ip}" username="${rabbit.username}"  
  password="${rabbit.password}" port="${rabbit.port}" virtual-host="${rabbit.vhost}"/> 
  <rabbit:admin connection-factory="connectionFactory"/> 
  <rabbit:template id="amqpTemplate" connection-factory="connectionFactory" /> 
  <!-- spring template聲明--> 
  <!-- 聲明一個隊列 --> 
  <rabbit:queue id="test_queue_key" name="test_queue_key" durable="true" auto-delete="false" exclusive="false"> 
   <rabbit:queue-arguments> 
    <entry key="x-max-priority"> 
      <value type="java.lang.Integer">10</value>//這個地方一定是integer的,別的不好使??! 
    </entry> 
   </rabbit:queue-arguments> 
  </rabbit:queue> 
  <!-- 監(jiān)聽配置queues:監(jiān)聽的隊列,多個的話用逗號(,)分隔 ref:監(jiān)聽器--> 
  <rabbit:listener-container connection-factory="connectionFactory" acknowledge="auto"> 
    <rabbit:listener queue-names="test_queue_key" ref="queueListenter" method="onMessage"/> 
  </rabbit:listener-container> 
<bean id="queueListenter" class="com.DF.spring.springAMQP.QueueListener" /> 

1.2.3.2.2代碼部分:

producter:

AbstractApplicationContext ctx = new  
ClassPathXmlApplicationContext("classpath:/spring/rabbitmq-contextDemo2.xml"); 
RabbitTemplate amqpTemplate = ctx.getBean(RabbitTemplate.class); 
 Random random = new Random(); 
  for (int i=0; i< 1000; i++){ 
    final int priority = random.nextInt(10 - 1 + 1) + 1;//隨機的優(yōu)先級 
    amqpTemplate.convertAndSend("test_queue_key", (Object)("hello world"), new MessagePostProcessor() { 
     @Override 
     public Message postProcessMessage(Message message) throws AmqpException { 
      message.getMessageProperties().setPriority(priority); 
      return message; 
     } 
    }); 
  } 

customer: 

public class QueueListener implements MessageListener{ 
 @Override 
 public void onMessage(Message message) { 
  try{ 
   System.out.print("[x] 接收到的消息:"+new String(message.getBody(),"utf-8")+"&&&"+"優(yōu)先級"+message.getMessageProperties().getPrority()); 
   Thread.sleep(1000); 
  }catch(Exception e){ 
   e.printStackTrace(); 
  } 
 } 
} 

從客戶端看下隊列里面的消息:

我們發(fā)送隨機優(yōu)先級的消息進入隊列,看看消費端打印出來的消息:

到這里,rabbitmq結(jié)合spring的demo功能實現(xiàn)......

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot2.6.x默認禁用循環(huán)依賴后的問題解決

    SpringBoot2.6.x默認禁用循環(huán)依賴后的問題解決

    由于SpringBoot從底層逐漸引導開發(fā)者書寫規(guī)范的代碼,同時也是個憂傷的消息,循環(huán)依賴的應(yīng)用場景實在是太廣泛了,所以SpringBoot 2.6.x不推薦使用循環(huán)依賴,本文給大家說下SpringBoot2.6.x默認禁用循環(huán)依賴后的應(yīng)對策略,感興趣的朋友一起看看吧
    2022-02-02
  • java類加載器和類反射使用示例

    java類加載器和類反射使用示例

    這篇文章主要介紹了java類加載器和類反射使用示例,需要的朋友可以參考下
    2014-03-03
  • Java時間類庫Timer的使用方法與實例詳解

    Java時間類庫Timer的使用方法與實例詳解

    這篇文章主要介紹了Jave時間類庫Timer的使用方法與實例詳解,需要的朋友可以參考下
    2020-02-02
  • 面試官:java ThreadLocal真的會造成內(nèi)存泄露嗎

    面試官:java ThreadLocal真的會造成內(nèi)存泄露嗎

    ThreadLocal,java面試過程中的“釘子戶”,在網(wǎng)上也充斥著各種有關(guān)ThreadLocal內(nèi)存泄露的問題,本文換個角度,先思考ThreadLocal體系中的ThreadLocalMap為什么要設(shè)計成弱引用
    2021-08-08
  • 詳解Java8與Runtime.getRuntime().availableProcessors()

    詳解Java8與Runtime.getRuntime().availableProcessors()

    這篇文章主要介紹了詳解Java8與Runtime.getRuntime().availableProcessors(),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • mybatis攔截器與分頁插件實例教程

    mybatis攔截器與分頁插件實例教程

    Mybatis攔截器常常會被用來進行分頁處理。所以下面這篇文章主要給大家介紹了關(guān)于mybatis攔截器與分頁插件的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mybatis具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • java中volatile關(guān)鍵字的作用詳解

    java中volatile關(guān)鍵字的作用詳解

    這篇文章主要介紹了java中volatile關(guān)鍵字的作用詳解,volatile可以保證,若一個線程改變了某塊內(nèi)存的值,其他線程是可見的,以至于其他線程能及時更新這塊內(nèi)存,需要的朋友可以參考下
    2023-09-09
  • mybatis之foreach用法詳解

    mybatis之foreach用法詳解

    這篇文章主要介紹了mybatis之foreach用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • java實現(xiàn)Api接口加密通信方式

    java實現(xiàn)Api接口加密通信方式

    這篇文章主要介紹了java實現(xiàn)Api接口加密通信方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • java簡單坦克大戰(zhàn)制作代碼

    java簡單坦克大戰(zhàn)制作代碼

    這篇文章主要介紹了java簡單坦克大戰(zhàn)制作代碼,利用Java語言中的集合、Swing、線程等知識點編寫一個坦克大戰(zhàn)游戲,需要的朋友可以參考下
    2016-07-07

最新評論