当前位置: 首页 > news >正文

揭阳专业网站制作公司工程公司有哪些职位

揭阳专业网站制作公司,工程公司有哪些职位,浙江建设信息港 官网,建设银行网站账户注销介绍 RabbitMQ是一个开源的消息队列系统#xff0c;实现了高级消息队列协议#xff08;AMQP#xff09;。 #x1f340;RabbitMQ起源于金融系统#xff0c;现在广泛应用于各种分布式系统中。它的主要功能是在应用程序之间提供异步消息传递#xff0c;实现系统间的解耦和…介绍 RabbitMQ是一个开源的消息队列系统实现了高级消息队列协议AMQP。 RabbitMQ起源于金融系统现在广泛应用于各种分布式系统中。它的主要功能是在应用程序之间提供异步消息传递实现系统间的解耦和消息的可靠传递。RabbitMQ使用Erlang语言开发支持多种客户端语言如Python、Ruby、.NET、Java等。 此外RabbitMQ具有以下特点 易用性提供了简单易用的API使得生产者和消费者可以方便地发送和接收消息。扩展性可以水平扩展以处理大量的消息支持集群部署来提高系统的吞吐量和可用性。高可用性通过镜像队列等机制保证消息不会因服务器故障而丢失确保了系统的稳健运行。多种交换模式支持直接交换、扇形交换、主题交换和头交换等多种交换模式满足不同的消息路由需求。多协议支持除了AMQP协议还支持STOMP等其他消息协议。 在docker中部署RabbitMQ 首先在dockerHub中找到RabbitMQ的镜像 rabbitmq - 官方图片 (docker.com) 执行命令拉取镜像 docker pull rabbitmq 镜像拉取完成之后启动镜像 docker run -d -p 5672:5672 -p 15672:15672 --name rabbitmq rabbitmq 此时我们打开 http://localhost:15672/会发现无法访问这是因为管理插件还未被激活 通过docker ps -a查看部署的RabbitMQ容器id在通过使用命令 docker exec -it 容器id /bin/bash  进入容器内部再运行rabbitmq-plugins enable rabbitmq_management 此时就可以打开管理插件了第一次使用 RabbitMQ 管理界面需要使用默认的用户名和密码 guest/guest来登录 消息队列简单模式直连交换机 simple模式是RabbitMQ最简单的一种模式如下图所示只有一个生产者一个消费者和一个队列 生产者和消费者在发送和接受消息时只需要指定队列名而不需要指定发送到哪个Exchange 生产者代码 class MyClass {public static void Main(string[] args){var factory new ConnectionFactory();factory.HostName localhost; //RabbitMQ服务在本地运行factory.UserName guest; //用户名factory.Password guest; //密码//创建连接using (var connection factory.CreateConnection()){//创建通道using (var channel connection.CreateModel()){//声明一个名称为hello的消息队列channel.QueueDeclare(hello, false, false, false, null); for (int i 0; i 5; i){string message Hello Word ! i; //传递的消息内容var body Encoding.UTF8.GetBytes(message);//此处的参数hello 就对应的就是上面声明的消息队列的路由键channel.BasicPublish(, hello, null, body); //开始传递Console.WriteLine(已发送 {0}, message);}}}} } 消费者代码自动模式 class MyClass {static void Main(string[] args){//创建连接工厂var factory new ConnectionFactory();factory.HostName localhost;factory.UserName guest;factory.Password guest;//创建连接using (var connection factory.CreateConnection()){//创建通道using (var channel connection.CreateModel()){//声明队列channel.QueueDeclare(hello, false, false, false, null);//事件的基本消费者var consumer new EventingBasicConsumer(channel);consumer.Received (model, ea) {var body ea.Body.ToArray();var message Encoding.UTF8.GetString(body);Console.WriteLine(已接收 {0}, message);//发送消息确认信号手动确认 //channel.BasicAck(ea.DeliveryTag,false);};//当 autoAck设置为true时也就是自动确认模式一旦消息队列将消息发送给消息消费者后就会从内存中将这个消息删除。//当autoAck设置为false时也就是手动模式如果此时的有一个消费者宕机消息队列就会将这条消息继续发送给其他的消费者这样数据在消息消费者集群的环境下就不会不丢失了。channel.BasicConsume(hello, true, consumer);Console.ReadKey();}}} } 在消费者代码中要注意的是autoAck设置为true时也就是自动确认模式的时候要去掉手动发送确认信号代码channel.BasicAck(ea.DeliveryTag,false);   代码调试 在代码执行到 channel.QueueDeclare(hello, false, false, false, null); 声明一个消息队列时在RabbitMQ的可视化界面就可以看见多了一个名称为hello的消息队列 当执行完五次消息传递时点击上图的hello消息队列Messages:设置为5然后点击Get Messages就可以看到传递过来的5条消息队列了 此时我们执行消费者代码因为autoAck设置为true了当消息队列将消息发送给消费者后就会立马将消息删除此时再点击Get Messages就会提示Queue is empty 消费者代码手动模式 在手动模式中我们将原来声明的队列删除调然后将生产者与消费者的声明队列代码中的第二个参数都改为true意味着这个队列是持久的。在 RabbitMQ 服务器重启之后持久的队列和它的消息都不会丢失 channel.QueueDeclare(hello, true, false, false, null); 然后添加一行代码设置当前消费者的预取模式为只预取一条消息 channel.BasicQos(0, 1, false); 接着是 发送消息确认信号 与 开启手动确认模式 channel.BasicAck(ea.DeliveryTag,false); channel.BasicConsume(hello, false, consumer); 要注意的地方是一定要在结尾处加上下方代码否则可能会出现还没发送消息确认信号进程就结束了这时就会发现将接收到的helloword打印到控制台了去RabbitMQ可视乎管理界面发现事件还未被消耗掉。 Console.ReadKey(); static void Main(string[] args){//创建连接工厂var factory new ConnectionFactory();factory.HostName localhost;factory.UserName guest;factory.Password guest;//创建连接using (var connection factory.CreateConnection()){//创建通道using (var channel connection.CreateModel()){//声明队列channel.QueueDeclare(hello, true, false, false, null);channel.BasicQos(0, 1, false);//事件的基本消费者var consumer new EventingBasicConsumer(channel);consumer.Received (model, ea) {var body ea.Body.ToArray();var message Encoding.UTF8.GetString(body);Console.WriteLine(已接收 {0}, message);//发送消息确认信号手动确认 channel.BasicAck(ea.DeliveryTag,false);};//当 autoAck设置为true时也就是自动确认模式一旦消息队列将消息发送给消息消费者后就会从内存中将这个消息删除。//当autoAck设置为false时也就是手动模式如果此时的有一个消费者宕机消息队列就会将这条消息继续发送给其他的消费者这样数据在消息消费者集群的环境下就不会不丢失了。channel.BasicConsume(hello, false, consumer);Console.ReadKey();}}} 代码调试 按照上面改成手动模式后消费者只预取一条消息如下图0、1、2被消费掉了此时再去RabbitMQ的可视乎管理界面点击GetMessage只剩下3、4的消息内容了
http://www.tj-hxxt.cn/news/226201.html

