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

苏州企业建设网站服务上海松江建设银行网站

苏州企业建设网站服务,上海松江建设银行网站,用dw设计网站怎么做,华资源网站建设一、介绍 RabbitMQ消息传递模型的核心思想是:生产者生产的消息从不会直接发送到队列。实际上,通常生产者甚至不知道这些消息传递到了哪些队列中。相反,生产者只能将消息发送到交换机,交换机工作的内容非常简单,一方…
  一、介绍    

        RabbitMQ消息传递模型的核心思想是:生产者生产的消息从不会直接发送到队列。实际上,通常生产者甚至不知道这些消息传递到了哪些队列中。

       相反,生产者只能将消息发送到交换机,交换机工作的内容非常简单,一方面他接受来自生产者的消息,另一方面他将他们推入队列。交换机必须确切知道如何处理收到的消息。是应该把这些消息放到特定队列还是说把他们放到许多队列还是说应该丢弃他们。这就由交换机来决定。

  二、类型
         1、类型

        总共有以下类型:直接(direct)[路由],主题(topic),标题(headers),扇出(fanout)[发布订阅],

          默认类型[无名类型] 通过("")进行标识

 channel.basicPublish("",TASK_QUEUE_NAME,null,message.getBytes());

          第一个参数是交换机名称,空字符串表示默认或无名的交换机;消息能路由发送到队列中,其实是由routingKey(bindingKey)绑定key指定的,如果它存在的话。

      2、 临时队列

       每当我们连接到Rabbit时,我们都需要一个全新的空队列,为此我们可以创建一个具有随机名称的队列,或者能让服务器为我们选择一个随机队列名称。其次一旦我们断开了消费者连接,队列将被自动删除。

       创建临时队列的方式如下

 String queueName = channel.queueDeclare().getQueue();
     3、绑定(bingings)

       binding其实时exchange和queue之间的桥梁,他告诉我们exchange和哪个队列进行了绑定关系

    4、fanout

        他是将接收到的所有消息广播到他知道的所有队列中

        消费者,另一个复制即可

public class ReceiveLogs01 {//交换机的名称public static final String EXCHANGE_NAME = "logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明一个交换机channel.exchangeDeclare(EXCHANGE_NAME,"fanout");//声明一个队列  临时队列/*** 队列的名称是随机的* 当消费者断开与队列的连接的时候,队列就自动删除*/String queueName = channel.queueDeclare().getQueue();/*** 绑定队列与交换机*/channel.queueBind(queueName,EXCHANGE_NAME,"");System.out.println("等待接收消息,把接收到的消息打印在屏幕上......");//接收消息DeliverCallback deliverCallback = (consumerTag,message) ->{System.out.println("01控制台打印接收到的消息:"+new String(message.getBody()));};CancelCallback cancelCallback = (consumerTag) ->{};channel.basicConsume(queueName,true,deliverCallback,cancelCallback);}
}

   生产者

public class EmitLog {//交换机的名称public static final String EXCHANGE_NAME = "logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明交换机channel.exchangeDeclare(EXCHANGE_NAME,"fanout");Scanner scanner = new Scanner(System.in);while (scanner.hasNext()){String message = scanner.next();channel.basicPublish(EXCHANGE_NAME,"",null,message.getBytes());System.out.println("生产者发出消息:"+message);}}
}

     结果

   5、direct

      消息只去到他绑定的routingKey队列中,支持多重绑定,当exchange的绑定类型是direct,但是他绑定的多个队列的key如果都相同,在这种情况下虽然绑定类型是direct但是他表现的就和fanout有点类似了。

     生产者

public class DirectLogs {//交换机的名称public static final String EXCHANGE_NAME = "direct_logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明交换机channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);Scanner scanner = new Scanner(System.in);while (scanner.hasNext()){String message = scanner.next();channel.basicPublish(EXCHANGE_NAME,"warning",null,message.getBytes());System.out.println("生产者发出消息:"+message);}}
}

   消费者1

public class ReceiveLogs01 {//交换机名称public static final String EXCHANGE_NAME = "direct_logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明一个交换机channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);//声明一个队列channel.queueDeclare("console",false,false,false,null);//绑定队列与交换机channel.queueBind("console",EXCHANGE_NAME,"info");channel.queueBind("console",EXCHANGE_NAME,"warning");DeliverCallback deliverCallback = (consumerTag,message) ->{System.out.println("direct01控制台打印接收到的消息:"+new String(message.getBody()));};CancelCallback cancelCallback = (consumerTag) ->{};channel.basicConsume("console",true,deliverCallback,cancelCallback);}
}

  消费者2

