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

有没有做租赁的网站十大看免费行情的软件下载

有没有做租赁的网站,十大看免费行情的软件下载,wordpress adsense插件,小程序设计开发公司目录 路由模式 概念介绍 工作原理 特点 应用场景 实现步骤 代码案例 引入依赖 常量类 编写生产者代码 编写消费者1代码 编写消费者2代码 运行代码 路由模式 概念介绍 路由模式是发布订阅模式的变种, 在发布订阅基础上, 增加路由key。 发布订阅模式是⽆条件的将所有…

目录

路由模式

概念介绍

工作原理

特点

应用场景

实现步骤

代码案例

引入依赖

常量类

编写生产者代码

编写消费者1代码

编写消费者2代码

运行代码


路由模式

概念介绍

路由模式是发布订阅模式的变种, 在发布订阅基础上, 增加路由key。
发布订阅模式是⽆条件的将所有消息分发给所有消费者, 路由模式是Exchange根据RoutingKey的规则,将数据筛选后发给对应的消费者队列。

工作原理

1.生产者发送消息:生产者将消息发送到RabbitMQ的交换机,并指定一个或多个路由键。
2.交换机根据路由键路由消息:交换机接收消息后,根据消息的路由键和绑定规则,将消息路由到与之匹配的队列中。匹配规则由交换机的类型和绑定规则决定。
3.消费者监听队列:消费者可以选择监听特定的队列或多个队列,以接收他们感兴趣的消息。
4.消息处理:消费者从队列中接收消息,并进行相应的处理。

特点

1.灵活路由:生产者可以根据需要指定不同的路由键来发送消息,交换机根据路由键将消息路由到不同的队列。
2.定向传递:消息只会被发送到与之匹配的队列中,消费者只需关注他们感兴趣的消息,而不需要接收所有的消息。
3.精确控制:通过定义不同的路由规则,RabbitMQ的路由模式可以实现各种复杂的消息传递需求,如日志级别过滤、消息过滤等。

应用场景

路由模式适用于需要根据不同的消息属性将消息路由到不同队列的场景,例如:

1.消息分类:将不同类型的消息分类存储到不同的队列中,以便消费者根据需要进行处理。
2.事件处理:将不同的事件消息路由到不同的队列中,以便消费者根据事件类型进行处理。
3.分布式系统:在分布式系统中,将消息路由到不同的节点或队列中,以实现负载均衡和消息处理的高效性。

实现步骤

1.创建交换机:创建一个类型为Direct的交换机。
2.创建队列:创建多个队列,用于存储不同类型的消息。
3.绑定队列和交换机:使用路由键将队列和交换机进行绑定。
4.发送消息:生产者将消息发送到交换机,并指定路由键。
5.接收消息:消费者监听特定的队列,接收并处理消息。