相关文章:

  • 网站建设宣传文案艾宗建设计公司网站
  • 小说网页网站建设如何用wordpress查看搭建的站点
  • 哪些网做网站比较好网页设计论文题目什么样的好写
  • 云南网站建设定做网站建设的发展
  • kuake自助建站系统官网企业管理10大系统
  • 章丘营销型网站建设wordpress 加入引导页
  • 数字域名做网站企业网站设计方式
  • 做网站新手流程株洲在线网站的目标客户
  • 小清新博客网站门户类网站前台
  • 开发网站如何选需要怎么做网站源代码
  • 申请网站空间就是申请域名宁波市住房和城乡建设局网站
  • seo入门黑帽培训教程河北网站优化
  • 网站建设合集外贸流程全步骤流程图
  • 网站建设算无形资产吗在百度做推广送网站好吗
  • 宿州网站建设设计公司皋兰县建设局网站
  • 焦作网站开发公司郴州住房和城乡建设部网站
  • 小企网站建设解决方案wordpress 源码出售
  • 已有网站做app需要多少钱大连2021建设网
  • 网站友情链接怎样做网站步骤
  • asp学校网站系统申请阿里巴巴网站首页
  • 上海网站建设公司招聘企业公司黄页大全
  • 哪个公司建网站网站地图怎么用
  • 手机评测网站哪个网站是专门做招商的平台
  • 提高网站订单转化率大兴网站开发网站建设哪家好
  • dw网站建设心理学网站的建设
  • 大连网站关键词推广网站建设公司的市场定位
  • 什么对网站建设起到计划和指导作用品牌网站设计图片
  • se 网站优化一个网站是怎么建立的
  • 网站在哪里购买如何注册网站名称
  • 免费的网站或软件江西网站建设技术