zoukankan      html  css  js  c++  java
  • MSMQ 消息队列

    原文地址:http://blog.163.com/jiashe_007/blog/static/1005138952010317114653653/

    手记:转来的!今天装西门子WINCC软件,没成功,提示微软消息队列Message Queue 没有安装,然后在控制面板-添加删除程序里安装Windows组件,提示要插入系统盘,找了好久都没找到,才发现原来系统盘是很重要的资料,不可以丢啊!第二天找来系统盘安装,安装的过程中中断,提示“无法启动MSMQ服务”,刚开始不知道MSMQ是个什么东西,上网搜索,果然有人问了同样的问题,但是没有解答,然后就找到这篇博文,看了看,对消息队列有了了解。还不错!使用下面的方法,首先启动MSMQ服务,然后就可以安装消息队列,安装了消息队列就可以安装WINCC了!WINCC 7.0 SP1很大,需要安装内容很多!

    问2:无法启动MSMQ服务!!!!CMD的方法用过了,最后MSDOS里显示, 系统发生1058错误,无法启动服务,原因是他被禁用或者与他相关的设备没有启动;问题补充:我列表里没有这个服务啊,连CMD里也这么提示   

    答2:原因:“Distributed Transaction Coordinator”服务未启动。
    解决:右击“我的电脑→管理→服务和应用程序→服务”中将此服务启动。也可使用如下方法:
    开始→运行中输入:cmd后依次输入如下语句:

    net stop msdtc
           msdtc -uninstall
           msdtc -install
           net start msdtc

    问1:为什么在xp上添加消息队列时不成功提示:无法启动MSMQ服务,消息队列客户端安装失败

    无法启动msmq服务 错误代码0x42c 错误描述:依存服务或组无法启动。

    答1:没有答案

    MSMQ的简单介绍

    标签: msmq的简单介绍 分类:VC

    MSMQ(MicroSoft  Message  Queue,微软消息队列)是在多个不同的应用之间实现相互通信的一种异步传输模式,相互通信的应用可以分布于同一台机器上,也可以分布于相连的网络空间中的任一位置。它的实现原理是:消息的发送者把自己想要发送的信息放入一个容器中(我们称之为Message),然后把它保存至一个系统公用空间的消息队列(Message  Queue)中;本地或者是异地的消息接收程序再从该队列中取出发给它的消息进行处理。   

    在消息传递机制中,有两个比较重要的概念。一个是消息,一个是队列。消息是由通信的双方所需要传递的信息,它可以是各式各样的媒体,如文本、声音、图象等等。消息最终的理解方式,为消息传递的双方事先商定,这样做的好处是,一是相当于对数据进行了简单的加密,二则采用自己定义的格式可以节省通信的传递量。消息可以含有发送和接收者的标识,这样只有指定的用户才能看到只传递给他的信息和返回是否操作成功的回执。消息也可以含有时间戳,以便于接收方对某些与时间相关的应用进行处理。消息还可以含有到期时间,它表明如果在指定时间内消息还未到达则作废,这主要应用与时间性关联较为紧密的应用。   

     消息队列是发送和接收消息的公用存储空间,它可以存在于内存中或者是物理文件中。消息可以以两种方式发送,即快递方式(express)和可恢复模式(recoverable),它们的区别在于,快递方式为了消息的快速传递,把消息放置于内存中,而不放于物理磁盘上,以获取较高的处理能力;可恢复模式在传送过程的每一步骤中,都把消息写入物理磁盘中,以得到较好的故障恢复能力。消息队列可以放置在发送方、接收方所在的机器上,也可以单独放置在另外一台机器上。正是由于消息队列在放置方式上的灵活性,形成了消息传送机制的可靠性。当保存消息队列的机器发生故障而重新启动以后,以可恢复模式发送的消息可以恢复到故障发生之前的状态,而以快递方式发送的消息则丢失了。另一方面,采用消息传递机制,发送方必要再担心接收方是否启动、是否发生故障等等非必要因素,只要消息成功发送出去,就可以认为处理完成,而实际上对方可能甚至未曾开机,或者实际完成交易时可能已经是第二天了。   

    采用MSMQ带来的好处是:由于是异步通信,无论是发送方还是接收方都不用等待对方返回成功消息,就可以执行余下的代码,因而大大地提高了事物处理的能力;当信息传送过程中,信息发送机制具有一定功能的故障恢复能力;MSMQ的消息传递机制使得消息通信的双方具有不同的物理平台成为可能。   

     在微软的.net平台上利用其提供的MSMQ功能,可以轻松创建或者删除消息队列、发送或者接收消息、甚至于对消息队列进行管理。   

     在.NET产品中,提供了一个MSMQ类库"System.Messaging.dll"。它提供了两个类分别对消息对象和消息队列对象进行操作。在能够使用MSMQ功能之前,你必须确定你的机器上安装了MSMQ消息队列组件,并确保服务正在运行中。在使用ASP.NET编程时,应在头部使用:   

        <%@  Assembly  Name="System.Messaging"%>   

        <%@  Import  NameSpace="System.Messsaging"%>   

       将MSMQ类库引入ASP.NET文件   

               1.  对消息队列的创建  

             dim  MsgQue  as  MessageQueue  

             MsgQue=New  MessageQueue(MsgPath)  

       其中:MsgPath可以为本地私有队列,如".MyQueue",也可以为其他机器的公有队列,如"Saidy777$MyQueue",Saidy为另一机器名。  

              

              2.  消息的发送  

            dim  MsgQue  as  MessageQueue  

            MsgQue.Send(Msg)  

       其中:Msg为任一对象。   

             3.  消息的接收   

     消息的接收又分成同步和异步方式两种,同步接收在规定时间内从消息队列中取出收到的第一条消息,当消息队列中没有消息时,程序处于等待状态;异步接收方式则是定义了一个事件处理函数,当消息队列中第一个消息到达时立即触发该函数。   

                          1)  同步方式  

             dim  Msg  as  Message  

             dim  Fmt  As  XmlMessageFormatter  

             Fmt=  CType(MsgQue.Formatter,XmlMessageFormatter)  

             Fmt.TargetTypeNames  =  new  String(){"System.String"}  

             Msg=MsgQue.receive(New  TimeSpan(0,0,3))  

    首先定义收到消息应转换成的格式,然后在指定时间内去接收消息   

                        2)  异步方式  

             dim  Fmt  As  XmlMessageFormatter  

            ''定义接收消息类型  

            Fmt  =  CType(MsgQue.Formatter,XmlMessageFormatter)  

            Fmt.TargetTypeNames  =  new  String(){"System.String"} ''定义消息处理函数入口  

            AddHandler  MsgQue.ReceiveCompleted,  New  ReceiveCompletedEventHandler  

            (AddressOf  OnReceiveCompleted)  ''定义消息处理函数  

            Public  Shared  Sub  OnReceiveCompleted(s  As  Object,  asyncResult  As  ReceiveAsyncEventArgs)  

            Dim  MsgQue  As  MessageQueue  =  CType(s,MessageQueue)  

            Dim  Msg  As  Message  =  MsgQue.EndReceive(asyncResult.AsyncResult)  

            ''此时Msg.Body即为所取消息对象  

            MsgQue.BeginReceive()  

            ''重新定义异步接收方式  

            End  sub  

           ''启动异步接收方式  

            MsgQue.BeginReceive   

       消息队列配置属性   

       关于队列的属性  

    path属性:它可以决定引用队列的三种方式,路径引用、格式名引用、标识引用   

    category属性:标识当前使用的队列的类型。Category是队列所有者定义的GUID值。该GUID值可以有GUID生成工具产生或者是用户自定义的数字值。GUID值不会唯一,这样才可以根据相同的GUID值,把多个消息队列划分为不同的类别(category)。   

      跟发送数据类型相关的属性   

      Formatter属性:决定在一个队列中如何发送和接收消息的顺序,以及可以在一个消息中发送什么样的内容。   和队列交互相关的属性   

      DenyShareReceive属性:决定同一时间内只有一个部件能够访问消息队列中的消息。   

      CanRead和CanWrite属性:决定队列是否可以被读取或者是写入。   

      MaximumQueueSize和MaximumJournalSize属性:以千字节为单位设置一个队列(日志队列)的消息最大容纳量。一旦接收的消息到达这个容量,新的消息将不再被接收。   

      一般情况下,消息队列的最大值为消息队列管理员所设置,如果这个值没有控制的话,那么缺省的消息队列最大容量将是无限制的。   

      UseJournalQueue属性::设置是否将收到的消息拷贝到日志消息队列中去。

  • 相关阅读:
    【学相伴】Nginx最新教程通俗易懂-狂神说
    Linux基础知识总结(命令行)
    CentOS7 运维
    Linux 的基础知识回顾(安装vmware) ---- No.1 后面都以Centos8 为例
    Linux sudo权限提升漏洞(CVE-2021-3156)
    Flutter开发指南之理论篇:Dart语法05(单线程模型,事件循环模型,Isolate)
    矩阵的范数
    函数导出在kvm_intel.ko,kvm.ko不共享
    python 调用内部类的两种方法
    python3 字符串方法
  • 原文地址:https://www.cnblogs.com/niaowo/p/3671412.html
Copyright © 2011-2022 走看看