RabbitMQ .NET消息隊(duì)列使用詳解
本文實(shí)例為大家分享了RabbitMQ .NET消息隊(duì)列使用方法,供大家參考,具體內(nèi)容如下
首先下載安裝包,我都環(huán)境是win7 64位:
去官網(wǎng)下載 otp_win64_19.0.exe 和rabbitmq-server-3.6.3.exe安裝好
然后開(kāi)始編程了:
(1)創(chuàng)建生產(chǎn)者類(lèi):
class Program { private static void Main() { //建立RabbitMQ連接和通道 var connectionFactory = new ConnectionFactory { HostName = "127.0.0.1", Port = 5672, UserName = "guest", Password = "guest", Protocol = Protocols.DefaultProtocol, AutomaticRecoveryEnabled = true, //自動(dòng)重連 RequestedFrameMax = UInt32.MaxValue, RequestedHeartbeat = UInt16.MaxValue //心跳超時(shí)時(shí)間 }; try { using (var connection = connectionFactory.CreateConnection()) { using (var channel = connection.CreateModel()) { //創(chuàng)建一個(gè)新的,持久的交換區(qū) channel.ExchangeDeclare("SISOExchange", ExchangeType.Direct, true, false, null); //創(chuàng)建一個(gè)新的,持久的隊(duì)列, 沒(méi)有排他性,與不自動(dòng)刪除 channel.QueueDeclare("SISOqueue", true, false, false, null); // 綁定隊(duì)列到交換區(qū) channel.QueueBind("SISOqueue", "SISOExchange", "optionalRoutingKey"); // 設(shè)置消息屬性 var properties = channel.CreateBasicProperties(); properties.DeliveryMode = 2; //消息是持久的,存在并不會(huì)受服務(wù)器重啟影響 //準(zhǔn)備開(kāi)始推送 //發(fā)布的消息可以是任何一個(gè)(可以被序列化的)字節(jié)數(shù)組,如序列化對(duì)象,一個(gè)實(shí)體的ID,或只是一個(gè)字符串 var encoding = new UTF8Encoding(); for (var i = 0; i < 10; i++) { var msg = string.Format("這是消息 #{0}?", i + 1); var msgBytes = encoding.GetBytes(msg); //RabbitMQ消息模型的核心思想就是,生產(chǎn)者不把消息直接發(fā)送給隊(duì)列。實(shí)際上,生產(chǎn)者在很多情況下都不知道消息是否會(huì)被發(fā)送到一個(gè)隊(duì)列中。取而代之的是,生產(chǎn)者將消息發(fā)送到交換區(qū)。交換區(qū)是一個(gè)非常簡(jiǎn)單的東西,它一端接受生產(chǎn)者的消息,另一端將他們推送到隊(duì)列中。交換區(qū)必須要明確的指導(dǎo)如何處理它接受到的消息。是放到一個(gè)隊(duì)列中,還是放到多個(gè)隊(duì)列中,亦或是被丟棄。這些規(guī)則可以通過(guò)交換區(qū)的類(lèi)型來(lái)定義。 //可用的交換區(qū)類(lèi)型有:direct,topic,headers,fanout。 //Exchange:用于接收消息生產(chǎn)者發(fā)送的消息,有三種類(lèi)型的exchange:direct, fanout,topic,不同類(lèi)型實(shí)現(xiàn)了不同的路由算法; //RoutingKey:是RabbitMQ實(shí)現(xiàn)路由分發(fā)到各個(gè)隊(duì)列的規(guī)則,并結(jié)合Binging提供于Exchange使用將消息推送入隊(duì)列; //Queue:是消息隊(duì)列,可以根據(jù)需要定義多個(gè)隊(duì)列,設(shè)置隊(duì)列的屬性,比如:消息移除、消息緩存、回調(diào)機(jī)制等設(shè)置,實(shí)現(xiàn)與Consumer通信; channel.BasicPublish("SISOExchange", "optionalRoutingKey", properties, msgBytes); } channel.Close(); } } } catch (Exception ex) { Console.WriteLine(ex.Message); } Console.WriteLine("消息發(fā)布!"); Console.ReadKey(true); } }
(2)創(chuàng)建消費(fèi)者類(lèi):
class Program { private static void Main() { // 建立RabbitMQ連接和通道 var connectionFactory = new ConnectionFactory { HostName = "127.0.0.1", Port = 5672, UserName = "guest", Password = "guest", Protocol = Protocols.AMQP_0_9_1, RequestedFrameMax = UInt32.MaxValue, RequestedHeartbeat = UInt16.MaxValue }; using (var connection = connectionFactory.CreateConnection()) using (var channel = connection.CreateModel()) { // 這指示通道不預(yù)取超過(guò)1個(gè)消息 channel.BasicQos(0, 1, false); //創(chuàng)建一個(gè)新的,持久的交換區(qū) channel.ExchangeDeclare("SISOExchange", ExchangeType.Direct, true, false, null); //創(chuàng)建一個(gè)新的,持久的隊(duì)列 channel.QueueDeclare("sample-queue", true, false, false, null); //綁定隊(duì)列到交換區(qū) channel.QueueBind("SISOqueue", "SISOExchange", "optionalRoutingKey"); using (var subscription = new Subscription(channel, "SISOqueue", false)) { Console.WriteLine("等待消息..."); var encoding = new UTF8Encoding(); while (channel.IsOpen) { BasicDeliverEventArgs eventArgs; var success = subscription.Next(2000, out eventArgs); if (success == false) continue; var msgBytes = eventArgs.Body; var message = encoding.GetString(msgBytes); Console.WriteLine(message); channel.BasicAck(eventArgs.DeliveryTag, false); } } } } }
消費(fèi)者--結(jié)果如圖:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ADO調(diào)用分頁(yè)查詢(xún)存儲(chǔ)過(guò)程的實(shí)例講解
下面小編就為大家分享一篇ADO調(diào)用分頁(yè)查詢(xún)存儲(chǔ)過(guò)程的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12C#實(shí)現(xiàn)HTTP協(xié)議迷你服務(wù)器(兩種方法)
用C#語(yǔ)言實(shí)現(xiàn)HTTP協(xié)議的服務(wù)器類(lèi)本文將以?xún)煞N稍微有差別的方式用C#語(yǔ)言實(shí)現(xiàn);要完成高性能的Web服務(wù)功能,通常都是需要寫(xiě)入到服務(wù),如IIS,Apache Tomcat感興趣的朋友可以了解下,或許對(duì)你學(xué)習(xí)c#有所幫助2013-02-02ASP.NET?MVC使用JSAjaxFileUploader插件實(shí)現(xiàn)單文件上傳
這篇文章介紹了ASP.NET?MVC使用JSAjaxFileUploader插件實(shí)現(xiàn)單文件上傳的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09如何對(duì)ASP.NET網(wǎng)站實(shí)現(xiàn)靜態(tài)化
對(duì)于訪問(wèn)量比較大的網(wǎng)站,網(wǎng)頁(yè)靜態(tài)化是一個(gè)比較可靠的解決方案。靜態(tài)化將顯著降低服務(wù)器的壓力,提升服務(wù)器處理能力。下面將介紹兩種不同的實(shí)現(xiàn)方法,并進(jìn)行對(duì)比。2015-09-09ASP.NET實(shí)現(xiàn)個(gè)人信息注冊(cè)頁(yè)面并跳轉(zhuǎn)顯示
這篇文章主要介紹了ASP.NET實(shí)現(xiàn)個(gè)人信息注冊(cè)頁(yè)面并跳轉(zhuǎn)顯示的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12C# SetCursorPos簡(jiǎn)介及使用說(shuō)明
該函數(shù)把光標(biāo)移到屏幕的指定位置,如果新位置不在由ClipCursor函數(shù)設(shè)置的屏幕矩形區(qū)域之內(nèi),則系統(tǒng)自動(dòng)調(diào)整坐標(biāo),使得光標(biāo)在矩形之內(nèi)2012-12-12ASP.NET Web API教程 創(chuàng)建Admin控制器實(shí)例分享
在本文中我們要添加一個(gè)對(duì)產(chǎn)品支持CRUD(創(chuàng)建、讀取、更新和刪除)操作的Web API控制器,需要的朋友可以參考下2012-11-11