前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >.NET 云原生架构师训练营(模块二 基础巩固 RabbitMQ HelloWorld)--学习笔记

.NET 云原生架构师训练营(模块二 基础巩固 RabbitMQ HelloWorld)--学习笔记

作者头像
郑子铭
发布2021-01-13 16:02:06
2380
发布2021-01-13 16:02:06
举报

2.6.3 RabbitMQ -- HelloWorld

  • 发送端
  • 接收端
  • rabbitmq container
  • 发送信息

https://www.rabbitmq.com/tutorials/tutorial-one-dotnet.html

新建控制台项目 Sender,Receiver

添加 nuget 包:RabbitMQ.Client

发送端

代码语言:javascript
复制
namespace Sender
{
    class Sender
    {
        public static void Main()
        {
            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(" Press [enter] to exit.");
                Console.ReadLine();
            }
        }
    }
}

接收端

代码语言:javascript
复制
namespace Receiver
{
    class Receiver
    {
        public static void Main()
        {
            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 += (model, ea) =>
                {
                    var body = ea.Body.ToArray();
                    var message = Encoding.UTF8.GetString(body);
                    Console.WriteLine(" [x] Received {0}", message);
                };
                channel.BasicConsume(queue: "hello",
                    autoAck: true,
                    consumer: consumer);

                Console.WriteLine(" Press [enter] to exit.");
                Console.ReadLine();
            }
        }
    }
}

rabbitmq container

代码语言:javascript
复制
docker run -d -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management

运行成功后可以访问(localhost 替换为服务器地址)

代码语言:javascript
复制
http://localhost:15672/#/

用户名密码默认为 guest

替换发送端,接收端的 localhost 为服务器地址

发送信息

先启动接收端,再启动发送端

发送多条信息

Sender

代码语言:javascript
复制
channel.QueueDeclare(queue: "hello",
    durable: false, // 持久化
    exclusive: false, // 排它
    autoDelete: false, // 自动删除
    arguments: null);

Console.WriteLine("Please input your message with enter:");
string message = Console.ReadLine();
while (message != "EXIT")
{
    var body = Encoding.UTF8.GetBytes(message);

    channel.BasicPublish(exchange: "",
        routingKey: "hello",
        basicProperties: null,
        body: body);
    Console.WriteLine(" [x] Sent {0}", message);

    Console.WriteLine("Please input your message with enter:");
    message = Console.ReadLine();
}

先启动接收端,再启动发送端

GitHub源码链接:

https://github.com/MINGSON666/Personal-Learning-Library/tree/main/ArchitectTrainingCamp

课程链接

.NET云原生架构师训练营讲什么,怎么讲,讲多久

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-01-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DotNet NB 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 2.6.3 RabbitMQ -- HelloWorld
    • 发送端
      • 接收端
        • rabbitmq container
          • 发送信息
            • GitHub源码链接:
            • 课程链接
            相关产品与服务
            容器服务
            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档