本文整理匯總了C#中RabbitMQ.Client.QueueingBasicConsumer類的典型用法代碼示例。如果您正苦於以下問題:C# QueueingBasicConsumer類的具體用法?C# QueueingBasicConsumer怎麽用?C# QueueingBasicConsumer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
QueueingBasicConsumer類屬於RabbitMQ.Client命名空間,在下文中一共展示了QueueingBasicConsumer類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Telegraph
public Telegraph()
{
var connectionFactory = new ConnectionFactory { HostName = "localhost", VirtualHost = "test" };
_connection = connectionFactory.CreateConnection();
_channel = _connection.CreateModel();
_consumer = new QueueingBasicConsumer(_channel);
}
示例2: Intitialize
public void Intitialize()
{
var factory = new ConnectionFactory { HostName = "localhost" };
using(var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
channel.ExchangeDeclare("Aimbase.Events", "direct");
var consumer = new QueueingBasicConsumer(channel);
foreach (var evnt in _eventHandlers)
{
var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queueName, "Aimbase.Events", evnt.Type);
channel.BasicConsume(queueName, true, consumer);
}
while (true)
{
var ea = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
var body = ea.Body;
var message = Encoding.UTF8.GetString(body);
foreach (var eventHandler in _eventHandlers.Where(eh => eh.Type == ea.RoutingKey))
{
eventHandler.Handle(message);
}
}
}
}
示例3: Main
private static void Main(string[] args)
{
Console.WriteLine("Ready to start charging for orders - press <enter> to stacking up cash...");
Console.ReadLine();
var factory = new ConnectionFactory { HostName = "localhost" };
using (var connection = factory.CreateConnection())
{
using (var channel = connection.CreateModel())
{
var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queueName, ExchangeName, "");
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(queueName, true, consumer);
Console.WriteLine("Waiting for work - press <ctrl-c> to shut down...");
while (true)
{
var message = consumer.Queue.Dequeue();
var body = message.Body;
var contents = Encoding.UTF8.GetString(body);
int quantity = int.Parse(contents.Split(' ')[0]);
Console.WriteLine("Charging for {0} widgets.", quantity);
}
}
}
}
示例4: Main
private static void Main(string[] args)
{
var factory = new ConnectionFactory
{
HostName = "localhost",
UserName = "guest",
Password = "guest",
Protocol = Protocols.DefaultProtocol
};
using (var c = factory.CreateConnection())
using (var m = c.CreateModel())
{
var consumer = new QueueingBasicConsumer(m);
var props = new Dictionary<string, object>()
{
{"x-expires", 30*60000} // expire queue after 30 minutes, see http://www.rabbitmq.com/extensions.html
};
var q = m.QueueDeclare("", false, true, false, props);
m.QueueBind(q, "log4net-logging", "#");
m.BasicConsume(q, true, consumer);
while (true)
{
var msg = (BasicDeliverEventArgs) consumer.Queue.Dequeue();
if (msg.BasicProperties.IsAppIdPresent())
Console.Write(msg.BasicProperties.AppId + " ");
Console.Write(msg.Body.AsUtf8String());
}
}
}
示例5: WorkerThreadFunc
private static void WorkerThreadFunc()
{
var factory = new ConnectionFactory { HostName = "127.0.0.1" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
// mark all messages as persistent
const bool durable = true;
channel.QueueDeclare(QueueName, durable, false, false, null);
var consumer = new QueueingBasicConsumer(channel);
// turn auto acknowledge off so we can do it manually
const bool autoAck = false;
channel.BasicConsume(QueueName, autoAck, consumer);
while (true)
{
var ea = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
byte[] body = ea.Body;
var message = System.Text.Encoding.UTF8.GetString(body);
Thread.Sleep(5000);
channel.BasicAck(ea.DeliveryTag, false);
}
}
}
示例6: NextAsync
public Task<PollerResult<Event>> NextAsync(QueueName name)
{
var connection = _connectionProvider.GetConnection();
var result = new PollerResult<Event>(false , Event.Empty);
using (var channel = connection.CreateModel())
{
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(name.SubscriptionName, true, consumer);
BasicDeliverEventArgs eventArgs = null;
if (consumer.Queue.Dequeue((int)_longPollingTimeout.TotalMilliseconds,
out eventArgs))
{
var @event = new Event()
{
Body = Encoding.UTF8.GetString(eventArgs.Body),
QueueName = name.SubscriptionName,
UnderlyingMessage = eventArgs,
ContentType = "text/plain", // should it be JSON?
EventType = name.SubscriptionName
};
result = new PollerResult<Event>(true, @event);
}
return Task.FromResult(result);
}
}
示例7: Main
public static void Main()
{
ConnectionFactory factory = new ConnectionFactory();
factory.HostName = "localhost";
using (IConnection connection = factory.CreateConnection())
using (IModel channel = connection.CreateModel())
{
channel.QueueDeclare("start", false, false, false, null);
QueueingBasicConsumer consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume("start", true, consumer);
System.Console.WriteLine(" [*] Waiting for messages." +
"To exit press CTRL+C");
while (true)
{
BasicDeliverEventArgs ea =
(BasicDeliverEventArgs)consumer.Queue.Dequeue();
byte[] body = ea.Body;
string message = System.Text.Encoding.UTF8.GetString(body);
System.Console.WriteLine(" [x] Received {0}", message);
}
}
}
示例8: Main
private static void Main(string[] args)
{
Console.WriteLine("Logger waiting for messages...");
var factory = new ConnectionFactory { HostName = "localhost" };
using (var connection = factory.CreateConnection())
{
using (var channel = connection.CreateModel())
{
channel.ExchangeDeclare(ExchangeName, "topic");
var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queueName, ExchangeName, "ewk.#");
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(queueName, true, consumer);
int logEntry = 0;
Console.WriteLine("Waiting for work - press <ctrl-c> to shut down...");
while (true)
{
var message = consumer.Queue.Dequeue();
var body = message.Body;
var contents = Encoding.UTF8.GetString(body);
Console.WriteLine("[{0}:{1:yyyyMMdd-HHmmss.fffff}] {2}",
logEntry++, DateTimeOffset.Now, contents);
}
}
}
}
示例9: receive
/*
This method is receiving request from the server
*/
public void receive()
{
DateTime date_ini = DateTime.Now;
this.factory.HostName = c_reader.GetServer();
using (var connection = this.factory.CreateConnection())
{
using (var channel = connection.CreateModel())
{
channel.ExchangeDeclare("transmission", "fanout");
var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queueName, "transmission", "");
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(queueName, true, consumer);
Console.WriteLine(" [*] Waiting for logs." +
" To exit press CTRL+C");
while (true)
{
var event_args = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
var body = event_args.Body;
var message = Encoding.UTF8.GetString(body);
Console.WriteLine(" [x] {0}", message);
//method to storage the message into the database
StoreData(message);
}
}
}
}
示例10: Main
static void Main()
{
_factory = new ConnectionFactory { HostName = "localhost", UserName = "guest", Password = "guest" };
using (_connection = _factory.CreateConnection())
{
using (var channel = _connection.CreateModel())
{
channel.ExchangeDeclare(ExchangeName, "direct");
channel.QueueDeclare(CardPaymentQueueName, true, false, false, null);
channel.QueueBind(CardPaymentQueueName, ExchangeName, "CardPayment");
channel.BasicQos(0, 1, false);
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(CardPaymentQueueName, false, consumer);
while (true)
{
var ea = consumer.Queue.Dequeue();
var message = (Payment)ea.Body.DeSerialize(typeof(Payment));
var routingKey = ea.RoutingKey;
channel.BasicAck(ea.DeliveryTag, false);
Console.WriteLine("--- Payment - Routing Key <{0}> : {1} : {2}", routingKey, message.CardNumber, message.AmountToPay);
}
}
}
}
示例11: Main
public static void Main()
{
var factory = new ConnectionFactory() { HostName = "localhost" };
using( var connection = factory.CreateConnection() )
using( var channel = connection.CreateModel() )
{
channel.QueueDeclare( queue: "task_queue", durable: true, exclusive: false, autoDelete: false, arguments: null );
channel.BasicQos( prefetchSize: 0, prefetchCount: 1, global: false );
var consumer = new QueueingBasicConsumer( channel );
channel.BasicConsume( queue: "task_queue", noAck: false, consumer: consumer );
Console.WriteLine( " [*] Waiting for messages. To exit press CTRL+C" );
while( true )
{
var ea = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
var body = ea.Body;
var message = Encoding.UTF8.GetString( body );
Console.WriteLine( " [x] Received {0}", message );
int dots = message.Split( '.' ).Length - 1;
Thread.Sleep( dots * 1000 );
Console.WriteLine( " [x] Done" );
channel.BasicAck( deliveryTag: ea.DeliveryTag, multiple: false );
}
}
}
示例12: Run
public void Run()
{
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
{
using (var channel = connection.CreateModel())
{
channel.ExchangeDeclare(exchange: "perf", type: "fanout");
var queueName = channel.QueueDeclare().QueueName;
channel.QueueBind(queue: queueName, exchange: "perf", routingKey: "");
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(queueName, true, consumer);
Console.WriteLine(" [*] Waiting for perf. To exit press CTRL+C");
timer.Start();
while (true)
{
var ea = consumer.Queue.Dequeue();
var body = ea.Body;
var message = Encoding.UTF8.GetString(body);
receivedMessages += 1;
}
}
}
}
示例13: ConsumeMessages
private void ConsumeMessages(string queueName)
{
using (IConnection conn = factory.CreateConnection())
{
using (IModel channel = conn.CreateModel())
{
var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume(queueName, false, consumer);
Trace.WriteLine(string.Format("Waiting for messages from: {0}", queueName));
while (true)
{
BasicDeliverEventArgs ea = null;
try
{
ea = consumer.Queue.Dequeue();
}
catch (EndOfStreamException endOfStreamException)
{
Trace.WriteLine(endOfStreamException);
}
if (ea == null) break;
var body = ea.Body;
var receivedMessage = _serializer.Deserialie<NotificationMessage>(body);
Trace.WriteLine(
string.Format(
"Message Received: {0} From: {1}, To: {2} on Thread: {3} with CorrelationId: {4} and DeliveryTag: {5}",
receivedMessage.Message, receivedMessage.Source, receivedMessage.Target,
Thread.CurrentThread.ManagedThreadId, ea.BasicProperties.CorrelationId, ea.DeliveryTag));
Thread.Sleep(300);
channel.BasicAck(ea.DeliveryTag, false);
}
}
}
}
示例14: ReceiveDotNetObjects
private static void ReceiveDotNetObjects(IModel model)
{
model.BasicQos(0, 1, false);
QueueingBasicConsumer consumer = new QueueingBasicConsumer(model);
model.BasicConsume(CommonService.DotNetObjectQueueName, false, consumer);
while (true)
{
BasicDeliverEventArgs deliveryArguments = consumer.Queue.Dequeue() as BasicDeliverEventArgs;
string objectType = deliveryArguments.BasicProperties.Type;
Type t = Type.GetType(objectType);
String jsonified = Encoding.UTF8.GetString(deliveryArguments.Body);
object rawObject = JsonConvert.DeserializeObject(jsonified, t);
Console.WriteLine("Object type: {0}", objectType);
if (rawObject.GetType() == typeof(Customer))
{
Customer customer = rawObject as Customer;
Console.WriteLine("Customer name: {0}", customer.Name);
}
else if (rawObject.GetType() == typeof(NewCustomer))
{
NewCustomer newCustomer = rawObject as NewCustomer;
Console.WriteLine("NewCustomer name: {0}", newCustomer.Name);
}
model.BasicAck(deliveryArguments.DeliveryTag, false);
}
}
示例15: Main
static void Main(string[] args)
{
var exchg = "socketIOdemo";
var queue = "socketIOdemoNetQ";
var ser = new JavaScriptSerializer();
var factory = new ConnectionFactory();
factory.Protocol = Protocols.FromEnvironment();
factory.HostName = "localhost";
using (var con = factory.CreateConnection())
using (var mod = con.CreateModel())
{
mod.QueueDeclare(queue, true, false, false, null);
mod.ExchangeDeclare(exchg, ExchangeType.Fanout, true);
mod.QueueBind(queue, exchg, string.Empty);
var consumer = new QueueingBasicConsumer(mod);
mod.BasicConsume(queue, false, consumer);
Console.WriteLine("Waiting for messages...");
while (true)
{
var e = (BasicDeliverEventArgs)consumer.Queue.Dequeue();
mod.BasicAck(e.DeliveryTag, false);
var props = e.BasicProperties;
byte[] body = e.Body;
var msg = ser.Deserialize<Message>(Encoding.UTF8.GetString(body));
Console.WriteLine(DateTime.Now.ToShortTimeString()+">> " + msg.body);
}
}
}