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

网站加载速度慢的原因国际新闻最新消息今天2024年

网站加载速度慢的原因,国际新闻最新消息今天2024年,岳阳建网站,网页开发背景怎么写文章目录 交换机fanoutDirecttopicHeadersRPC 交换机 **交换机 **是消息队列中的一个组件#xff0c;其作用类似于网络路由器。它负责将我们发送的消息转发到相应的目标#xff0c;就像快递站将快递发送到对应的站点#xff0c;或者网络路由器将网络请求转发到相应的服务器… 文章目录 交换机fanoutDirecttopicHeadersRPC 交换机 **交换机 **是消息队列中的一个组件其作用类似于网络路由器。它负责将我们发送的消息转发到相应的目标就像快递站将快递发送到对应的站点或者网络路由器将网络请求转发到相应的服务器或客户端一样。交换机的主要功能是提供转发消息的能力根据消息的路由规则将消息投递到合适的队列或绑定的消费者。 我们可以理解为如果说一个快递站已经承受不了那么多的快递了就建多个快递站。 fanout 扇出广播 特点消息会被转发到所有绑定到该交换机的队列 场景:很适用于发布订阅的场景比如写日志可以多个系统间共享 示例场景 生产者代码 package com.yupi.springbootinit.mq;import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory;import java.util.Scanner;public class FanoutProducer {// 交换机名字private static final String EXCHANGE_NAME fanout-exchange;public static void main(String[] argv) throws Exception {ConnectionFactory factory new ConnectionFactory();factory.setHost(localhost);try (Connection connection factory.newConnection();Channel channel connection.createChannel()) {// 创建交换机channel.exchangeDeclare(EXCHANGE_NAME, fanout);Scanner scanner new Scanner(System.in);while (scanner.hasNext()) {String message scanner.nextLine();channel.basicPublish(EXCHANGE_NAME, , null, message.getBytes(UTF-8));System.out.println( [x] Sent message );}}} }消费者代码 package com.yupi.springbootinit.mq;import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.DeliverCallback;public class FanoutConsumer {//交换机名字private static final String EXCHANGE_NAME fanout-exchange;public static void main(String[] argv) throws Exception {//建立连接ConnectionFactory factory new ConnectionFactory();factory.setHost(localhost);Connection connection factory.newConnection();//创建频道Channel channel1 connection.createChannel();// 声明交换机channel1.exchangeDeclare(EXCHANGE_NAME, fanout);// 创建队列1连接到交换机上String queueName xiaowang_queue;channel1.queueDeclare(queueName, true, false, false, null);channel1.queueBind(queueName, EXCHANGE_NAME, );// 创建队列2,连接到交换机上String queueName2 xiaoli_queue;channel1.queueDeclare(queueName2, true, false, false, null);channel1.queueBind(queueName2, EXCHANGE_NAME, );System.out.println( [*] Waiting for messages. To exit press CTRLC);// 创建交付回调函数1DeliverCallback deliverCallback1 (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [小王] Received message );};// 创建交付回调函数2DeliverCallback deliverCallback2 (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [小李] Received message );};// 开始消费消息队列1channel1.basicConsume(queueName, true, deliverCallback1, consumerTag - { });// 开始消费消息队列2channel1.basicConsume(queueName2, true, deliverCallback2, consumerTag - { });} }Direct 官方教程https://www.rabbitmq.com/tutorials/tutorial-four-java.html 特点消息会根据路由键转发到指定的队列 场景特定的消息只交给特定的系统程序来处理 注意不同队列可以绑定相同的路由键 示例场景 老板在发送消息同时会带上路由键根据路由键找对应的队列来发送 生产者代码 package com.yupi.springbootinit.mq;import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory;import java.util.Scanner;public class DirectProducer {private static final String EXCHANGE_NAME direct-exchange;public static void main(String[] argv) throws Exception {ConnectionFactory factory new ConnectionFactory();factory.setHost(localhost);try (Connection connection factory.newConnection();Channel channel connection.createChannel()) {//声明交换机是directchannel.exchangeDeclare(EXCHANGE_NAME, direct);//输入消息 和 路由键Scanner scanner new Scanner(System.in);while (scanner.hasNext()) {String userInput scanner.nextLine();String[] strings userInput.split( );if (strings.length 1) {continue;}String message strings[0];String routingKey strings[1];//发布消息的时候注意指定路由键channel.basicPublish(EXCHANGE_NAME, routingKey, null, message.getBytes(UTF-8));System.out.println( [x] Sent message with routing: routingKey );}}} }消费者代码 package com.yupi.springbootinit.mq;import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.DeliverCallback;public class DirectConsumer {private static final String EXCHANGE_NAME direct-exchange;public static void main(String[] argv) throws Exception {ConnectionFactory factory new ConnectionFactory();factory.setHost(localhost);Connection connection factory.newConnection();Channel channel connection.createChannel();//声明交换机不过生成者已经声明过了消费者声不声明都可以channel.exchangeDeclare(EXCHANGE_NAME, direct);// 创建队列String queueName xiaoyu_queue;channel.queueDeclare(queueName, true, false, false, null);channel.queueBind(queueName, EXCHANGE_NAME, xiaoyu); //指定2交换机和路由键// 创建队列随机分配一个队列名称String queueName2 xiaopi_queue;channel.queueDeclare(queueName2, true, false, false, null);channel.queueBind(queueName2, EXCHANGE_NAME, xiaopi);System.out.println( [*] Waiting for messages. To exit press CTRLC);DeliverCallback xiaoyuDeliverCallback (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [xiaoyu] Received delivery.getEnvelope().getRoutingKey() : message );};DeliverCallback xiaopiDeliverCallback (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [xiaopi] Received delivery.getEnvelope().getRoutingKey() : message );};channel.basicConsume(queueName, true, xiaoyuDeliverCallback, consumerTag - {});channel.basicConsume(queueName2, true, xiaopiDeliverCallback, consumerTag - {});} }topic 官方教程https://www.rabbitmq.com/tutorials/tutorial-five-java.html 特点消息会根据一个模糊的路由键转发到指定的队列 场景:特定的一类消息可以交给特定的一类系统程序来处理 规则 :匹配一个单词比如.orange那么 abc.orange、ikun.orange 都能匹配#:匹配0个或多个单词比如orange.#那么orangeorange.abc.ikun都能匹配 应用场景 老板要下发一个任务让多个组来处理 生产者代码 package com.yupi.springbootinit.mq;import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory;import java.util.Scanner;public class TopicProducer {private static final String EXCHANGE_NAME topic-exchange;public static void main(String[] argv) throws Exception {ConnectionFactory factory new ConnectionFactory();factory.setHost(localhost);try (Connection connection factory.newConnection();Channel channel connection.createChannel()) {channel.exchangeDeclare(EXCHANGE_NAME, topic);Scanner scanner new Scanner(System.in);while (scanner.hasNext()) {String userInput scanner.nextLine();String[] strings userInput.split( );if (strings.length 1) {continue;}String message strings[0];String routingKey strings[1];channel.basicPublish(EXCHANGE_NAME, routingKey, null, message.getBytes(UTF-8));System.out.println( [x] Sent message with routing: routingKey );}}} }消费者代码 package com.yupi.springbootinit.mq;import com.rabbitmq.client.Channel; import com.rabbitmq.client.Connection; import com.rabbitmq.client.ConnectionFactory; import com.rabbitmq.client.DeliverCallback;public class TopicConsumer {private static final String EXCHANGE_NAME topic-exchange;public static void main(String[] argv) throws Exception {ConnectionFactory factory new ConnectionFactory();factory.setHost(localhost);Connection connection factory.newConnection();Channel channel connection.createChannel();channel.exchangeDeclare(EXCHANGE_NAME, topic);// 创建队列String queueName frontend_queue;channel.queueDeclare(queueName, true, false, false, null);channel.queueBind(queueName, EXCHANGE_NAME, #.前端.#);// 创建队列String queueName2 backend_queue;channel.queueDeclare(queueName2, true, false, false, null);channel.queueBind(queueName2, EXCHANGE_NAME, #.后端.#);// 创建队列String queueName3 product_queue;channel.queueDeclare(queueName3, true, false, false, null);channel.queueBind(queueName3, EXCHANGE_NAME, #.产品.#);System.out.println( [*] Waiting for messages. To exit press CTRLC);DeliverCallback xiaoaDeliverCallback (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [xiaoa] Received delivery.getEnvelope().getRoutingKey() : message );};DeliverCallback xiaobDeliverCallback (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [xiaob] Received delivery.getEnvelope().getRoutingKey() : message );};DeliverCallback xiaocDeliverCallback (consumerTag, delivery) - {String message new String(delivery.getBody(), UTF-8);System.out.println( [xiaoc] Received delivery.getEnvelope().getRoutingKey() : message );};channel.basicConsume(queueName, true, xiaoaDeliverCallback, consumerTag - {});channel.basicConsume(queueName2, true, xiaobDeliverCallback, consumerTag - {});channel.basicConsume(queueName3, true, xiaocDeliverCallback, consumerTag - {});} }这样生产者发消息前端.后端 就可以匹配到前端和后端两个队列 Headers 可以根据headers中的内容来指定发送到哪个队列由于性能差比较复杂一般不推荐使用 RPC 支持用消息队列来模拟RPC的调用但是一般没必要直接用 Dubbo、GRPC 等 RPC 框架就好了。
http://www.zqtcl.cn/news/438623/

