频 道 直 达 - 新闻 - 培训 - 软件 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 读书 - 博客 - BBS
51CTO.COM_中国最大的网络技术网站
找资料:

4.6.2 消息队列的内核实现

作者: Jim Mauro; Richard McDougall 出处:机械工业出版社华章公司  2007-09-24 17:35    砖    好    评论   进入论坛
阅读提示:《Solaris 内核结构》(第2版)第4章主要介绍的是进程间通信(IPC),本文是消息队列的内核实现。

4.6.2 消息队列的内核实现
在本节我们会大致浏览消息队列生成、发送/接收消息的内核代码流,因为这些代码代表了大部分消息队列活动。
1.为应用程序(调用了msgget(2))生成消息,都是从调用内核ipc_get()例程开始的。对每个消息队列标识符而言,都有一个可用的ipc_perm结构。
2.一旦结构被分配,系统就会初始化结构成员,使其与调用进程的UID、GID相同,并且初始化调用代码传递过来的权限模式位,然后设置IPC_ALLOC位来表示ipc_perm结构已经分配(4.1节有ipc_get()代码)。
如果ipc_get()返回成功,应用程序代码会得到一个有效的消息队列标识符,并能够通过它来发送/接收消息,运行消息控制(msgctl(2))操作。
发送消息的调用(msgsnd(2))需要应用程序组建消息,设置消息类型字段,以及生成消息体(例如,一个文本消息)。
1.代码从用户地址空间拷贝消息到内核中的指定区域。
2.接下来,是基本的处理工作——例如,增长处理器统计值,表示消息队列系统调用正在执行。cpu_sysinfo结构维护了一个msg计数器,表明所执行的消息队列系统调用的总数。
3.执行代码验证调用进程的访问权限。
4.消息剩余部分的流程最好的表示方法是伪码。

msgrcv支持代码会简单一些,因为我们只要在队列上得到一个消息(与放入消息到队列中正相反)。对于msgrcv,不需要分配内核资源。接收消息的内核代码流程包括对操作的权限检查,该操作在队列上的所有消息中循环。

1.如果被请求的消息类型与队列中的一个消息匹配,代码会将消息类型复制到用户提供的位置,并且将消息数据复制到用户提供的位置。
2.接下来,代码更新msqid_ds结构的字段,从msg_cbytes中减去消息大小,msg_lrpid中设置PID,msg_rtime中设置时间,释放消息资源,释放消息头(msg结构),并释放资源映射表项。
如果代码对所有消息都循环后,还没有找到匹配的类型,将会返回“没有消息”的错误。
上述操作结束后,应用程序代码会在msgrcv(2)系统调用提供的缓存区中生成消息类型和数据。在这个过程中应用程序所使用的唯一的可调用例程是msgctl(2)。控制函数是直接的,它们主要负责在消息队列的ipc_perm结构中获取或设置值。
3.以IPC_RMID标志位调用msgctl(2)时,意味着调用者想从系统中删除消息队列,内核会遍历队列中的消息链表,释放与每个消息相关联的内核资源。
4.内核发送信号,唤醒在消息队列上睡眠的进程(线程)。进程最终以EIDRM错误结束(ID被删除)。
5.系统仅仅标识msqid_ds结构体为可用,然后返回。

【责任编辑:雪花 TEL:(010)68476606-8007】

回书目   上一节   下一节
专题
Solaris基础知识入门
Linux/Solaris服务器的安全配置
Solaris 10 配置管理
Ajax+JSP网站开发从入门到精通
ASP.NET Ajax网站开发从入门到精通
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 最 大 的 网 络 技 术 网 站 ·
技 术 成 就 梦 想
订阅技术快讯
电子杂志下载
名称:SQL Server数据库管理精品黄皮书
简介:书中文章经过精挑细选,便于用户能根据自己的实际工作和学习,快速在本书寻找到相关资料。内容涵盖了SQL Server的安装与升级、语句查询、数据备份和恢复、自动化任务、数据同步、数据字典、安全和预防、性能和优化、集群等各方面应用信息,以及DBA管理人员在数据库管理工作中
名称:2007路由技术大全
简介:《2007路由技术大全》由51CTO.com网站特别策划制作,该书包括路由器技术、路由器产品、路由器配置、安全设置、路由器故障处理、路由器密码恢复,以及广大网友在实践使用中的心得经验和技巧文章,内容注重实用性,适用于初学者入门,也适合多年从业者提高,是一本实践和理论完
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
浏览器的战国时代
浏览器的战国时代
ARP攻击防范与解决方案
ARP攻击防范与解决方案
NAC安全访问控制
NAC安全访问控制
· NAC安全访问控制
· 网络布线测试仪器
· Windows Server 2008专..
· Windows远程桌面应用
· 网络故障排除宝典
· 运营商封堵ADSL共享 中..
· 解析35岁技术人的价值..
· 世纪枭雄比尔盖茨的王..
· 主流品牌防火墙配置
· ASP.NET开发教程
· 超级计算机TOP500专题
· Vista SP1对决XP SP3
· SQL Server 2008/2005..
· 程序员如何成长?
· C#技术开发指南
· 虚拟化技术还有点“虚”
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
SOA 面向服务架构
SOA 面向服务架构
· SOA 面向服务架构
· SQL Server 2008/2005..
· Apache技术专题
· 三层交换技术专题
· SQL Server入门到精通
· Windows远程桌面应用
· C#技术开发指南
· Apache技术专题
· Windows集群服务应用
· C#技术开发指南
· 国际文档格式标准开战
· 路由器设置与口令恢复
· Linux 集群技术专题
· PHP开发应用手册
· SOA 面向服务架构
· 企业数据恢复指南
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
SQL Server入门到精通
SQL Server入门到精通
· SQL Server入门到精通
· SQL Server 2008/2005..
· SOA 面向服务架构
· Apache技术专题
· C#技术开发指南
· 三层交换技术专题
· Apache技术专题
· C#技术开发指南
· Windows远程桌面应用
· 企业数据恢复指南
· Windows集群服务应用
· 路由器设置与口令恢复
· Linux 集群技术专题
· SOA 面向服务架构
· 了解统一威胁管理(UTM)..
· 反垃圾邮件技术应用