日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

SpringBoot整合RabbitMQ, 實現生產者與消費者的功能

瀏覽:146日期:2023-03-21 11:12:50

自然,依賴是少不了的。除了spring-boot-starter-web依賴外。就這個是最主要的依賴了,其他的看著辦就是了。我用的是gradle,用maven的看著弄也一樣的。無非就是包+包名+版本

//AMQPcompile(’org.springframework.boot:spring-boot-starter-amqp:2.0.4.RELEASE’)

這里有一個坑。導致我后來發送消息時一直連不上去。報錯: java.net.SocketException: socket closed。我去網上尋找了許多方案。大致都是一個意思。沒有設置遠程連接權限。讓我添加一個用戶,并且設置最大權限。 下面是添加rabbitmq用戶的命令

#rabbitmqctl add_user 賬號 密碼rabbitmqctl add_user admin 614#分配用戶標簽(admin為要賦予administrator權限的剛創建的那個賬號的名字)rabbitmqctl set_user_tags admin administrator#設置權限,開啟遠程訪問rabbitmqctl set_permissions -p '/' admin '.*' '.*' '.*'

我用完之后去管控臺(http://ip:15672)看了一下用戶列表。確實已經添加上去了,也是最大權限。然鵝并沒有什么卵用后來強行摸索出來了,原來是版本差異的原因。我SpringBoot本來是使用的是2.0.3版本,然后AMQP我使用的是2.0.4。可能有什么不兼容的地方。把Springboot和AMQP的版本給同步成一個就好了。別的版本差一點根本沒啥問題,就AMQP特殊,也是醉了。 使用SpriongBoot的yml配置:重點是rabbitmq那一欄設置好登錄用戶、密碼、地址端口、虛擬地址、超時時間就可以了

server: port: 8080 servlet: context-path: /spring: http: encoding: charset: UTF-8 jackson: #前端頁面傳Date值時格式化 date-format: yyyy-MM-dd HH:mm:ss time-zone: GMT+8 datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://192.168.194.128:3306/mysql?serverTimezone=Asia/Shanghai username: root password: 614 rabbitmq: port: 5672 host: 192.168.194.128 username: admin password: 614 virtual-host: / connection-timeout: 15s#Redis配置 redis: host: 192.168.194.128 port: 6379 #Redis連接池配置 jedis: pool: min-idle: 0 max-idle: 8 max-active: 8 max-wait: -1ms

這里又有個小坑,這個rabbitmq的超時時間(connection-timeout)配的我真的是醉了,我看的教程里寫的是15000,表示15秒,我一輸之后IDEA直接報紅線啊。網上一找,全特么用毫秒值配的,行吧,應該我們用的不是一個版本。點開看下這參數接受一個java.time.Duration對象,百思不得其解。這玩意咋配?我不會啊。找了二十分鐘的攻略才知道是這樣子配的,使用數字+時間標志。比如1h、1M、1m、1d、1s、1ms這種格式就行了。

咳咳,配置文件弄好后也就差不多可以使用rabbitmq發消息了。生產端發消息。只需要使用 RabbitTemplate 類就夠了,看到這個名字,有沒有一種很熟悉的感覺?Redis也有個這玩意 叫 RedisTemplate 關于發消息,在這兒最好還是先指定好exchange和routingKey,即交換機和路由鍵。這樣發過去的消息才能被發到指定的交換機上,然后交換機在通過你的routingKey來發送給綁定了該routingKey的所有隊列。所以首先登陸管控臺(http://ip:15672),到Exchanges和Queues菜單下,創建好交換機和隊列,還有他們之間的routingKey。這個步驟我就不詳細描述了。單靠語言不怎么能夠描述清楚。估計得配很多圖,有需要的自行google把。 萬事俱備。正式開始發送消息。先準備一個要發的玩意。根據業務需求自己創個model就行。我這隨便寫一個。關于這個messageId,及消息唯一ID。他的作用是將該條消息數據和RabbitMQ發送的消息綁定起來。不要也不是不行。只是最好還是設置一個這個參數。

package com.skypyb.rabbitmq.entity;import java.io.Serializable;public class User1 implements Serializable{ private Long id; private String name; private String messageId;//儲存消息發送的唯一標識 public User1() { } public User1(Long id, String name, String messageId) { this.id = id; this.name = name; this.messageId = messageId; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getMessageId() { return messageId; } public void setMessageId(String messageId) { this.messageId = messageId; }}

要發送的數據模型已經準備好,接下來這個類是一個重點。即發送消息的類。注入RabbbitTemplate,然后就可以通過他的 convertSendAndReceive() 方法進行消息的發送。他有很多種重載,最好是選用我這種,比較可控。交換機、路由鍵、消息唯一ID全部指定好。

package com.skypyb.rabbitmq.producer;import com.skypyb.rabbitmq.entity.User1;import org.springframework.amqp.rabbit.core.RabbitTemplate;import org.springframework.amqp.rabbit.support.CorrelationData;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Component;@Component('user1Sender')public class User1Sender { @Autowired private RabbitTemplate rabbitTemplate;//操作rabbitmq的模板 public void send(User1 user1){ CorrelationData correlationData= new CorrelationData(); correlationData.setId(user1.getMessageId()); rabbitTemplate.convertSendAndReceive('user1-exchange',//exchange'user1.key1',//routingKeyuser1,//消息體內容correlationData//消息唯一ID ); }}

emmmm,是不是感覺還是挺簡單的。一個方法調用,消息就過去了。就發送到指定的交換機了。交換機再通過你的routingKey轉發給綁定在上邊的隊列。生產端這邊就完事了。 寫個測試類測試一下。

package com.skypyb.test;import com.skypyb.rabbitmq.Application;import com.skypyb.rabbitmq.entity.User1;import com.skypyb.rabbitmq.producer.User1Sender;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringRunner;import javax.annotation.Resource;import java.util.UUID;@RunWith(SpringRunner.class)@SpringBootTest(classes = Application.class)public class TestOne { @Autowired private User1Sender user1Sender; @Test public void testSend1(){ User1 user1 = new User1(); user1.setId(1L); user1.setName('測試用戶1'); user1.setMessageId('user1$'+System.currentTimeMillis()+'$'+ UUID.randomUUID().toString()); user1Sender.send(user1); }}

運行完畢后。登陸管控臺(http://ip:15672),進入Queues菜單。即可發現消息隊列中已接收到一條消息,會是一個等待消費的狀態。至于到底是哪個消息隊列來處理嘛,那就得看你的exchange通過你的routingKey具體把消息轉發到哪兒了。這個都是在管控臺里邊配置的。 生產端準備完畢。接下來是消費端。消費端也很簡單,yml需要添加消費端的配置。簽收模式最好選擇手動簽收。可控。

server: port: 8081 servlet: context-path: /spring: http: encoding: charset: UTF-8 jackson: #前端頁面傳Date值時格式化 date-format: yyyy-MM-dd HH:mm:ss time-zone: GMT+8 datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://192.168.194.128:3306/mysql?serverTimezone=Asia/Shanghai username: root password: 614 #rabbitmq基本配置 rabbitmq: addresses: 192.168.194.128:5672 username: admin password: 614 virtual-host: / connection-timeout: 15s #rabbitmq消費端配置 listener: simple: #并發數 concurrency: 5 #最大并發數 max-concurrency: 10 #簽收模式:手工簽收、自動簽收 acknowledge-mode: manual #限流,在此消費端同一時間只有一條消息消費 prefetch: 1#Redis配置 redis: host: 192.168.194.128 port: 6379 #Redis連接池配置 jedis: pool: min-idle: 0 max-idle: 8 max-active: 8 max-wait: -1ms

具體的消費者,具體解釋都寫在注釋中了。 關于@Exchange注解中設置的交換機的type屬性,主要是用這些值:

fanout:會把所有發到Exchange的消息路由到所有和它綁定的Queue direct:會把消息路由到routing key和binding key完全相同的Queue,不相同的丟棄 topic:direct是嚴格匹配,那么topic就算模糊匹配,routing key和binding key都用.來區分單詞串,比如A.B.C,*匹配任意單詞,#匹配任意多個或0個單詞,比如。A.B.*可以匹配到A.B.C headers:不依賴routing key和binding key,通過對比消息屬性中的headers屬性,對比Exchange和Queue綁定時指定的鍵值對,相同就路由過來

basicAck()方法可以確認消息消費。執行后,消息隊列中這條消息就沒了。multiple參數表示是否批量消費,一般都選false。

package com.skypyb.rabbitmq.controller;import com.rabbitmq.client.Channel;import com.skypyb.rabbitmq.entity.User1;import org.springframework.amqp.rabbit.annotation.*;import org.springframework.amqp.support.AmqpHeaders;import org.springframework.messaging.handler.annotation.Headers;import org.springframework.messaging.handler.annotation.Payload;import org.springframework.stereotype.Component;import java.io.IOException;import java.util.Map;@Componentpublic class User1Receiver { /** * @param user1 消息體,使用 @Payload 注解 * @param headers 消息頭,使用 @Headers 注解 * @param channel */ /*@RabbitListener表示監聽的具體隊列. bindings屬性代表綁定。里邊有幾個值填寫,填寫好綁定的隊列名字和交換機名字 指定好routingKey。若指定的這些參數不存在的話。則會自行給你創建好 durable代表是否持久化 */ @RabbitListener(bindings = @QueueBinding( value = @Queue(value = 'user1-queue', durable = 'true'), exchange = @Exchange(name = 'user1-exchange', durable = 'true', type = 'topic'), key = 'user1.#' ) ) @RabbitHandler//標識這個方法用于消費消息 public void onUser1Message(@Payload User1 user1,@Headers Map<String, Object> headers,Channel channel) throws IOException { //消費者操作 System.out.println('-------收到消息辣!-----'); System.out.println('發過來的用戶名為:' + user1.getName()); //basicAck()表示確認已經消費消息。通知一下mq,需要先得到 delivery tag //delivery tag可以從消息頭里邊get出來 Long deliveryTag = (Long) headers.get(AmqpHeaders.DELIVERY_TAG); channel.basicAck(deliveryTag, false); }}

把消費端的服務打開后,就已經在監聽了。若監聽的隊列中已有消息,則會立即處理。直到隊列中沒消息為止。若隊列為空,他就不會動,這個時候我啟動一下生產者那邊的測試,消息一發出去,立馬就被消費。非常完美。就是這個效果。 呼,偶爾也不想咸魚了啊,今天一天大概把RabbitMQ搞明白一些了,配置也會配了,消息也會發了。踩了一萬個坑,有不少是那種比較SB的采坑方式,一般人應該踩不到,我就不打出來了。還是感覺有很多收獲的。就是累成麻瓜了。

以上就是SpringBoot整合RabbitMQ, 實現生產者與消費者的功能的詳細內容,更多關于SpringBoot整合RabbitMQ, 實現生產者與消費者的功能的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩免费精品| 亚洲一区成人| 日欧美一区二区| 蜜臀久久99精品久久久久宅男| 99国产精品视频免费观看一公开 | 99国产一区| 一本一本久久| 蜜臀av国产精品久久久久| 日韩精品视频网| 卡一卡二国产精品| 国产精品yjizz视频网| 国产99亚洲| 日av在线不卡| 欧美日一区二区三区在线观看国产免| 91嫩草精品| 精品三级在线观看视频| 中文在线免费视频| 激情婷婷久久| 亚洲日本久久| 国产精品观看| 中文字幕在线官网| 亚洲欧美日韩国产| 国产图片一区| 神马午夜在线视频| 午夜在线精品| 欧美日一区二区在线观看| 国产一区二区三区精品在线观看| 久久国产电影| 亚洲日本免费电影| 久草精品视频| 美女少妇全过程你懂的久久| 亚洲人成网77777色在线播放| 国产情侣久久| 日韩欧美一区二区三区免费看| 久久久夜精品| 日韩区一区二| 天堂√中文最新版在线| 久久www成人_看片免费不卡| 国产精品成人国产| av高清不卡| 免费在线观看视频一区| 另类欧美日韩国产在线| 红桃视频欧美| 国产日韩一区二区三区在线| 日韩精品诱惑一区?区三区| 麻豆精品91| 久久超级碰碰| 夜久久久久久| 久久一区视频| 99国内精品| 麻豆91在线播放| 亚洲一区二区免费看| 久久一区精品| 天堂成人免费av电影一区| 国产精品videossex久久发布| 久久久人人人| 国产精品一卡| 亚洲综合三区| 国产传媒在线| 日本v片在线高清不卡在线观看| 中文在线中文资源| 91欧美精品| 在线亚洲欧美| av中文字幕在线观看第一页| 蜜桃av一区二区三区电影| 国产精品原创| 久久国内精品| 99香蕉国产精品偷在线观看 | 日本va欧美va精品发布| 日韩电影免费网站| 日韩精品国产欧美| 欧美美女一区| 国产一区2区在线观看| 婷婷亚洲成人| 蜜臀av免费一区二区三区| 国产日韩三级| 亚洲一区亚洲| 亚洲精品国产嫩草在线观看| 国产欧美日韩视频在线 | 国产真实久久| 精品美女视频| 91福利精品在线观看| 狠狠干综合网| 欧美日韩尤物久久| 久久亚洲人体| 国产欧美高清视频在线| 免费成人av在线播放| 91精品久久久久久久久久不卡| 国产精品videosex极品| 免费国产亚洲视频| 欧美天堂亚洲电影院在线观看| sm捆绑调教国产免费网站在线观看 | 成人日韩精品| 国模大尺度视频一区二区| 午夜亚洲福利| 丝袜国产日韩另类美女| 欧美网站在线| 久久国产主播| av高清一区| 日韩一区电影| 国产一区二区三区四区五区传媒| 国产精品久久久久久模特| 日本在线不卡视频一二三区| 视频在线观看91| 日韩在线中文| 欧美日韩调教| 欧洲av一区二区| 老牛国产精品一区的观看方式| 四虎成人av| 欧美亚洲综合视频| 日韩美女精品| 国产精品nxnn| 日韩va欧美va亚洲va久久| 国产精品蜜芽在线观看| 亚洲一级网站| 日韩和欧美一区二区三区| 国产精品中文字幕制服诱惑| 激情久久五月| 精品久久国产一区| 奶水喷射视频一区| 国产精品一区二区av日韩在线| 国产日韩一区| 国产aⅴ精品一区二区四区| 99久久视频| 亚洲va久久久噜噜噜久久| 欧美激情在线精品一区二区三区| 91精品婷婷色在线观看| 久久99视频| 欧美日韩精品一区二区视频| 国产精品亚洲欧美| 美女视频免费精品| 亚洲精品人人| 一区二区三区四区在线看| 国产伦精品一区二区三区在线播放 | 国产一区二区三区精品在线观看| 97人人精品| 蜜臀久久久久久久| 国产午夜精品一区二区三区欧美| 97精品中文字幕| 欧美黄色一区二区| 免费看的黄色欧美网站| 国产一在线精品一区在线观看| 一本色道久久精品| 日本中文字幕不卡| 免费亚洲一区| 鲁鲁在线中文| 亚洲18在线| 日韩成人精品一区| 在线一区视频| 国产精品xxx| 日韩中文字幕亚洲一区二区va在线| 久久国产精品免费精品3p| 国产白浆在线免费观看| 久久国产三级| 激情综合网五月| 超碰在线99| 日本精品黄色| 麻豆精品av| 免费日韩一区二区三区| 亚洲欧美专区| 91精品啪在线观看国产18| 蜜桃av一区二区在线观看| 欧美国产不卡| 国产精品白丝久久av网站| 亚洲天堂久久| 亚洲www啪成人一区二区| 久久av一区二区三区| www.九色在线| 日本不卡一区二区| 九色porny丨国产首页在线| 欧美一区影院| 中文一区一区三区免费在线观 | 久久高清国产| 欧美 日韩 国产一区二区在线视频| 最新亚洲一区| 91精品国产经典在线观看| 亚洲我射av| 亚洲精品激情| 福利一区和二区| 亚洲一区二区日韩| 麻豆精品在线播放| 99在线观看免费视频精品观看| 丁香六月综合| 国产精品亚洲欧美一级在线| 日韩专区一卡二卡| 亚洲免费精品| 国产精品一级| 欧美黑人做爰爽爽爽| 国产精品网址| 国产精品一在线观看| 久久国产免费| 国产精品一区二区三区四区在线观看| 国产精品一区高清| 香蕉精品999视频一区二区| 国产日韩一区| 免费观看不卡av| 日韩国产成人精品| 成人污污视频| 福利欧美精品在线| 亚洲一区二区三区高清不卡|