相关文章:

  • 网站建设到运营赚钱上海网络哪家比较好
  • 做网站要求高吗超炫网站
  • 贵卅省住房和城乡建设厅网站怎么快速仿wordpress站
  • 苏州网站建设排名clef wordpress
  • 罗定建设局网站汽车装饰网站源码
  • 网站用什么切版商城网站怎么建
  • 设计网站公司多少钱wordpress获取所有标签
  • 怎么看一个网站是哪个公司做的电子商务网站设计与规划
  • 邯郸哪里做网站优化网站建设如何排版
  • 济南网站建设设计制作公司找人做网站价格
  • 阿里网站年费续费怎么做分录大型的网站开发
  • 中山做网站费用广西壮族自治区住房和建设厅网站
  • vs2015做网站如何添加控件建设网站计划 ppt
  • 简述网站设计流程贵阳小程序开发软件公司
  • 营销网站建设的原则设计网站页面要注意什么
  • 上海怎么做网站国外网站 设计
  • 开发公司土地评估费计入土地价款优化搜狐的培训
  • 网站建设佰首选金手指三360怎么免费建网站
  • 网站万能密码修复苏州市建设中心网站
  • 如何搭建php网站网站制作的前期主要是做好什么工作
  • 站酷设计网站官网站不能正常显示出现后台代码
  • 网站域名改版微信公众号免费开通
  • 代网站建设如何对网站进行爬虫
  • 做公司+网站建设价格低网站两边广告代码
  • 服务器上怎做网站提升网页优化排名
  • 上海网站推广模板景德镇网站开发
  • 艺术风格网站成都软件开发公司排行榜
  • 搭建个人网站赚钱网站开发应该注意什么
  • 医药招商网站建设做招聘网站都需要什么手续
  • 通州网站建设电话外贸订单网站推广