RabbitMQ經過Exchange.headers屬性代替routekey,x-match實現隊列精準匹配

消費者:web

 static void Main(string[] args)
        {
            ConnectionFactory factory = new ConnectionFactory()
            {
                HostName = "192.168.254.40",
                UserName = "admin",
                Password = "admin",
            };

            //第一步:建立connection
            var connection = factory.CreateConnection();

            //第二步:建立一個channel
            var channel = connection.CreateModel();

            //第三步:申明交換機【由於rabbitmq已經有了自定義的ampq default exchange】
            channel.ExchangeDeclare("myheadersexchange", ExchangeType.Headers, true, false, null);

            //第四步:建立一個隊列(queue)
            channel.QueueDeclare("myheadersqueue", true, false, false, null);

            //將queue綁定到exchange之上。。。。
            channel.QueueBind("myheadersqueue", "myheadersexchange", string.Empty, new Dictionary<string, object>()
            {
                {"x-match", "all"},
                {"username", "jack"},
                {"password", "12345" }
            });

            EventingBasicConsumer consumer = new EventingBasicConsumer(channel);

            consumer.Received += (sender, e) =>
            {
                var msg = Encoding.UTF8.GetString(e.Body);

                Console.WriteLine(msg);
            };

            channel.BasicConsume("myheadersqueue", true, consumer);

            Console.WriteLine("consumer1 端啓動完畢!!!");

            Console.Read();
        }

生產者:ui

static void Main(string[] args)
        {
            ConnectionFactory factory = new ConnectionFactory()
            {
                HostName = "192.168.254.40",
                UserName = "admin",
                Password = "admin",
            };

            //第一步:建立connection
            var connection = factory.CreateConnection();

            //第二步:建立一個channel
            var channel = connection.CreateModel();

            var properties = channel.CreateBasicProperties();

            properties.Headers = new Dictionary<string, object>();

            properties.Headers.Add("password", "12345");
            properties.Headers.Add("username", "jack");

            for (int i = 0; i < 100; i++)
            {
                var msg = Encoding.UTF8.GetBytes(string.Format("{0} :{1}", i, "你好"));

                //第五步:發佈消息
                channel.BasicPublish("myheadersexchange", routingKey: string.Empty, basicProperties: properties, body: msg);

                Console.WriteLine(i);
            }
        }

headers 是採用多個屬性代替routing keyspa

x-match [all/any] all: 全部的header頭信息必須匹配。。。code

any: 只要有一個匹配就ok了。。。。orm


direct exchange: 只須要匹配一個routingkey就能夠了。。。。blog

而如今的headers匹配,必須是知足一個或者所有的條件。。。 【and /or】的關係。。。排序

if(name=="jack" || age==20){
queue1.add(msg);
}rabbitmq

if(name=="jack" && age==20){
queue2.add(msg);
}隊列

在webui上看一下:string

x-match: any

x-match:all

key,value的順序沒有特別大的關係,由於headers.erl中會將這些key按照字母進行排序。。。

相關文章
相關標籤/搜索