单台服务器的消息队列,单消息队列完成客户服务器进程之间的双向通信.doc

哈尔滨理工大学

《UNIX程序设计》

课程设计报告

题  目:单消息队列完成客户/服务器进程之间的双向通信

院  系:计算机科学与技术学院 网络工程系

班级学号:

姓  名:

指导教师: 郭锦兰

成 绩:

2013年12月23日

第1章 绪论1

1.1 选题内容1

1.2 相关技术1

第2章 系统设计2

2.1 系统介绍2

2.2实现原理2

2.3主要问题的解决方法及关键技术5

2.4 流程图6

第3章 系统实现7

3.1客户端截图7

3.2服务器端截图8

结 论9

附 录10

附录A 核心程序代码10

绪论

选题内容

单消息队列完成客户/服务器进程之间的双向通信

相关技术

随着对通信双方安全性的要求越来越高,对能使通信安全的机制需求更加迫切,UNIX下在消息队列中嵌入加密解密算法无疑适应了潮流。UNIX为进程提供了丰富的交流方式,其中公开的交流方式有信号量、消息队列、共享内存,有名管道和文件等。采用消息队列作为通信渠道可以弥补这些缺陷:

消息队列是一种FIFO的队列性结构,可以保证先送的数据先到达,后送的数据后到达,避免的插队现象。

消息队列将输出的信息进行了打包处理,这样就可以保证以每个消息为单位进行接收了。

消息队列还可以对数据分类,更可以对不同分类的数据采取不同的方式操作,这更加灵活,安全性更高。

所以,利用消息队列实现客户服务器之间的加密通信是一种很安全的方式,研究单消息队列完成客户服务器之间的加密通信业显得很迫切和必要。

系统设计

2.1 系统介绍

本是,对信息进行有效的。

2.3实现原理

1. 建立或返回消息队列描述符

进程可用系统调用msgget来建立或返回消息队列的描述符。该系统调用的语法格式为:

int msgget(key,msgflg)

key_t key;

int msgflg;

其中,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绝对值的所有消息中,选择类型最低的第一消息返回。

如果所返回的消息的大小等于或小于用户请求,核心便将消息正文拷贝到用户区,再从队列中删除该消息,并唤醒睡眠的发送进程;如果消息比用户要求的大

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值