网站大量收购闲置独家精品文档,联系QQ:2885784924

用消息队列实现Client与Server间的通信.docVIP

用消息队列实现Client与Server间的通信.doc

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用消息队列实现Client与Server间的通信

用消息队列实现Client和Server间的通信.txt35温馨是大自然的一抹色彩,独具慧眼的匠师才能把它表现得尽善尽美;温馨是乐谱上的一个跳动音符,感情细腻的歌唱者才能把它表达得至真至纯用消息队列实现Client和Server间的通信 本文主要介绍UNIX操作系统中消息队列机制、调用方法以及多路复用消息技术,通过应用实例,给出了其在Client和Server间的通信实现。 网络应用的标准模型是客户一服务员模型。在金融系统应用软件开发中,这种模型被广泛的采用,并且实现这种模型的方法多种多样。因此,根据不同的业务类型,选择较好的实现方法至关重要。 在UNIX系统的内部结构中,含有消息机构,即所有的消息都放在内核中,并且它们都有一个相应的消息队列号。消息机构允许进程发送一个消息到任意其它进程,从而实现系统中进程间的通信。 一、UNIX系统中的消息机构 消息是一个格式化的可变长度的信息单元。它有如下属性:(1)长整数类型 (2)消息的数据长度 (3)数据。由于消息的长度是可变的,故将消息分为消息首部和消息数据两部分。在消息首部中,记录着消息的类型和大小,指向消息数据区的指针,消息队列的链接指针等。每个消息队列有一个称为 key的名称,如同用户文件描述符一样,每个消息队列还有一个消息队列描述符。此外,在一个系统中,可能有若干个消息队列,所有消息队列的头标组成一个数组。图1 示出了消息和消息队列的数据结构。 图1 消息和消息队列的数据结构 1. 建立或返回消息队列描述符 进程可用系统调用megget来建立或返回消息队列的描述符。该系统调用的语法格式为: int megget(key,msgflg) key_t key; int megflg; 其中,key是消息队列的名字;msgflg是用户设置的标志。如果IPC_CREAT表示系统无以key命名的消息队列,则建立消息队列标识符;若已存在,则返回消息队列描述符msgid。   对于系统调用,核心将搜索消息队列头标数组,确定是否有指定关键字的消息队列。若无,核心将分配一新的队列结构,并返回给用户一个消息队列描述符;否则,它只是检查消息队列的许可权之后便返回。 2.消息的发送 进程可用megsnd( )系统调用来发送一个消息,并将它链入消息队列的尾部。该系统调用的语法格式如下: int msgsnd(msgid,msgp,msgsz,msgflg) int msgid; struct msgbuf * msgp; int msgsz,msgflg; 其中,msgid是由msgget返回的消息队列描述符;msgp指向包含这条消息的结构,该结构由如下两个成员组成: struct msgbuf { long mtype; /* 消息类型 */ char mtext[ ]; /* 消息的文本 */ } msgsz是mtext的字节长度;msgflg规定了当无内存空间来存储消息时,进程等待还是立即返回。 对于msgsnd( )系统调用,核心检查消息队列描述符和许可权是否合法;消息长度是否超过系统规定的长度,若过长,进程睡眠等待出现足够大的空间,通过检查后,核心为消息分配消息数据区,并将消息从用户空间拷贝到消息数据区,分配消息首部,将它链入该消息队列的尾部,在消息首部填写消息类型,大小以及指向消息数据区的指针,还有修改消息队列的头标中的数据。然后唤醒在等待消息到来的队列中睡眠的进程。 3. 消息的接收 进程可用msgrcv( )系统调用,从消息队列中读一条消息,语法格式为: int msgrcv(msgid,msgp,msgsz,msgtyp,msgflg) int msgid,msgsz,msgflg; struct msgbuf * msgp; long msgtyp; 其中,msgid,msgp,msgsz,msgflg与msgsnd相似,msgtype是规定用户想读的消息类型。 对于msgrcv( )系统调用是先由核心检查消息队列标识符和许可权,接着根据msgtyp分三种情况处理。 (1) msgtyp=0,核心寻找消息队列中的第一个消息,并将它返回给调用进程; (2)msgtyp为正整数,核心返回给类型的第一个消息; (3)msgtyp为负整数,核心应在其类型值小于或等于msgtyp绝对值的所有消息中,选择类型最低的第一消息返回。 如果所返回的消息的大小等于或小于用户请求,核心便将消息正文拷贝到用户区,再从队列中删除该消息,并唤醒睡眠的发送进程;如果消息比用户要求的大,则系统返回错误信息。 4. 消息队列的操纵 可利用msgctl( )系统调用,来改变消息队列的属性,即拥有者,许可权等。其语法格式如下: int msgctl(msgid,cmd,buf) int msgid,cmd; stru

文档评论(0)

woai118doc + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档