RabbitMQ.NET消息隊(duì)列怎么用-創(chuàng)新互聯(lián)

這篇文章主要介紹了RabbitMQ .NET消息隊(duì)列怎么用,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)長期為超過千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為景泰企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),景泰網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

具體內(nèi)容如下

首先下載安裝包,我都環(huán)境是win7 64位:
去官網(wǎng)下載 otp_win64_19.0.exe  和rabbitmq-server-3.6.3.exe安裝好
然后開始編程了:
(1)創(chuàng)建生產(chǎn)者類:


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ì)列, 沒有排他性,與不自動(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)備開始推送 
           //發(fā)布的消息可以是任何一個(gè)(可以被序列化的)字節(jié)數(shù)組,如序列化對象,一個(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è)非常簡單的東西,它一端接受生產(chǎn)者的消息,另一端將他們推送到隊(duì)列中。交換區(qū)必須要明確的指導(dǎo)如何處理它接受到的消息。是放到一個(gè)隊(duì)列中,還是放到多個(gè)隊(duì)列中,亦或是被丟棄。這些規(guī)則可以通過交換區(qū)的類型來定義。 
             //可用的交換區(qū)類型有:direct,topic,headers,fanout。 
             //Exchange:用于接收消息生產(chǎn)者發(fā)送的消息,有三種類型的exchange:direct, fanout,topic,不同類型實(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); 
   } 
 }

(1)創(chuàng)建消費(fè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ù)取超過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é)果如圖:

RabbitMQ .NET消息隊(duì)列怎么用

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“RabbitMQ .NET消息隊(duì)列怎么用”這篇文章對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

分享標(biāo)題:RabbitMQ.NET消息隊(duì)列怎么用-創(chuàng)新互聯(lián)
文章地址:http://www.muchs.cn/article48/ceodhp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、品牌網(wǎng)站制作網(wǎng)頁設(shè)計(jì)公司、外貿(mào)網(wǎng)站建設(shè)網(wǎng)站收錄、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化