[c#]RabbitMQ的简单使用
来源:互联网 发布:mysql修改数据的语句 编辑:程序博客网 时间:2024/06/05 15:02
摘要
Message Queue消息队列,简称MQ,是一种应用程序对应用程序的通信方法,应用程序通过读写出入队列的消息来通信,而无需专用连接来链接它们。消息传递指的是程序之间通过在消息中发送数据进行通信,而不是通过直接调用彼此通信。
MQ是消费-生产者模型的一个典型代表,一端往消息队列中不断写入消息,而另一端则可以读取或者订阅队列中的消息。
安装
官网地址:http://www.rabbitmq.com/download.html。
下载后,需要安装RabbitMQ服务。如果没有Erlang环境会弹出下面的提示:
下载Erlang环境并安装
地址:http://www.erlang.org/downloads
然后安装RabbitMQ,安装成功后会在服务中看到该服务。
一个例子
新建一个控制台应用程序,并使用Nuget引入RabbitMQ
代码如下:
当type等于1时,客户端为生产者,2时为消费者
/// <summary> /// RabbitMQ /// </summary> class Program { static void Main(string[] args) { string type = Console.ReadLine(); //生产者 if (type=="1") { ConnectionFactory factory = new ConnectionFactory(); factory.HostName = "127.0.0.1"; //默认端口 factory.Port = 5672; using (IConnection conn = factory.CreateConnection()) { using (IModel channel = conn.CreateModel()) { //在MQ上定义一个持久化队列,如果名称相同不会重复创建 channel.QueueDeclare("MyRabbitMQ", true, false, false, null); while (true) { string message = string.Format("Message_{0}", Console.ReadLine()); byte[] buffer = Encoding.UTF8.GetBytes(message); IBasicProperties properties = channel.CreateBasicProperties(); properties.DeliveryMode = 2; channel.BasicPublish("", "MyRabbitMQ", properties, buffer); Console.WriteLine("消息发送成功:" + message); } } } } else { //消费者 ConnectionFactory factory = new ConnectionFactory(); factory.HostName = "127.0.0.1"; //默认端口 factory.Port = 5672; using (IConnection conn = factory.CreateConnection()) { using (IModel channel = conn.CreateModel()) { //在MQ上定义一个持久化队列,如果名称相同不会重复创建 channel.QueueDeclare("MyRabbitMQ", true, false, false, null); //输入1,那如果接收一个消息,但是没有应答,则客户端不会收到下一个消息 channel.BasicQos(0, 1, false); Console.WriteLine("Listening..."); //在队列上定义一个消费者 QueueingBasicConsumer consumer = new QueueingBasicConsumer(channel); //消费队列,并设置应答模式为程序主动应答 channel.BasicConsume("MyRabbitMQ", false, consumer); while (true) { //阻塞函数,获取队列中的消息 BasicDeliverEventArgs ea = (BasicDeliverEventArgs)consumer.Queue.Dequeue(); byte[] bytes = ea.Body; string str = Encoding.UTF8.GetString(bytes); Console.WriteLine("队列消息:" + str.ToString()); //回复确认 channel.BasicAck(ea.DeliveryTag, false); } } } } } }
测试
启动生产者
启动消费者
使用生产者入队,1,2,3,4,5,6,7,8
消费者
参考文章
http://www.cnblogs.com/qy1141/p/4054135.html?utm_source=tuicool&utm_medium=referral
- 博客地址:http://www.cnblogs.com/wolf-sun/
博客版权:如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。
阅读全文
0 0
- [c#]RabbitMQ的简单使用
- rabbitmq的简单使用(1)
- rabbitmq的简单使用(2)
- rabbitmq的简单使用(3)
- rabbitmq简单使用
- rabbitmq 简单使用
- RabbitMQ的简单认识
- linux下rabbitmq SimpleAmqpClient客户端的使用的简单例子
- RabbitMQ(二) java简单的实现RabbitMQ
- 简单的方法使用zabbix监控rabbitmq消息队列堵塞
- 关于RabbitMQ-C入门使用需要注意的几个问题
- RabbitMQ的使用
- rabbitmq的命令使用
- rabbitmq 的命令使用
- RabbitMQ的使用
- celery、rabbitmq的使用
- RabbitMQ的使用总结
- RabbitMQ的使用场景
- CentOS安装MariaDB的方法
- select各种获取值设置值得方法 js和jquery
- Leetcode54. Spiral Matrix
- DOM树、RenderObject树、RenderLayer树
- 我是如何一步一步渗透校园网服务器的
- [c#]RabbitMQ的简单使用
- Java 内存溢出(java.lang.OutOfMemoryError)的常见情况和处理方式总结 java.lang.OutOfMemoryError这个错误我相信大部分开发人员都有遇到过,产生该错
- 数据库的发展史
- TCP中的RST标志(Reset)详解
- Redis做实时排行榜
- SQLServer的感想
- 多个接口的案例
- 公众号门店开发,用腾讯地图api获取门店地址的经纬度
- first blog