[MQ]ActiveMQ消息收发简单例子

本文介绍了一个使用ActiveMQ进行消息收发的性能测试案例。通过发送和接收MapMessage类型的消息,测试了不同数量级消息的吞吐量,并提供了简单的监听封装类实现。文中还附带了完整的测试代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

例子中使用的消息类型是:MapMessage。代码比较简单,帖出来给大家看看:

接收消息:

private void Receive()
        {
            var factory = new ConnectionFactory(Program.BrokerUri);
            var timeout = new TimeSpan(0, 0, 10);
            using (var connection = factory.CreateConnection())
            {
                using (var session = connection.CreateSession())
                {
                    var destination = SessionUtil.GetDestination(session, Program.NormalQueueDestination);
                    using (var consumer = session.CreateConsumer(destination))
                    {
                        connection.Start();
                        var stopwatch = new Stopwatch();
                        var index = 1;
                        for (var i = 0; i < Program.MessageCount; i++)
                        {
                            if (index == 1)
                            {
                                stopwatch.Start();
                            }

                            try
                            {
                                var message = (IMapMessage)consumer.Receive(timeout);
                                index++;
                                var messageObj = Common.GetMessageObjByIMapMessage(message);
                                if (messageObj != null)
                                {
                                    //Debug.WriteLine(messageObj.MediaTaskId);
                                }

                                if (index == Program.StatisticsMessageCountSpan)
                                {
                                    stopwatch.Stop();
                                    var spendSeconds = stopwatch.Elapsed.TotalSeconds;
                                    var speed = Program.StatisticsMessageCountSpan / spendSeconds;
                                    Debug.WriteLine("Receive " + Program.StatisticsMessageCountSpan + " Messages Spend:" + spendSeconds + " Seconds. (" + speed.ToString("0.00") + "/s)");

                                    stopwatch.Reset();
                                    index = 1;
                                }
                            }
                            catch (Exception ex)
                            {
                                Debug.WriteLine(ex);
                            }
                        }
                    }
                }
            }
        }

 发送消息:

private void Send()
        {
            var factory = new ConnectionFactory(Program.BrokerUri);
            using (var connection = factory.CreateConnection())
            {
                using (var session = connection.CreateSession())
                {
                    var destination = SessionUtil.GetDestination(session, Program.NormalQueueDestination);
                    using (var producer = session.CreateProducer(destination))
                    {
                        connection.Start();
                        var mediaTaskId = 100000000000000;
                        var stopwatch = new Stopwatch();
                        var index = 1;
                        for (var i = 1; i <= Program.MessageCount; i++)
                        {
                            if (index == 1)
                            {
                                stopwatch.Start();
                            }

                            try
                            {
                                mediaTaskId++;
                                var message = session.CreateMapMessage();
                                Common.SetMapMessage(message, Common.GetMessageObj(mediaTaskId.ToString()));
                                producer.Send(message);
                                index++;
                                
                                if (index == Program.StatisticsMessageCountSpan)
                                {
                                    stopwatch.Stop();
                                    var spendSeconds = stopwatch.Elapsed.TotalSeconds;
                                    var speed = Program.StatisticsMessageCountSpan / spendSeconds;
                                    Debug.WriteLine("Send " + Program.StatisticsMessageCountSpan + " Messages Spend:" + spendSeconds + " Seconds. (" + speed.ToString("0.00") + "/s)");

                                    stopwatch.Reset();
                                    index = 1;
                                }
                            }
                            catch (Exception ex)
                            {
                                Debug.WriteLine(ex);
                            }
                        }
                    }
                }
            }

            MessageBox.Show(@"Send Done!");
        }

简单监听封装类:

using System;
using System.Diagnostics;
using System.Threading;
using Apache.NMS;

namespace ActiveMQ.PerformanceTest
{
    public class ActiveMqListener
    {
        public event MessageReceivedEventHandler MessageReceived;
        private readonly IMessageConsumer _messageConsumer;
        private readonly TimeSpan _timeout;
        private readonly int _sleepMinutes;
        private bool _listen;

        public ActiveMqListener(IMessageConsumer messageConsumer, TimeSpan timeout, int sleepMinutes)
        {
            _messageConsumer = messageConsumer;
            _timeout = timeout;
            _sleepMinutes = sleepMinutes;
        }

        public void Start()
        {
            _listen = true;

            StartListening();
        }

        public void Stop()
        {
            _listen = false;
        }

        private void StartListening()
        {
            while (_listen)
            {
                var message = _messageConsumer.Receive(_timeout);
                if (message == null)
                {
                    Debug.WriteLine("[%Notice:ActiveMqListener Start " + _sleepMinutes + " Minutes Sleep.%]");
                    Thread.Sleep(_sleepMinutes * 1000 * 60);
                }
                else
                {
                    FireRecieveEvent(message);
                }
            }
        }

        private void FireRecieveEvent(object message)
        {
            if (MessageReceived != null)
            {
                MessageReceived(this, new MessageEventArgs(message));
            }
        }
    }

    public delegate void MessageReceivedEventHandler(object sender, MessageEventArgs args);

    public class MessageEventArgs : EventArgs
    {
        private readonly object _message;

        public object Message
        {
            get { return _message; }
        }

        public MessageEventArgs(object message)
        {
            _message = message;
        }
    }
}

 完整代码下载地址:

http://files.cnblogs.com/CopyPaster/ActiveMQ.PerformanceTest.rar

 

 

转载于:https://www.cnblogs.com/CopyPaster/archive/2012/04/27/2473205.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值