public class ReceiveLogs02 {//交换机名称public static final String EXCHANGE_NAME = "direct_logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明一个交换机channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.DIRECT);//声明一个队列channel.queueDeclare("disk",false,false,false,null);//绑定队列与交换机channel.queueBind("disk",EXCHANGE_NAME,"error");DeliverCallback deliverCallback = (consumerTag,message) ->{System.out.println("direct02控制台打印接收到的消息:"+new String(message.getBody()));};CancelCallback cancelCallback = (consumerTag) ->{};channel.basicConsume("disk",true,deliverCallback,cancelCallback);}
}
      5、topic

           发送到类型是topic交换机的消息的routing_key不能随意写,必须满足一定的要求,它必须是一个单词列表,以点号分隔开。这些单词可以是任意单词,比如说“stock.usd.nyse”,"nyse.vmw","quick.orange.rabbit"这种类型的。但是这个单词列表最多不能超过255个字节。【* 可以代替一个单词;#可以替代零个或多个单词】

          例如Q1->绑定的是orange带三个单词的字符串(*.orange.*)

                 Q2->绑定的是最后一个是rabbit的3个单词(*.*.rabbit)

                          第一个单词是lazy的多个单词(lazy.#)

         当一个队列绑定键是#,那么这个队列将接收所有数据,有点像fanout;如果队列绑定键当中没有#h和*出现,那么该队列绑定类型就是direct了。

        生产者

public class EmitLogTopic {//交换机名称public static final String EXCHANGE_NAME = "topic_logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();Map<String, String> bindingKeyMap = new HashMap<>();bindingKeyMap.put("quick.orange.rabbit","被队列Q1Q2接收到");bindingKeyMap.put("lazy.orange.eleplant","被队列Q1Q2接收到");bindingKeyMap.put("quick.orange.fox","被队列Q1接收到");bindingKeyMap.put("lazy.brown.fox","被队列Q2接收到");bindingKeyMap.put("lazy.pink.rabbit","虽然满足两个绑定但只被队列Q2接收一次");bindingKeyMap.put("quick.brown.fox","不匹配任何绑定不会被任何队列接收到会被丢弃");bindingKeyMap.put("quick.orange.male.rabbit","是四个单词不匹配任何绑定会被丢弃");bindingKeyMap.put("lazy.orange.male.rabbit","是四个单词但匹配Q2");for (Map.Entry<String, String> bindingKeyEntry : bindingKeyMap.entrySet()) {String routingKey = bindingKeyEntry.getKey();String message = bindingKeyEntry.getValue();channel.basicPublish(EXCHANGE_NAME,routingKey,null,message.getBytes());System.out.println("生产者发出消息:"+message);}}
}

  消费者1

public class ReceiveLogsTopic01 {//交换机名称public static final String EXCHANGE_NAME = "topic_logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明交换机channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.TOPIC);//声明队列String queueName = "Q1";channel.queueDeclare(queueName,false,false,false,null);channel.queueBind(queueName,EXCHANGE_NAME,"*.orange.*");System.out.println("Q1等待接收消息。。。。。。");//接收消息channel.basicConsume(queueName,true,(consumeTag,message)->{System.out.println(new String(message.getBody()));System.out.println(" 接收队列:"+queueName+" 绑定键:"+message.getEnvelope().getRoutingKey());},(message)->{});}
}

   消费者2

public class ReceiveLogsTopic02 {//交换机名称public static final String EXCHANGE_NAME = "topic_logs";public static void main(String[] args) throws Exception {Channel channel = RabbitMqUtil.getChannel();//声明交换机channel.exchangeDeclare(EXCHANGE_NAME, BuiltinExchangeType.TOPIC);//声明队列String queueName = "Q2";channel.queueDeclare(queueName,false,false,false,null);channel.queueBind(queueName,EXCHANGE_NAME,"*.*.rabbit");channel.queueBind(queueName,EXCHANGE_NAME,"lazy.#");System.out.println("Q2等待接收消息。。。。。。");//接收消息channel.basicConsume(queueName,true,(consumeTag,message)->{System.out.println(new String(message.getBody()));System.out.println(" 接收队列:"+queueName+" 绑定键:"+message.getEnvelope().getRoutingKey());},(message)->{});}
}

http://www.yayakq.cn/news/371171/

相关文章:

  • 网站建设 策划做网站很累
  • wordpress可以做下载站织梦医院网站源码
  • 网站设计范例呼和浩特城乡建设网站
  • 网站前端做报名框代码制作安卓app的软件
  • 做图网站有哪些东西吗网页设计师职业规划
  • 手绘风网站太原免费静态网页制作网站
  • 网站预付款怎么做会计分录温江 网站建设
  • 惠州搜索引擎seoseo排名需要多少钱
  • 做门户网站用什么技术好制作网页网站项目介绍
  • 全国优秀作文网站vue做移动端网站与pc端有什么区别
  • 观澜小学 网站建设南昌专业做网站公司有哪些
  • 东莞网站网站建设.net 网站生成安装文件目录
  • 淘宝联盟推广做网站违法搭建网站属于什么专业
  • 源码快速建站百度广告投放技巧
  • 建设工程信息网官网新网站网站设计 验收标准
  • 阿里云建设个人网站做刷题网站赚钱么
  • 网站硬件方案有没有教做韩餐的网站
  • 海南做网站的模具做外贸网站
  • 小程序制作网站在线设计平台官网
  • 类似freenom的免费域名网站做营销网站哪家好
  • 网站api怎么做的深圳企业管理咨询公司
  • 营销型网站举例找网站建设
  • 公司网站如何在百度上能搜索到杭州 网站定制
  • 做一个赚钱的网站好建设企业银行电脑版怎么下载
  • 制作旅游网站网页的代码aspcms 网站无法显示该页面
  • 盗网站asp源码免费crm网站下载
  • 个人做的网站可以收款响应式网站要怎么做
  • 深圳市门户网站建设建设网站一般多钱
  • 免费建站平台排行榜xampp如何搭建wordpress
  • cms适合做什么网站网站页面优化怎么做