當前位置: 首頁>>代碼示例>>C#>>正文


C# ConnectionFactory.CreateModel方法代碼示例

本文整理匯總了C#中RabbitMQ.Client.ConnectionFactory.CreateModel方法的典型用法代碼示例。如果您正苦於以下問題:C# ConnectionFactory.CreateModel方法的具體用法?C# ConnectionFactory.CreateModel怎麽用?C# ConnectionFactory.CreateModel使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在RabbitMQ.Client.ConnectionFactory的用法示例。


在下文中一共展示了ConnectionFactory.CreateModel方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Main

        static void Main(string[] args)
        {
            var serverAddress = "192.168.0.196";
              var queueName = "message_data_cs";

              using (var conn = new ConnectionFactory().CreateConnection(serverAddress))
              {
            using (var ch = conn.CreateModel())
            {
              ch.QueueDeclare(queueName, true);
              var properties = ch.CreateBasicProperties();
              properties.SetPersistent(true);

              for (int i = 0; i < 10; i++)
              {
            var message = new Message()
            {
              From = "C# Sample",
              Body = String.Format("Message No. {0}", i)
            };

            Console.WriteLine("Sending: {0}", i);
            ch.BasicPublish("", queueName, properties, Message.Serialize(message));
              }
            }
              }
        }
開發者ID:antlypls,項目名稱:rabbitmq_demos,代碼行數:27,代碼來源:Program.cs

示例2: WillCreateInputAndErrorQueue

        public void WillCreateInputAndErrorQueue()
        {
            var testRabbitQueues = "test.rabbit.queues";
            CreateBus(testRabbitQueues, new HandlerActivatorForTesting()).Start(1);


            using (var connection = new ConnectionFactory {Uri = ConnectionString}.CreateConnection())
            using (var model = connection.CreateModel())
            {
                Assert.DoesNotThrow(() => model.BasicGet(testRabbitQueues, true));
                Assert.DoesNotThrow(() => model.BasicGet(testRabbitQueues + ".error", true));
            }
        }
開發者ID:nls75,項目名稱:Rebus,代碼行數:13,代碼來源:TestRebusOnRabbit.cs

示例3: DeleteQueue

 public static void DeleteQueue(string queueName)
 {
     using (var connection = new ConnectionFactory {Uri = ConnectionString}.CreateConnection())
     using (var model = connection.CreateModel())
     {
         // just ignore if it fails...
         try
         {
             model.QueueDelete(queueName);
         }
         catch
         {
         }
     }
 }
開發者ID:sTodorov,項目名稱:Rebus,代碼行數:15,代碼來源:RabbitMqFixtureBase.cs

示例4: Main

        static void Main(string[] args)
        {
            var serverAddress = "192.168.0.196";
              var queueName = "string_data";

              using (var conn = new ConnectionFactory().CreateConnection(serverAddress))
              {
            using (var ch = conn.CreateModel())
            {
              var messages = Enumerable.Range(1, 10).Select(x => String.Format("Hello from .NET! Message No. {0}", x));

              foreach (var message in messages)
              {
            Console.WriteLine("Sending: {0}", message);
            ch.BasicPublish("", queueName, null, Encoding.ASCII.GetBytes(message));
              }
            }
              }
        }
開發者ID:antlypls,項目名稱:rabbitmq_demos,代碼行數:19,代碼來源:Program.cs

示例5: Main

        static void Main(string[] args)
        {
            var serverAddress = @"192.168.0.196";
              var queueName = "string_data";

              var conn = new ConnectionFactory().CreateConnection(serverAddress);
              using (var ch = conn.CreateModel())
              {
            conn.AutoClose = true;
            ch.QueueDeclare(queueName);

            BasicGetResult result = null;
            while ((result = ch.BasicGet(queueName, false)) != null)
            {
              ch.BasicAck(result.DeliveryTag, false);
              Console.WriteLine("Message: {0}", Encoding.ASCII.GetString(result.Body));
            }
              }
        }
開發者ID:antlypls,項目名稱:rabbitmq_demos,代碼行數:19,代碼來源:Program.cs

示例6: Main

        static void Main(string[] args)
        {
            var serverAddress = @"192.168.0.196";
              var queueName = "message_data_cs";

              var conn = new ConnectionFactory().CreateConnection(serverAddress);
              using (var ch = conn.CreateModel())
              {
            conn.AutoClose = true;
            ch.QueueDeclare(queueName, true);

            BasicGetResult result = null;
            while ((result = ch.BasicGet(queueName, false)) != null)
            {
              ch.BasicAck(result.DeliveryTag, false);
              var message = Message.Deserialize(result.Body);
              Console.WriteLine(message.Text);
            }
              }

              Console.ReadKey();
        }