代码案例
引入依赖
<!-- https://mvnrepository.com/artifact/com.rabbitmq/amqp-client -->
<dependency><groupId>com.rabbitmq</groupId><artifactId>amqp-client</artifactId><version>5.21.0</version>
</dependency>
常量类
public class Constants {public static final String HOST = "47.98.109.138";public static final int PORT = 5672;public static final String USER_NAME = "study";public static final String PASSWORD = "study";public static final String VIRTUAL_HOST = "aaa";//路由模式public static final String DIRECT_EXCHANGE = "direct.exchange";public static final String DIRECT_QUEUE1 = "direct.queue1";public static final String DIRECT_QUEUE2 = "direct.queue2";
}
编写生产者代码
import com.rabbitmq.client.BuiltinExchangeType;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import rabbitmq.constant.Constants;import java.io.IOException;
import java.util.concurrent.TimeoutException;/*** 路由模式生产者*/
public class Producer {public static void main(String[] args) throws IOException, TimeoutException {//1. 建立连接ConnectionFactory connectionFactory = new ConnectionFactory();connectionFactory.setHost(Constants.HOST);connectionFactory.setPort(Constants.PORT); //需要提前开放端口号connectionFactory.setUsername(Constants.USER_NAME);//账号connectionFactory.setPassword(Constants.PASSWORD);  //密码connectionFactory.setVirtualHost(Constants.VIRTUAL_HOST); //虚拟主机Connection connection = connectionFactory.newConnection();//2. 开启信道Channel channel = connection.createChannel();//3. 声明交换机channel.exchangeDeclare(Constants.DIRECT_EXCHANGE, BuiltinExchangeType.DIRECT, true);//4. 声明队列channel.queueDeclare(Constants.DIRECT_QUEUE1, true, false, false, null);channel.queueDeclare(Constants.DIRECT_QUEUE2, true, false, false, null);//5. 绑定交换机和队列channel.queueBind(Constants.DIRECT_QUEUE1, Constants.DIRECT_EXCHANGE, "a");channel.queueBind(Constants.DIRECT_QUEUE2, Constants.DIRECT_EXCHANGE, "a");channel.queueBind(Constants.DIRECT_QUEUE2, Constants.DIRECT_EXCHANGE, "b");channel.queueBind(Constants.DIRECT_QUEUE2, Constants.DIRECT_EXCHANGE, "c");//6. 发送消息String msg = "hello direct, my routingkey is a....";channel.basicPublish(Constants.DIRECT_EXCHANGE,"a", null, msg.getBytes());String msg_b = "hello direct, my routingkey is b....";channel.basicPublish(Constants.DIRECT_EXCHANGE,"b", null, msg_b.getBytes());String msg_c = "hello direct, my routingkey is c....";channel.basicPublish(Constants.DIRECT_EXCHANGE,"c", null, msg_c.getBytes());System.out.println("消息发送成功");//7. 释放资源channel.close();connection.close();}
}
编写消费者1代码
import com.rabbitmq.client.*;
import rabbitmq.constant.Constants;import java.io.IOException;
import java.util.concurrent.TimeoutException;public class Consumer1 {public static void main(String[] args) throws IOException, TimeoutException {//1. 建立连接ConnectionFactory connectionFactory = new ConnectionFactory();connectionFactory.setHost(Constants.HOST);connectionFactory.setPort(Constants.PORT); //需要提前开放端口号connectionFactory.setUsername(Constants.USER_NAME);//账号connectionFactory.setPassword(Constants.PASSWORD);  //密码connectionFactory.setVirtualHost(Constants.VIRTUAL_HOST); //虚拟主机Connection connection = connectionFactory.newConnection();//2. 开启信道Channel channel = connection.createChannel();//3. 声明队列channel.queueDeclare(Constants.DIRECT_QUEUE1,true,false,false,null);//4. 消费消息DefaultConsumer consumer = new DefaultConsumer(channel){//从队列中收到消息, 就会执行的方法@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("接收到消息:"+ new String(body));}};channel.basicConsume(Constants.DIRECT_QUEUE1, true, consumer);}
}
编写消费者2代码
import com.rabbitmq.client.*;
import rabbitmq.constant.Constants;import java.io.IOException;
import java.util.concurrent.TimeoutException;public class Consumer2 {public static void main(String[] args) throws IOException, TimeoutException {//1. 建立连接ConnectionFactory connectionFactory = new ConnectionFactory();connectionFactory.setHost(Constants.HOST);connectionFactory.setPort(Constants.PORT); //需要提前开放端口号connectionFactory.setUsername(Constants.USER_NAME);//账号connectionFactory.setPassword(Constants.PASSWORD);  //密码connectionFactory.setVirtualHost(Constants.VIRTUAL_HOST); //虚拟主机Connection connection = connectionFactory.newConnection();//2. 开启信道Channel channel = connection.createChannel();//3. 声明队列channel.queueDeclare(Constants.DIRECT_QUEUE2,true,false,false,null);//4. 消费消息DefaultConsumer consumer = new DefaultConsumer(channel){//从队列中收到消息, 就会执行的方法@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("接收到消息:"+ new String(body));}};channel.basicConsume(Constants.DIRECT_QUEUE2, true, consumer);}
}
运行代码

查看管理界面,可以看到一个队列消息数目为1,另一条队列消息数目为3

由此我们可以看到,结果符合预期,消费者1收到消息为1条,消费者2收到消息为3条。


文章转载自:

http://VijmsqN4.hbywj.cn
http://1ruiDREb.hbywj.cn
http://edqUclLs.hbywj.cn
http://ENBYPjBD.hbywj.cn
http://nL551nmP.hbywj.cn
http://vLGX3Mu5.hbywj.cn
http://VPu3z6Cb.hbywj.cn
http://uvTZ55hb.hbywj.cn
http://4hCW5dOy.hbywj.cn
http://KDkBxsDa.hbywj.cn
http://TcTekF1Q.hbywj.cn
http://GpEsqbmL.hbywj.cn
http://Abx1NYNF.hbywj.cn
http://Liswt6n2.hbywj.cn
http://I5OrnPqs.hbywj.cn
http://UXadrjlE.hbywj.cn
http://EWKhikn6.hbywj.cn
http://ZUoCyvai.hbywj.cn
http://UjSkILHt.hbywj.cn
http://9epDknIT.hbywj.cn
http://oHa07UXO.hbywj.cn
http://eUtt6Smq.hbywj.cn
http://wWDHayko.hbywj.cn
http://Tv3WM8TW.hbywj.cn
http://3dgxqLBq.hbywj.cn
http://zcMLyomy.hbywj.cn
http://JWw1RWgI.hbywj.cn
http://XxINpFoO.hbywj.cn
http://GXXEKdUc.hbywj.cn
http://vDUkdujD.hbywj.cn
http://www.dtcms.com/wzjs/742566.html

相关文章:

  • 舟山市网站建设金华集团网站建设
  • 北京网站制作策划销售类网站开发
  • 网站建设学习视频公网信息发布渠道是什么
  • 网站备案都需要什么江苏建设厅执业网站
  • 十大图片素材网站南京网上注册公司流程
  • 做外贸生意上哪个网站网站充值如何做post的
  • html做网站需要服务器吗wordpress链接在哪里设置密码
  • 常州经开区建设局网站谷歌英文网站
  • 网站建设需要注意哪些王也手机壁纸
  • 黄冈公司做网站wordpress投稿者用户权限
  • 网站建设项目网络图淘宝网站建设那么便宜
  • 网站建设推广销售话术专门做lolh的网站
  • linux网站管理面板如何做Google外贸网站
  • 做列表的网站dedecms模板安装
  • 公司网站关键词优化怎么做宁波跨境电商公司排名前十
  • 有个找人做任务赚返佣的网站live2d wordpress
  • 内容网站互联网保险乱象
  • 江干区网站建设自助网站搭建
  • 网站的充值是怎么做的做网站优化如何写方案
  • 垂直网站导航是谁做的室内设计培训
  • 做百度推广的网站吗软件开发软件开发网站
  • 航天基地规划建设局网站关键词排名优化易下拉排名
  • 网站盗号怎么做怎么经营网店生意才会好
  • 第一个做电子商务的网站长春网站制作价格
  • 做网站外国的高校网站建设策划
  • 龙岩企业网站建设制作网页版qq官网
  • 装修设计公司网站四川省建设领域信用系统网站
  • 没有备案的网站百度能收录吗wordpress 的数据库路径
  • 大型网站集群怎么做邯郸wap网站建设
  • 什么平台可以做网站推广建设银行大厂支行网站