关闭

消息队列--MSMQ应用(二)

标签: 消息队列 MSMQ应用并发
365人阅读 评论(52) 收藏 举报
分类:

    上篇博客,仅仅是讲了MSMQ的简单应用,在实际的应用过程中,往往是要复杂一些的。

    首先,拿评教系统来说,我设计的具体流程为下图

    


    小编详解

    1、图中的两个评教学生端,都是我们的学生端代码,不同的是他们表示的是不同的模块,“数据提交MSMQ”表示的学生端的用户提交模块,表示将用户数据提交到MSMQ服务器;“事务结束”表示的是从队列中取值,插入数据库。

    2、在MSMQ中用不用事务的区别在于:无事务只是将记录写到缓存,数据容易丢失,有事务时会将记录写到缓存和磁盘,如果缓存中的数据丢失,MSMQ自动从磁盘恢复数据。但不用事务的效率大概是使用事务的2倍。

    3、将出队操作和向数据库插入数据中加入数据,是为了保持数据的一致性,避免数据已经出队,但并没有插入数据表等情况。

    4、此处的委托由事件触发,出队操作完成时,触发出队操作完成事件,委托给向数据库插入的方法,执行插入操作。


    部分代码

<span style="font-size:18px;">           //将任务添加到线程池
            ThreadPool.QueueUserWorkItem(o =>
            {
                //连接队列
                MessageQueue myQueue = new MessageQueue(@"FormatName:Direct=TCP:192.168.22.232\private$\myQueue");
             
                    while (true)
                    {
                       
                        //实例化消息队列事务对象
                        MessageQueueTransaction myTransaction = new MessageQueueTransaction();

                        //使用委托,接收消息完成的时候执行myreceivecompleted方法
                        myQueue.ReceiveCompleted += new ReceiveCompletedEventHandler(MyReceiveCompleted);
                       
                        //反序列化
                        myQueue.Formatter = new XmlMessageFormatter(new Type[] { typeof(evaluationassesscoursenumentity) });
                        //事务开始
                        myTransaction.Begin();
                      
                        //没有限时操作的接收消息
                        IAsyncResult abc = myQueue.BeginReceive();
                        //提交事务
                        myTransaction.Commit();
                    }
            });
        }</span>


        委托的插入方法

<span style="font-size:18px;">       private static void MyReceiveCompleted(Object source, ReceiveCompletedEventArgs asyncResult)
          {
            
            MessageQueue myQueue = (MessageQueue)source;
            //完成指定的异步接收操作
            System.Messaging.Message message = myQueue.EndReceive(asyncResult.AsyncResult);
            evaluationassesscoursenumentity transformassesscoursenum = message.Body as evaluationassesscoursenumentity;

            
            var CopyWXEvaluationStudentAssess = DependencyResolver.Current.GetService<WXEvaluationStudentAssessController>();
            //调用相应的方法,将队列的值插入数据库
            bool flag = CopyWXEvaluationStudentAssess.AddAssessNum(transformassesscoursenum);
           
            myQueue.Receive();
        }
</span>

    消息队列的介绍就先到这里,小编才疏学浅,有出入的地方,请大牛们多多指教。

    

1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:35789次
    • 积分:6492
    • 等级:
    • 排名:第3693名
    • 原创:71篇
    • 转载:0篇
    • 译文:0篇
    • 评论:2937条
    博客专栏
    最新评论