【Linux】对system V本地通信的内核级理解

这篇具有很好参考价值的文章主要介绍了【Linux】对system V本地通信的内核级理解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

 一、system V版本的进程间通信技术  

        通过之前的学习,我们大致可以感受出来,共享内存,消息队列和信号量在使用的时候是有很多共性的。它们三个的接口,包括接口中传的参数有的都有很大的相似度。其实,共享内存,消息队列和信号量是操作系统针对本地进程间通信特意设计出来的system V版本的进程间通信(IPC,Inter Process Communication)技术。共享内存,消息队列和信号量所管理的资源称为IPC资源。在操作系统底层,共享内存,消息队列和信号量都是有相对应的结构体将它们维护起来的

二、共享内存,消息队列和信号量对应的结构体

2.1、共享内存内核结构体

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

  • shm_perm:表示该共享内存的所有权和权限 

下面就是ipc_perm结构体的内核 

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

  • _key:就是我们用ftok函数设置进共享内存中的key
  • uid:共享内存所有者的有效用户ID。这通常是在创建共享内存段时指定用户的ID。只有具有适当权限的用户才能对共享内存段执行特定的操作(如读、写或删除)。
  • gid:共享内存所有者所属组的有效组ID。类似于uid,它用于确定组级别的权限。如果一个进程属于拥有共享内存段的组,那么它可能具有额外的访问权限。
  • cuid:共享内存创建者的有效用户ID。这个字段用于记录最初创建共享内存段的用户的ID,通常用于审计或追踪目的。
  • cgid:共享内存创建者所属组的有效组ID。类似于cuid,它记录了创建共享内存段的组的ID。
  • mode:该共享内存的权限
  • _seq:_seq字段通常用于确保IPC对象的唯一性和追踪对象的更改。当IPC对象(如共享内存段、信号量或消息队列)被创建、修改或删除时,其序列号可能会发生变化。这有助于防止IPC对象的重复创建和避免竞态条件

        只有超级用户或创建IPC对象的进程才有权改变ipc_perm结构体的值。其他进程只能根据这些值来确定它们对共享内存段的访问权限。 

共享内存内核结构体剩余成员变量

  • shm_segsz:该共享内存的大小。
  • shm_atime:该共享内存最后一次挂接的时间。
  • shm_dtime:该共享内存最后一次去挂接的时间。
  • shm_ctime:该共享内存最后一次修改的时间。
  • shm_cpid:创建该共享内存的进程的pid。
  • shm_lpid:   最后一个挂接或去挂接该共享内存的进程的pid。
  • shm_nattch:表示当前附加到共享内存段的进程数。 

2.2、消息队列内核结构体

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

 2.3、信号量内核结构体

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言 【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

2.4、内核间的共性

        上面详细地介绍了共享内存的内核结构及其各个字段代表的含义,消息队列和信号量的字段有的含义跟共享内存是一样的,如果大家想了解的更多,可以在命令行中通过man指令进行查阅,这里不做赘述。这里只是想输出一个结论,共享内存、消息队列和信号量的内核在实现的时候是有很多相似性的,换句话说,就是它们三个是一个体系中的东西,在本地进程间通信这个体系中。 

三、共享内存,消息队列和信号量在内核中的组织方式

        通过上面的介绍,我们会发现,描述共享内存,消息队列和信号量的结构体的第一个成员变量都是一个叫struct ipc_perm的结构体,这个结构体在阐述共享内存时已经有详细介绍了。其中,在操作系统内核中,会有一个ipc_id_ary数组,类型就为struct ipc_perm*。未来当我们要创建一个共享内存或消息队列或信号量时,我们需要先顺着ipc_id_array数组中的下标往后找,找到一个下标后在这个下标中填入新的初始化好的struct ipc_perm*(有对应的算法来往后推算数组下标),再将共享内存或消息队列或信号量的结构体中其它的属性填好,这样一个共享内存或消息队列或信号量就被创建出来了。当我们要删除一个IPC资源的时候,只需要在该数组中将对应下标中的struct ipc_perm*释放掉就可以了。这样对IPC资源的管理就变成了对数组的增删查改

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

        当我们要对一个IPC资源做管理时,只需要对ipc_id_array数组中对应位置的struct ipc_perm*做强转就可以将这个结构体地址强转成一个共享内存或消息队列或信号量的地址,这时该IPC资源的类型就确定了,类型确定了里面该有的属性也就确定了。这就是C++语言中多态的思想。因为操作系统是C语言写的,所以只能用指针强转实现上面的效果

【Linux】对system V本地通信的内核级理解,linux,服务器,后端,信息与通信,网络,c语言

        因为结构体的第一个成员变量是struct ipc_perm*,我们也知道结构体第一个成员变量的地址就是整个结构体的起始地址,未来通过第一个成员变量的地址加上偏移量我们也可以访问该结构体中的其他成员变量。