開發者ID:antlypls,項目名稱:rabbitmq_demos,代碼行數:22,代碼來源:Program.cs

示例7: Main

        static void Main(string[] args)
        {
            var serverAddress = "192.168.0.196";
              var queueName = "string_data";

              using (var conn = new ConnectionFactory().CreateConnection(serverAddress))
              {
            using (var ch = conn.CreateModel())
            {
              ch.QueueDeclare(queueName, true);
              var properties = ch.CreateBasicProperties();
              properties.SetPersistent(true);

              for (int i = 0; i < 10; i++)
              {
            var message = String.Format("Hello from .NET! Message No. {0}", i);
            Console.WriteLine("Sending: {0}", message);
            ch.BasicPublish("", queueName, (i % 2 == 1) ? properties : null, Encoding.ASCII.GetBytes(message));
              }
            }
              }
        }
開發者ID:antlypls,項目名稱:rabbitmq_demos,代碼行數:22,代碼來源:Program.cs

示例8: TestRabbitMq

        static void TestRabbitMq(int messageCount)
        {
            IConnection connection = new ConnectionFactory().CreateConnection();

            var serializer = new BinarySerializationStrategy();

            for (int i = 0; i < messageCount; i++)
            {
                IModel model = connection.CreateModel();
                model.ExchangeDeclare("rabbitMQ.test.exchange", ExchangeType.Direct, false, true, null);
                byte[] serializedMessage = serializer.Serialize(new TestMessage("test"));
                model.BasicPublish("rabbitMQ.test.exchange", string.Empty, null, serializedMessage);
                model.Close();
            }

            connection.Close();
        }
開發者ID:derekgreer,項目名稱:rabbitBusExamples,代碼行數:17,代碼來源:Program.cs

示例9: QueueExists

        bool QueueExists(string queueName)
        {
            using (var connection = new ConnectionFactory { Uri = ConnectionString }.CreateConnection())
            {
                using (var model = connection.CreateModel())
                {
                    try
                    {
                        model.QueueDeclarePassive(queueName);

                        // if the call succeeds, then the queue exists
                        return true;
                    }
                    catch (OperationInterruptedException exception)
                    {
                        if (exception.Message.Contains("NOT_FOUND"))
                        {
                            return false;
                        }

                        throw;
                    }
                }
            }
        }
開發者ID:nls75,項目名稱:Rebus,代碼行數:25,代碼來源:TestRabbitMqMessageQueue.cs

示例10: RabbitTransportDoesNotChokeOnMessagesContainingComplexHeaders

        public void RabbitTransportDoesNotChokeOnMessagesContainingComplexHeaders()
        {
            // arrange
            const string recipientInputQueue = "test.roundtripping.receiver";
            const string someText = "whoohaa!";

            DeleteQueue(recipientInputQueue);

            // ensure recipient queue is created...
            using (var recipient = new RabbitMqMessageQueue(ConnectionString, recipientInputQueue))
            {
                // force creation of the queue
                recipient.ReceiveMessage(new NoTransaction());

                // act
                // send a message with a complex header
                using (var connection = new ConnectionFactory { Uri = ConnectionString }.CreateConnection())
                using (var model = connection.CreateModel())
                {
                    var props = model.CreateBasicProperties();
                    props.Headers = new Dictionary<string, object>
                        {
                            {
                                "someKey", new Hashtable
                                    {
                                        {"someContainedKey", "someContainedValue"},
                                        {"anotherContainedKey", "anotherContainedValue"},
                                    }
                            }
                        };

                    model.BasicPublish(recipient.ExchangeName,
                                       recipientInputQueue,
                                       props,
                                       Encoding.GetBytes(someText));
                }

                Thread.Sleep(2.Seconds());

                // assert
                var receivedTransportMessage = recipient.ReceiveMessage(new NoTransaction());
                receivedTransportMessage.ShouldNotBe(null);
                Encoding.GetString(receivedTransportMessage.Body).ShouldBe(someText);
            }

            // assert
        }
開發者ID:nls75,項目名稱:Rebus,代碼行數:47,代碼來源:TestRabbitMqMessageQueue.cs


注:本文中的RabbitMQ.Client.ConnectionFactory.CreateModel方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。