netcore使用RabbitMQ入门--win10开发环境(实践篇无理论)
1.进入rabbitMQ官网下载安装包
2.点击安装包安装的时候会提示需要先装erlang
点击是会自动跳转到erlang的下载界面如果没有跳转可以直接点击这里下载,根据系统选择下载包
下载完之后双击exe安装包进行安装,一直下一步就行了(如果不想装在c盘那就改一下盘符)
3.装完了erlang,回去找到刚才第一步下载的rabbitMQ的安装包双击安装,一样的一直下一步就行了(中间遇到需要给它网络点确定就可以了)
4.以上步骤完成了rabbitMQ服务的安装,为了方便操作和管理下面我们安装可视化管理界面
4.1打开cmd界面进入rabbitMQ的安装目录下的sbin目录
4.2根据官网步骤执行命令rabbitmq-plugins enable rabbitmq_management
4.3安装成功找到安装目录找到rabbitmq-server.bat双击运行(如果有错就右键以管理员身份运行)出现如下界面
4.4打开浏览器访问http://localhost:15672/
4.5默认用户和密码都是guest直接登录看下结果
代码实现
1,创建demo生产者控制台项目
2,通过nuget安装RabbitMQ.Client
代码里的用户名和密码不能用默认账号不然会报错,所以先去Admin界面添加一个用户如用户名wyb密码123456
添加之后默认没有连接权限需要去设置
3,在主函数Main里面写生产者代码这里先生产5条消息只是简单的demo(特别提醒代码里的端口号是5672不是进入管理地址的15672)
string hostName = "192.168.50.176"; int port = 5672;//默认端口5672;前端界面的端口是15672特别注意不要混淆 string userName = "wyb"; string password = "123456"; string virtualHost = "/"; //创建一个连接工厂 var factory = new ConnectionFactory(); factory.UserName = userName; factory.Password = password; factory.HostName = hostName; factory.Port = port; factory.VirtualHost = virtualHost; //创建一个连接,此时可以在rabbitmq后台Web管理页面中的Connections中看到一个连接生成 //一个连接可以创建多个通道 var connection = factory.CreateConnection(); string queueName = "q1";//队列名称 //创建一个通道 //此时可以在rabbitmq后台Web管理页面中的Channels中看到一个新通道生成 var channel = connection.CreateModel(); //给通道绑定一个队列,队列如果不存在,则会创建新队列,如果队列已存在,那么参数一定要正确,特别是arguments参数,否则会报错 var arguments = new Dictionary<string, object>() { { "x-queue-type", "classic" } }; channel.QueueDeclare(queue: queueName, durable: true, exclusive: false, autoDelete: false, arguments: arguments); //发布5条消息 for (var i = 0; i < 5; i++) { var buffer = Encoding.UTF8.GetBytes(i.ToString()); channel.BasicPublish("", queueName, null, buffer); Console.WriteLine("发布消息:"+i); } channel.Close(); Console.ReadKey();
4,f5运行项目看到如下结果就表示成功
5,同生产者项目一样的步骤创建一下消费者控制台项目(一样nuget安装RabbitMQ.Client)
6,在消费者项目的main函数里写消费者的代码
string hostName = "192.168.50.176"; int port = 5672;//默认端口5672;前端界面的端口是15672特别注意不要混淆 string userName = "wyb"; string password = "123456"; string virtualHost = "/"; //创建一个连接工厂 var factory = new ConnectionFactory(); factory.UserName = userName; factory.Password = password; factory.HostName = hostName; factory.Port = port; factory.VirtualHost = virtualHost; //创建一个连接,此时可以在rabbitmq后台Web管理页面中的Connections中看到一个连接生成 //一个连接可以创建多个通道 var connection = factory.CreateConnection(); string queue = "q1";//队列名称 //创建一个通道 //此时可以在rabbitmq后台Web管理页面中的Channels中看到一个新通道生成 var channel = connection.CreateModel(); //给通道绑定一个队列,队列如果不存在,则会创建新队列,如果队列已存在,那么参数一定要正确,特别是arguments参数,否则会报错 var arguments = new Dictionary<string, object>() { { "x-queue-type", "classic" } }; channel.QueueDeclare(queue: queue, durable: true, exclusive: false, autoDelete: false, arguments: arguments); //channel.BasicQos(2, 2, false);//设置QOS //在通道中定义一个事件消费者 EventingBasicConsumer consumer = new EventingBasicConsumer(channel); consumer.Received += (sender, e) => { var body = e.Body.Span; var message = Encoding.UTF8.GetString(body); Console.WriteLine($"接收到消息:{message}"); Thread.Sleep(500);//暂停一下 //通知消息已被处理,如果没有,那么消息将会被重复消费 channel.BasicAck(e.DeliveryTag, false); }; //ack设置成false,表示不自动提交,那么就需要在消息被消费后,手动调用BasicAck去提交消息 channel.BasicConsume(queue, false, consumer); Console.ReadKey();
7运行消费者项目结果如下
结束
简单操作到此,后面再介绍实际应用