四、总结

        其实System V的通信技术在现在已经逐渐被边缘化了。System V是一个单独设计的内核模块,其标准的设计不符合Linux下一切皆文件的思想。尽管隶属于文件部分,但已经是一个独立的模块,且shmid与文件描述符之间的兼容性做得并不好。通过上面的学习我们也可以看到,System V自己搞了一个类似于文件描述符表的ipc_id_ary数组,与文件那一套背离了。网络通信使用的是文件的接口,这使得System V标准在整合进网络结构时面临困难。随着POSIX标准的出现和普及,它为进程间通信提供了一套统一的接口和规范,使得不同的操作系统和应用程序在进程间通信上有了更好的兼容性和互操作性。这也进一步削弱了System V IPC的地位。System V版本的进程间通信技术由于设计上的局限性、与现代操作系统和网络结构的不兼容性以及新兴技术的出现,逐渐被边缘化。文章来源地址https://www.toymoban.com/news/detail-856471.html

到了这里,关于【Linux】对system V本地通信的内核级理解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【1000个GDB技巧之】如何在远端服务器打开通过vscode动态观测Linux内核实战篇?

    (也可以直接在vscode中配置,忽略) 主要步骤:在~/.ssh/config中添加服务端的host,以便vscode的remote中能够登录 详细配置过程参考兄弟篇文章:ssh config如何配置用host名替代root@1.1.1.1 初次使用remote功能,需要在远端安装一个ssh的代理,需要耗费一定时间。 添加一个调试配置文

    2024年04月16日
    浏览(40)
  • 【内网穿透】Linux本地搭建GitLab服务器

    转载自cpolar极点云文章:Linux搭建GitLab私有仓库,并内网穿透实现公网访问 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的Web服务。 Gitlab是被广泛使用的基于git的开源代码管理平台, 基于Ruby on Rails构建, 主要针对软件开发过程中

    2024年02月07日
    浏览(41)
  • 使用Docker在Linux服务器本地部署PaddleSpeech Web服务

    1. 从官方Docker Hub拉取环境 2. 启动容器并分派端口 3. 自然语言处理工具库NLTK安装 方法一:使用 nltk 自带的 download() 下载,由于国内网络问题,大概率失败。 方法二:从下载文件手动安装包。 链接:https://pan.baidu.com/s/1nQveCEAucFSNbuOAsrs6yw?pwd=yydh 提取码:yydh 从百度网盘下载nlt

    2024年01月20日
    浏览(51)
  • 【Linux内网穿透】】Linux本地搭建GitLab服务器 - 内网穿透远程访问

    转载自cpolar极点云文章:Linux搭建GitLab私有仓库,并内网穿透实现公网访问 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的Web服务。 Gitlab是被广泛使用的基于git的开源代码管理平台, 基于Ruby on Rails构建, 主要针对软件开发过程中

    2024年02月07日
    浏览(48)
  • 从Linux服务器下载文件到window本地电脑

    1.  用sz命令 如果通过xshell连接到服务器,且为SSH方式,则可以用sz命令,直接在Linux的提示符下操作。 此方法一定是要用xshell或其他类似的软件用ssh的钥匙方式登录Linux才可以使用 2 . 使用Git Bashscp命令 如果Windows安装了Git,可以通过打开Git bash用scp命令远程拷贝文件到本地 此

    2024年02月11日
    浏览(53)
  • IDEA实现ssh远程连接本地Linux服务器

    本文主要介绍如何在IDEA中设置远程连接服务器开发环境,并结合Cpolar内网穿透工具实现无公网远程连接,然后实现远程Linux环境进行开发。 IDEA的远程开发功能,可以将本地的编译、构建、调试、运行等工作都放在远程服务器上执行,而本地仅运行客户端软件进行常规的开发

    2024年02月22日
    浏览(56)
  • Linux AMH服务器管理面板本地安装与远程访问

    最近,我发现了一个超级强大的人工智能学习网站。它以通俗易懂的方式呈现复杂的概念,而且内容风趣幽默。我觉得它对大家可能会有所帮助,所以我在此分享。点击这里跳转到网站。 AMH 是一款基于 Linux 系统的服务器管理面板,它提供了一系列的功能,包括网站管理、

    2024年02月05日
    浏览(67)
  • Linux本地搭建GitLab服务器 - 内网穿透远程访问

    转载自cpolar极点云文章:Linux搭建GitLab私有仓库,并内网穿透实现公网访问 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的Web服务。 Gitlab是被广泛使用的基于git的开源代码管理平台, 基于Ruby on Rails构建, 主要针对软件开发过程中

    2024年02月06日
    浏览(60)
  • (Windows )本地连接远程服务器(Linux),免密码登录设置

    在使用VScode连接远程服务器时,每次打开都要输入密码,以及使用ssh登录或其它方法登录,都要本地输入密码,这大大降低了使用感受,下面总结了免密码登录的方法,用起来巴适得很,起飞。 本地必须在PowerShell终端操控,如下: 打开终端后在终端输入以下命令: 回车再回

    2024年02月11日
    浏览(56)
  • Linux下TCP网络服务器与客户端通信程序入门

    实现客户端连接服务器,通过终端窗口发送信息给服务器端,服务器接收到信息后对信息数据进行回传,客户端读取回传信息并返回。 服务器当前IP地址要知道 建立socket 绑定本地IP地址并设置端口号 知道服务器的IP地址和端口号 然后进行连接

    2024年02月14日
    浏览(62)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包