RabbitMQ学习之:(七)Fanout Exchange (转贴+我的评论)
From:http://lostechies.com/derekgreer/2012/05/16/rabbitmq-for-windows-fanout-exchanges/
PunCha: There is not too much to say about this topic....
RabbitMQ for Windows: Fanout Exchanges
This is the sixth installment to the series: RabbitMQ for Windows. In the last installment, we walked through creating a direct exchange example and introduced the push API. In this installment, we’ll walk through a fanout exchange example.
As discussed earlier in the series, the fanout exchange type is useful for facilitating the publish-subscribe pattern. When we publish a message to a fanout exchange, the message is delivered indiscriminately to all bound queues. With the Direct, Topic, and Headers exchange types, a criteria is used by a routing algorithm taking the form of a routing key or a collection of message headers depending on the exchange type in question. A routing key or a collection of message headers may also be specified with the fanout exchange which will be delivered as part of the message’s metadata, but they will not be used as a filter in determining which queue receives a published message.
To demonstrate the fanout exchange, we’ll use a stock ticker example. In the previous example, logs were routed to queues based upon a matching routing key (an empty string in the logging example’s case). In this example, we’d like our messages to be delivered to all bound queues regardless of qualification.
Similar to the previous example, we’ll create a Producer console application which periodically publishes stock quote messages and a Consumer console application which displays the message to the console.
We’ll start our Producer app as before by establishing a connection using the default settings, creating the connection, and creating a channel:
namespace Producer
{
class Program
{
static volatile bool _cancelling; static void Main(string[] args)
{
var connectionFactory = new ConnectionFactory();
IConnection connection = connectionFactory.CreateConnection();
IModel channel = connection.CreateModel();
}
}
}
Next, we need to declare an exchange of type “fanout”. We’ll name our new exchange “fanout-exchange-example”:
channel.ExchangeDeclare("direct-exchange-example", ExchangeType.Fanout, false, true, null);
To publish the stock messages periodically, we’ll call a PublishQuotes() method with the provided channel and run it on a background thread:
var thread = new Thread(() => PublishQuotes(channel));
thread.Start();
Next, we’ll provide a way to exit the application by prompting the user to enter ‘x’ and use a simple Boolean to signal the background thread when to exit:
Console.WriteLine("Press 'x' to exit");
var input = (char) Console.Read();
_cancelling = true;
Lastly, we need to close the channel and connection:
channel.Close();
connection.Close();
For our PublishQuotes() method, well iterate over a set of stock symbols, retrieve the stock information for each symbol, and publish a simple string-based message in the form [symbol]:[price]:
static void PublishQuotes(IModel channel)
{
while (true)
{
if (_cancelling) return;
IEnumerable quotes = FetchStockQuotes(new[] {"GOOG", "HD", "MCD"});
foreach (string quote in quotes)
{
byte[] message = Encoding.UTF8.GetBytes(quote);
channel.BasicPublish("direct-exchange-example", "", null, message);
}
Thread.Sleep(5000);
}
}
To implement the FetchStockQuotes() method, we’ll use the Yahoo Finance API which entails retrieving an XML-based list of stock quotes and parsing out the bit of information we’re interested in for our example:
static IEnumerable<string> FetchStockQuotes(string[] symbols)
{
var quotes = new List<string>(); string url = string.Format("http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.quotes%20where%20symbol%20in%20({0})&env=store://datatables.org/alltableswithkeys",
String.Join("%2C", symbols.Select(s => "%22" + s + "%22")));
var wc = new WebClient {Proxy = WebRequest.DefaultWebProxy};
var ms = new MemoryStream(wc.DownloadData(url));
var reader = new XmlTextReader(ms);
XDocument doc = XDocument.Load(reader);
XElement results = doc.Root.Element("results"); foreach (string symbol in symbols)
{
XElement q = results.Elements("quote").First(w => w.Attribute("symbol").Value == symbol);
quotes.Add(symbol + ":" + q.Element("AskRealtime").Value);
} return quotes;
}
Here is the complete Producer listing:
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Net;
using System.Text;
using System.Threading;
using System.Xml;
using System.Xml.Linq;
using RabbitMQ.Client; namespace Producer
{
class Program
{
static volatile bool _cancelling; static void Main(string[] args)
{
var connectionFactory = new ConnectionFactory();
IConnection connection = connectionFactory.CreateConnection();
IModel channel = connection.CreateModel();
channel.ExchangeDeclare("direct-exchange-example", ExchangeType.Fanout, false, true, null); var thread = new Thread(() => PublishQuotes(channel));
thread.Start(); Console.WriteLine("Press 'x' to exit");
var input = (char) Console.Read();
_cancelling = true; channel.Close();
connection.Close();
} static void PublishQuotes(IModel channel)
{
while (true)
{
if (_cancelling) return;
IEnumerable quotes = FetchStockQuotes(new[] {"GOOG", "HD", "MCD"});
foreach (string quote in quotes)
{
byte[] message = Encoding.UTF8.GetBytes(quote);
channel.BasicPublish("direct-exchange-example", "", null, message);
}
Thread.Sleep(5000);
}
} static IEnumerable<string> FetchStockQuotes(string[] symbols)
{
var quotes = new List<string>(); string url = string.Format("http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.quotes%20where%20symbol%20in%20({0})&env=store://datatables.org/alltableswithkeys",
String.Join("%2C", symbols.Select(s => "%22" + s + "%22")));
var wc = new WebClient {Proxy = WebRequest.DefaultWebProxy};
var ms = new MemoryStream(wc.DownloadData(url));
var reader = new XmlTextReader(ms);
XDocument doc = XDocument.Load(reader);
XElement results = doc.Root.Element("results"); foreach (string symbol in symbols)
{
XElement q = results.Elements("quote").First(w => w.Attribute("symbol").Value == symbol);
quotes.Add(symbol + ":" + q.Element("AskRealtime").Value);
} return quotes;
}
}
}
Our Consumer application will be similar to the one used in our logging example, but we’ll change the exchange name, queue name, and exchange type and put the processing of the messages within a while loop to continually display our any updates to our stock prices. Here’s the full listing for our Consumer app:
using System;
using System.IO;
using System.Text;
using RabbitMQ.Client;
using RabbitMQ.Client.Events; namespace Consumer
{
class Program
{
static void Main(string[] args)
{
var connectionFactory = new ConnectionFactory();
IConnection connection = connectionFactory.CreateConnection();
IModel channel = connection.CreateModel(); channel.ExchangeDeclare("direct-exchange-example", ExchangeType.Fanout, false, true, null);
channel.QueueDeclare("quotes", false, false, true, null);
channel.QueueBind("quotes", "direct-exchange-example", ""); var consumer = new QueueingBasicConsumer(channel);
channel.BasicConsume("quotes", true, consumer); while (true)
{
try
{
var eventArgs = (BasicDeliverEventArgs) consumer.Queue.Dequeue();
string message = Encoding.UTF8.GetString(eventArgs.Body);
Console.WriteLine(message);
}
catch (EndOfStreamException)
{
// The consumer was cancelled, the model closed, or the connection went away.
break;
}
} channel.Close();
connection.Close();
}
}
}
Setting our solution startup projects to run both the Producer and Consumer apps together, we should see messages similar to the following for the Consumer output:
GOOG:611.62
HD:48.66
MCD:91.06
GOOG:611.58
HD:48.66
MCD:91.06
To show our queue would receive messages published to the fanout exchange regardless of the routing key value, we can change the value of the routing key to “anything”:
channel.QueueBind("quotes", "direct-exchange-example", "anything");
Running the application again shows the same values:
GOOG:611.62
HD:48.66
MCD:91.06
GOOG:611.58
HD:48.66
MCD:91.06
That concludes our fanout exchange example. Next time, we’ll take a look at the topic exchange type.
RabbitMQ学习之:(七)Fanout Exchange (转贴+我的评论)的更多相关文章
- rabbitmq学习(七) —— springboot下的可靠使用
前面的学习都是基于原生的api,下面我们使用spingboot来整合rabbitmq springboot对rabbitmq提供了友好支持,极大的简化了开发流程 引入maven <depende ...
- rabbitMQ学习(七)反馈模式
反馈模式 在消费端接收到消息后,会反馈给服务器信息. 连接代码: import java.io.IOException; import com.rabbitmq.client.Channel; imp ...
- rabbitMQ学习笔记(七) RPC 远程过程调用
关于RPC的介绍请参考百度百科里的关于RPC的介绍:http://baike.baidu.com/view/32726.htm#sub32726 现在来看看Rabbitmq中RPC吧!RPC的工作示意 ...
- RabbitMQ学习总结 第六篇:Topic类型的exchange
目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...
- RabbitMQ学习系列(四): 几种Exchange 模式
上一篇,讲了RabbitMQ的具体用法,可以看看这篇文章:RabbitMQ学习系列(三): C# 如何使用 RabbitMQ.今天说些理论的东西,Exchange 的几种模式. AMQP协议中的核心思 ...
- (七)RabbitMQ消息队列-通过fanout模式将消息推送到多个Queue中
原文:(七)RabbitMQ消息队列-通过fanout模式将消息推送到多个Queue中 前面第六章我们使用的是direct直连模式来进行消息投递和分发.本章将介绍如何使用fanout模式将消息推送到多 ...
- RabbitMQ学习之:(六)Direct Exchange (转贴+我的评论)
From: http://lostechies.com/derekgreer/2012/04/02/rabbitmq-for-windows-direct-exchanges/ RabbitMQ fo ...
- RabbitMQ学习笔记4-使用fanout交换器
fanout交换器会把发送给它的所有消息发送给绑定在它上面的队列,起到广播一样的效果. 本里使用实际业务中常见的例子, 订单系统:创建订单,然后发送一个事件消息 积分系统:发送订单的积分奖励 短信平台 ...
- PHP 下基于 php-amqp 扩展的 RabbitMQ 简单用例 (二) -- Topic Exchange 和 Fanout Exchange
Topic Exchange 此模式下交换机,在推送消息时, 会根据消息的主题词和队列的主题词决定将消息推送到哪个队列. 交换机只会为 Queue 分发符合其指定的主题的消息. 向交换机发送消息时,消 ...
随机推荐
- Linux目录结构以及一些常见操作
本章内容: Linux 目录结构 远程服务器关机及重启时的注意事项 不要在服务器访问高峰运行高负载命令 远程配置防火墙时不要把自己踢出服务器 指定合理的密码规范并定期更新 合理分配权限 定期备份重要数 ...
- org.apache.tomcat.util.descriptor.web.WebXml.setVersion Unknown version string [4.0]
错误: 在 IDEA 创建WEB项目之后,打印出的日志中总是出现一行警告信息: 12-May-2018 15:52:30.692 警告 [RMI TCP Connection(3)-127.0.0.1 ...
- eclipse安装Bug检查工具
第一步:下载spotbugs工具 打开eclipse>Help>Eclipse Matketplace 打开 Eclipse Marketplace 搜索 spotbugs,点击Insta ...
- 洛谷 P2765 魔术球问题 (dinic求最大流,最小边覆盖)
P2765 魔术球问题 题目描述 «问题描述: 假设有n根柱子,现要按下述规则在这n根柱子中依次放入编号为1,2,3,...的球. (1)每次只能在某根柱子的最上面放球. (2)在同一根柱子中,任何2 ...
- [NOI2014]购票——斜率优化+树链剖分+线段树
建议到UOJ上去交 题解 一眼\(DP\),先把转移方程写出来 设\(dp[i]\)为从点\(i\)出发到点\(1\)的最小费用,那么存在转移 \[f[i]=min\{f[j]+(d[i]-d[j]) ...
- luogu4422 [COCI2017-2018#1] Deda[线段树二分]
讨论帖:线段树二分的题..我还考场切过..白学 这题我一年前的模拟赛考场还切过,现在就不会了..好菜啊. 显然直接线段树拆成$\log n$个区间,然后每个区间在进行线段树二分即可. UPD:复杂度分 ...
- react-router5.x 的配置及其页面跳转方法和js跳转方法
https://blog.csdn.net/sinat_37255207/article/details/90745207 上次用react-router 的时候 还是3.x 很久不用 已经到rea ...
- Java8-Stream-No.10
import java.util.Arrays; import java.util.IntSummaryStatistics; import java.util.List; import java.u ...
- 第02组团队Git现场编程实战
GitHub仓库地址 click here 1.组员职责分工 组员 职责分工 黄智.赵镇 百度地图API使用 潘松波.颜志鹏 写分别测评福州人均消费50以下,50-100.100-200.200以上最 ...
- linux 搭建 jenkins 前端自动构建时,老是提示 sh: vue-cli-service: command not found
如题. 在 shell 里面执行 env 发现一个 NODE_ENV=production 的环境变量,是这个东西的原因. 通过 unset NODE_ENV 命令去掉这个环境变量就可以了 ...