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

来源:互联网 发布:陌陌站街用什么软件 编辑:程序博客网 时间:2024/06/08 04:43

    上篇博客,仅仅是讲了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