RabbitMQ入门学习系列(二),单生产者消费者

栏目: 后端 · 发布时间: 5年前

内容简介:友情提示​ 安装好Rabbitmq-server,Erlang后,在vs中添加 Rabbitmq.client.建立两个控制台应用,实现单生产者单消费者的模式。​ 我对我的文章负责,发现好多网上的文章 没有实践,都发出来的,让人走很多弯路,如果你在我的文章中遇到无法实现,或者无法走通的。可以直接公众号:爱码农爱生活 留言。必定会再次复查原因。让每一篇 文章的流程都能顺利实现。

友情提示

我对我的文章负责,发现好多网上的文章 没有实践,都发出来的,让人走很多弯路,如果你在我的文章中遇到无法实现,或者无法走通的问题。可以直接在公众号《爱 码农 爱生活 》留言。必定会再次复查原因。让每一篇 文章都能顺利实现。道理讲明白 。原理讲清楚。代码必实现

快速阅读

​ 安装好Rabbitmq-server,Erlang后,在vs中添加 Rabbitmq.client.建立两个控制台应用,实现单生产者单消费者的模式。

友情提示

​ 我对我的文章负责,发现好多网上的文章 没有实践,都发出来的,让人走很多弯路,如果你在我的文章中遇到无法实现,或者无法走通的。可以直接公众号:爱码农爱生活 留言。必定会再次复查原因。让每一篇 文章的流程都能顺利实现。

1.安装rabittmq

RabbitMQ入门学习系列(二),单生产者消费者

提示没有安装elang,要先下载安装erlang

2.下载安装erlang

会自动打开Erlang的下载链接 地址。我的是win7 64位系统,所以我选择下面红框里的这个

RabbitMQ入门学习系列(二),单生产者消费者

3.Erlang和RabbitMq的下载地址备份

今天终于下载下来了。 为了避免以后因为网络问题下不下来,直接备份到百度云

  1. rabbitmq-server-3.7.15.exe 下载地址

链接: https://pan.baidu.com/s/1aTEtVwNvSV58gzbmLncQlA 提取码:3b1x

  1. otp_win64_22.0 -erlang 下载地址

    链接: https://pan.baidu.com/s/1DF_KDKxTAHRGHZj6LYKdaA

提取码:9oy8

4.OTP是啥

​ Open Telecom Platform的缩写,简单理解就是一个框架 ,主要是把通用部分代码和业务代码进行分离。具体想多了解的可以参考: https://www.cnblogs.com/john-d/archive/2010/04/16/1711276.html

5.OTP22的安装

安装OTP22 ,直接打开,安装到自己的程序目录就行。 一直next到结束 。

RabbitMQ入门学习系列(二),单生产者消费者

6.安装RabbitMq-server

直接打开,安装到自己的程序目录就行。 一直next到结束

RabbitMQ入门学习系列(二),单生产者消费者

RabbitMQ入门学习系列(二),单生产者消费者

7.官方的入门教程代码下载

https://github.com/rabbitmq/rabbitmq-tutorials

8.RabbitMQ 入门代码 Hello world

Rabbitmq是一个消息中间件,生产者生产消息放入队列中,消费者从队列中拿消息进行消费。

RabbitMQ入门学习系列(二),单生产者消费者

分别给两个项目安装RabbitMQ.client依赖包。 如果用这种方式安装的话,产生的项目是netcore的

RabbitMQ入门学习系列(二),单生产者消费者

好了,vs打开启动项目

不过遇到vs不能调试的错误了。,记得以前也遇到过这个问题,网上好多人说是把msvsmon.exe从别的地方复制一份就可以了,但是我的不行,最后是通过添加删除程序解决的。

感觉这个错误,好像会出现在多个vs版本的时候会容易出现混乱。

RabbitMQ入门学习系列(二),单生产者消费者

但是发现新建的程序台程序是可以使用的。

这个先不用管了直接转为传统的方式,vs打开项目,Nuget添加RabbitMq.client进行测试

重新在console控制台里操作吧。

9.vs中创建生产者

先安装RabbitMQ.Client

RabbitMQ入门学习系列(二),单生产者消费者

生产者代码:

注意:创建的链接如果是远程服务器,要换成远程服务器的IP地址,我们是用localhost在本地测试

​ 创建完链接以后,再创建信道。大多数的api调用都是在信道中完成的。

​ 最后声明一个队列,把我们要发送的消息发送出去。

​ 消息的内容在队列中存的是了一个字节数组 ,我们一般用Encoding.UTF8.GetBytes

static void Main(string[] args)
 {
     var factory = new ConnectionFactory() { HostName = "localhost" };
     using (var connection = factory.CreateConnection())
     {
         using (var channel = connection.CreateModel())
         {
             channel.QueueDeclare(queue: "hello",
                                  durable: false, exclusive: false, autoDelete: false, arguments: null);
             string message = "hello world";
             var body = Encoding.UTF8.GetBytes(message);
             channel.BasicPublish(exchange: "", routingKey: "hello", basicProperties: null, body: body);
             Console.WriteLine("[x] sent {0}", message);
         }
     }
     Console.WriteLine("");
     Console.ReadLine();
 }

10.消费者

消费者从消息队列中监听消息 ,要保持持续连接

代码:

​ 注意:

1. Console.ReadLine();的位置,要放在channel代码块中。
  1. 流程还是建立连接-》创建信道-》定义队列=》
  2. 因为可能先启动消费者,所以队列也需要进行声明 一下。
  3. 在使用队列时,要保证队列必须存在。
static void Main(string[] args)
{
    var factory = new ConnectionFactory() { HostName = "localhost" };
    using (var connection = factory.CreateConnection())
    {
        using (var channel = connection.CreateModel())
        {
            channel.QueueDeclare(queue: "hello",
                                 durable: false, exclusive: false, autoDelete: false, arguments: null);

            //以下是区别生产者的
            var consumer = new EventingBasicConsumer(channel);
            consumer.Received += (sender, e) =>
            {
                var body = e.Body;
                var message = Encoding.UTF8.GetString(body);
                Console.WriteLine("Received {0}", message);
            };
            channel.BasicConsume(queue: "hello", autoAck: true, consumer: consumer);
            Console.WriteLine("");
            Console.ReadLine();
        }

    }

}

运行效果

RabbitMQ入门学习系列(二),单生产者消费者


以上所述就是小编给大家介绍的《RabbitMQ入门学习系列(二),单生产者消费者》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

大数据供应链

大数据供应链

娜达·R·桑德斯 (Nada R. Sanders) / 丁晓松 / 中国人民大学出版社 / 2015-7-1 / CNY 55.00

第一本大数据供应链落地之道的权威著作,全球顶级供应链管理专家娜达·桑德斯博士聚焦传统供应链模式向大数据转型,助力工业4.0时代智能供应链构建。 在靠大数据驱动供应链处于领先地位的企业中,45% 是零售商,如沃尔玛、亚马逊,而22%是快消企业,如戴尔电脑。他们都前所未有地掌控了自己的供应链。在库存管理、订单履行率、原材料和产品交付上具有更为广阔的视野。利用具有预见性的大数据分析结果,可以使供需......一起来看看 《大数据供应链》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试