0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux下進(jìn)程通訊消息隊(duì)列

嵌入式技術(shù) ? 來(lái)源:嵌入式技術(shù) ? 作者:嵌入式技術(shù) ? 2022-08-19 19:56 ? 次閱讀

Linux下進(jìn)程通訊消息隊(duì)列

?MQ(message queue),從字面意思上看,本質(zhì)是個(gè)隊(duì)列,F(xiàn)IFO 先入先出,只不過(guò)隊(duì)列中存放的內(nèi)容是message 而已。MQ 是在消息的傳輸過(guò)程中保存消息的容器。多用于分布式系統(tǒng)之間進(jìn)行通信。

消息隊(duì)列與 FIFO 很相似,都是一個(gè)隊(duì)列結(jié)構(gòu),都可以有多個(gè)進(jìn)程往隊(duì)列里面寫信息,多個(gè)進(jìn)程從隊(duì)列中讀取信息。

1.查看消息隊(duì)列命令

??1.查看消息隊(duì)列:ipcs -q

[wbyq@wbyq ~]$ ipcs -q

--------- 消息隊(duì)列 -----------
鍵        msqid      擁有者  權(quán)限     已用字節(jié)數(shù) 消息      
0xb8104ad9 1          wbyq       644        0            0           
0xd2350093 2          wbyq       666        208          2  

??2.查看消息隊(duì)列限制信息:ipcs -lq

[wbyq@wbyq ~]$ ipcs -lq

---------- 消息限制 -----------
系統(tǒng)最大隊(duì)列數(shù)量 = 32000
最大消息尺寸 (字節(jié)) = 8192
默認(rèn)的隊(duì)列最大尺寸 (字節(jié)) = 16384

??3.查看消息隊(duì)列詳細(xì)信息:ipcs -q -i

[wbyq@wbyq ~]$ ipcs -q -i 2

消息隊(duì)列 msqid=2
uid=1000	gid=1000	cuid=1000	cgid=1000	模式=0666
cbytes=208	qbytes=16384	qnum=2	lspid=10177	lrpid=10175
發(fā)送時(shí)間=Thu Apr 28 11:56:08 2022  
接收時(shí)間=Thu Apr 28 11:56:08 2022  
更改時(shí)間=Thu Apr 28 11:49:04 2022  

??4.創(chuàng)建消息隊(duì)列:ipcmk -Q

[wbyq@wbyq ~]$ ipcmk -Q
消息隊(duì)列 id:4
[wbyq@wbyq ~]$ ipcs -q

--------- 消息隊(duì)列 -----------
鍵        msqid      擁有者  權(quán)限     已用字節(jié)數(shù) 消息      
0xb8104ad9 1          wbyq       644        0            0           
0xd2350093 2          wbyq       666        208          2           
0x05ae2c01 4          wbyq       644        0            0        

5.刪除信號(hào)量:ipcrm -q

[wbyq@wbyq ~]$ ipcrm -q 4
[wbyq@wbyq ~]$ ipcs -q
--------- 消息隊(duì)列 -----------
鍵        msqid      擁有者  權(quán)限     已用字節(jié)數(shù) 消息      
0xb8104ad9 1          wbyq       644        0            0           
0xd2350093 2          wbyq       666        208          2    

2.相關(guān)函數(shù)

#include 
#include 
#include 
int msgget(key_t key, int msgflg);
函數(shù)功能:創(chuàng)建消息隊(duì)列
形參:key 鍵值,ftok產(chǎn)生
? ? ?msgflg?標(biāo)志 IPC_CREAT|0666
返回值:失敗返回-1,成功返回msqid
int msgsnd(int msqid, const void *msgp, size_t msgsz, int msgflg);
函數(shù)功能: 將消息添加到隊(duì)列中
形參:msqid msgget函數(shù)返回值
???msgp 消息內(nèi)容數(shù)據(jù),一般以結(jié)構(gòu)體類型填充
??????struct msgbuf {
????????????long mtype; /* 消息類型, 必須 > 0 */
????????????char mtext[1]; /消息數(shù)據(jù)/
????????????};
??????注意:struct msgbuf必須自己重寫,第一個(gè)參數(shù)long mtype必須指定,且>0,其他類型自定義
???msgsz 消息字節(jié)數(shù),大小為:sizeof(struct msgbuf)-sizeof(mtype);
???msgflg 0當(dāng)隊(duì)列滿時(shí)阻塞,直到消息寫入成功
??????IPC_NOWAIT 當(dāng)隊(duì)列滿時(shí)不阻塞,立刻返回
??????IPC_NOERROR 若發(fā)送的消息大于 size 字節(jié),則把該消息截?cái)?,截?cái)嗖糠謱⒈粊G棄,且不通知發(fā)送進(jìn)程。
返回值:成功返回0,失敗返回-1;
ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp,int msgflg);
函數(shù)功能:從隊(duì)列中取出消息
形參:msqid msgget函數(shù)返回值
???msgp 存放讀取到的消息內(nèi)容
???msgsz 消息字節(jié)數(shù),大小為:sizeof(struct msgbuf)-sizeof(mtype);
???msgtyp 消息類型:
???????>0 接收對(duì)列中的第 1 個(gè)類型等于 msgtyp 的消息
???????==0 取出消息隊(duì)列中的第一條消息
???????<0 接收其類型小于或等于 msgtyp 絕對(duì)值的第 1 個(gè)最低類型消息
???msgflg 0 當(dāng)隊(duì)列空時(shí)阻塞,或者消息類型不匹配時(shí)阻塞
?????? IPC_NOWAIT 不阻塞,立刻返回
?????? IPC_NOERROR 若發(fā)送的消息大于 size 字節(jié),則把該消息截?cái)?,截?cái)嗖糠謱⒈粊G棄,且不通知發(fā)送進(jìn)程。
返回值:成功返回讀取的字節(jié)數(shù),失敗返回-1;
int msgctl(int msqid, int cmd, struct msqid_ds *buf);
函數(shù)功能:控制函數(shù)
形參:msqid msgget函數(shù)返回值
???cmd 通常為 IPC_RMID 表示刪除消息隊(duì)列。
當(dāng)刪除消息隊(duì)列時(shí),則buf填NULL即可;

3.示例

??(1)創(chuàng)建消息隊(duì)列,添加消息到隊(duì)列

#include 
#include 
#include 
#include 
#include 
#include 
#include 
struct msgbuf
{
	long mtype;//消息類型,必須>0
	int cnt;
	char buff[100];
};
int main(int argc,char *argv[])
{
	if(argc!=4)
	{
		printf("格式:./app <消息類型> <消息數(shù)據(jù)> <消息內(nèi)容>\n");
		return 0;
	}
    key_t key=ftok("msgsnd.c", 1234);//生成鍵值
	if(key==-1)
	{
		printf("生成鍵值失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("key=%#x\n",key);
	int msqid=msgget(key,IPC_CREAT|0666);//創(chuàng)建消息隊(duì)列
	if(msqid==-1)
	{
		printf("創(chuàng)建消息隊(duì)列失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("msqid=%d\n",msqid);
	struct msgbuf msg;
	msg.mtype=atoi(argv[1]);//消息類型
	msg.cnt=atoi(argv[2]);//消息數(shù)據(jù)
	strcpy(msg.buff,argv[3]);//消息內(nèi)容
	int msg_size=sizeof(msg)-sizeof(long);//消息大小,總大小-消息類型大小
	/*添加消息到隊(duì)列*/
	int size=msgsnd(msqid,&msg,msg_size,0);
	if(size==-1)
	{
		printf("寫入消息失敗err=%s\n",strerror(errno));
	}
	else printf("消息寫入成功\n");
	return 0;
}  

??(2)從隊(duì)列中取消息

#include 
#include 
#include 
#include 
#include 
#include 
#include 
struct msgbuf
{
	long mtype;//消息類型,必須>0
	int cnt;
	char buff[100];
};
int main(int argc,char *argv[])
{
	if(argc!=2)
	{
		printf("格式:./app <消息類型>\n");
		return 0;
	}
    key_t key=ftok("msgsnd.c", 1234);//生成鍵值
	if(key==-1)
	{
		printf("生成鍵值失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("key=%#x\n",key);
	int msqid=msgget(key,IPC_CREAT|0666);//創(chuàng)建消息隊(duì)列
	if(msqid==-1)
	{
		printf("創(chuàng)建消息隊(duì)列失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("msqid=%d\n",msqid);
	struct msgbuf msg;
	int msg_size=sizeof(msg)-sizeof(long);//消息大小
	long msgtyp=atoi(argv[1]);//要寫讀取的消息類型
	//從消息隊(duì)列中取數(shù)據(jù)
	ssize_t size=msgrcv(msqid,&msg,msg_size,msgtyp,0);
	if(size==-1)
	{
		printf("讀取消息失敗err=%s\n",strerror(errno));
	}
	else 
	{
		printf("------------讀取消息成功size:%ld----------------\n",size);
		printf("\tmtype=%ld\n",msg.mtype);
		printf("\tcnt=%d\n",msg.cnt);
		printf("\tbuff=%s\n",msg.buff);
	}
	return 0;
}  

??(3)運(yùn)行效果

pYYBAGL_eXuABxWmAAeJ5O7XsAY981.png#pic_center


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11161

    瀏覽量

    208459
  • IPC
    IPC
    +關(guān)注

    關(guān)注

    3

    文章

    335

    瀏覽量

    51712
  • 進(jìn)程
    +關(guān)注

    關(guān)注

    0

    文章

    198

    瀏覽量

    13933
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式環(huán)形隊(duì)列與消息隊(duì)列的實(shí)現(xiàn)原理

    嵌入式環(huán)形隊(duì)列,也稱為環(huán)形緩沖區(qū)或循環(huán)隊(duì)列,是一種先進(jìn)先出(FIFO)的數(shù)據(jù)結(jié)構(gòu),用于在固定大小的存儲(chǔ)區(qū)域中高效地存儲(chǔ)和訪問(wèn)數(shù)據(jù)。其主要特點(diǎn)包括固定大小的數(shù)組和兩個(gè)指針(頭指針和尾指針),分別指向隊(duì)列的起始位置和結(jié)束位置。
    的頭像 發(fā)表于 09-02 15:29 ?211次閱讀

    深入探討Linux進(jìn)程調(diào)度器

    Linux操作系統(tǒng)作為一個(gè)開源且廣泛應(yīng)用的操作系統(tǒng),其內(nèi)核設(shè)計(jì)包含了許多核心功能,而進(jìn)程調(diào)度器(Scheduler)就是其中一個(gè)至關(guān)重要的模塊。進(jìn)程調(diào)度器負(fù)責(zé)決定在任何給定的時(shí)刻哪個(gè)進(jìn)程
    的頭像 發(fā)表于 08-13 13:36 ?845次閱讀
    深入探討<b class='flag-5'>Linux</b>的<b class='flag-5'>進(jìn)程</b>調(diào)度器

    進(jìn)程間通信的消息隊(duì)列介紹

    消息隊(duì)列是一種非常常見的進(jìn)程間通信方式。
    的頭像 發(fā)表于 04-08 17:27 ?260次閱讀

    linux查詢進(jìn)程占用的內(nèi)存方法有哪些?

    linux查詢進(jìn)程占用的內(nèi)存方法
    發(fā)表于 04-08 06:03

    淺談Linux進(jìn)程

    進(jìn)程和程序的區(qū)別: 進(jìn)程是動(dòng)態(tài)的,程序是靜態(tài)的 一、進(jìn)程的創(chuàng)建(fork()函數(shù)) int main(){ pid_t pid; pid=fork(); if(pid?????>0
    的頭像 發(fā)表于 01-28 15:54 ?222次閱讀
    淺談<b class='flag-5'>Linux</b>的<b class='flag-5'>進(jìn)程</b>

    labview 隊(duì)列最前端插入的應(yīng)用

    起到很多作用。本文將詳細(xì)介紹LabVIEW隊(duì)列的應(yīng)用,特別是在最前端插入數(shù)據(jù)的情況。 首先,讓我們了解LabVIEW隊(duì)列的基本概念。隊(duì)列是一種數(shù)據(jù)結(jié)構(gòu),允許在一端插入元素,并在另一端
    的頭像 發(fā)表于 01-08 11:45 ?1065次閱讀

    Linux進(jìn)程、線程和協(xié)程的基礎(chǔ)概念

    進(jìn)程是計(jì)算機(jī)中運(yùn)行的程序的實(shí)例,它是操作系統(tǒng)中最基本的執(zhí)行單元之一。每個(gè)進(jìn)程都有自己的獨(dú)立內(nèi)存空間、系統(tǒng)資源和代碼執(zhí)行流。這意味著一個(gè)進(jìn)程的崩潰通常不會(huì)影響其他進(jìn)程,
    的頭像 發(fā)表于 12-06 09:22 ?711次閱讀

    linux查看weblogic進(jìn)程

    Linux操作系統(tǒng)中,WebLogic是一種常用的Java應(yīng)用服務(wù)器,用于部署和管理企業(yè)級(jí)Java應(yīng)用程序。為了確保WebLogic服務(wù)器正常運(yùn)行,有時(shí)我們需要查看WebLogic進(jìn)程以了解其狀態(tài)
    的頭像 發(fā)表于 12-05 16:07 ?1642次閱讀

    Linux進(jìn)程通信的方法

    進(jìn)程是操作系統(tǒng)的概念,每當(dāng)我們執(zhí)行一個(gè)程序時(shí),對(duì)于操作系統(tǒng)來(lái)講就創(chuàng)建了一個(gè)進(jìn)程,在這個(gè)過(guò)程中,伴隨著資源的分配和釋放??梢哉J(rèn)為進(jìn)程是一個(gè)程序的一次執(zhí)行過(guò)程。
    的頭像 發(fā)表于 11-29 14:45 ?640次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>下</b><b class='flag-5'>進(jìn)程</b>通信的方法

    linux開發(fā)避免僵尸進(jìn)程的方法

    一、什么是僵死進(jìn)程? 一般情況,程序調(diào)用exit(包括_exit和_Exit,它們的區(qū)別這里不做解釋),它的絕大多數(shù)內(nèi)存和相關(guān)的資源已經(jīng)被內(nèi)核釋放掉,但是在進(jìn)程表中這個(gè)進(jìn)程項(xiàng)(ent
    的頭像 發(fā)表于 11-11 16:38 ?654次閱讀
    <b class='flag-5'>linux</b><b class='flag-5'>下</b>開發(fā)避免僵尸<b class='flag-5'>進(jìn)程</b>的方法

    如何實(shí)現(xiàn)一套linux進(jìn)程間通信的機(jī)制

    我們知道linux進(jìn)程的間通信的組件有管道,消息隊(duì)列,socket, 信號(hào)量,共享內(nèi)存等。但是我們?nèi)绻约簩?shí)現(xiàn)一套進(jìn)程間通信的機(jī)制的話,要怎么做?了解android 開發(fā)的可能會(huì)知道
    的頭像 發(fā)表于 11-10 14:56 ?579次閱讀
    如何實(shí)現(xiàn)一套<b class='flag-5'>linux</b><b class='flag-5'>進(jìn)程</b>間通信的機(jī)制

    Linux系統(tǒng)上多線程和多進(jìn)程的運(yùn)行效率

    深受其害。 經(jīng)常在網(wǎng)絡(luò)上看到有的XDJM問(wèn)“多進(jìn)程好還是多線程好?”、“Linux用多進(jìn)程還是多線程?”等等期望一勞永逸的問(wèn)題,我只能說(shuō):沒(méi)有最好,只有更好。根據(jù)實(shí)際情況來(lái)判斷,哪個(gè)
    的頭像 發(fā)表于 11-10 10:54 ?1216次閱讀
    <b class='flag-5'>Linux</b>系統(tǒng)上多線程和多<b class='flag-5'>進(jìn)程</b>的運(yùn)行效率

    基于ARM-Linux嵌入式系統(tǒng)的多進(jìn)程并發(fā)服務(wù)器設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《基于ARM-Linux嵌入式系統(tǒng)的多進(jìn)程并發(fā)服務(wù)器設(shè)計(jì).pdf》資料免費(fèi)下載
    發(fā)表于 11-08 15:31 ?0次下載
    基于ARM-<b class='flag-5'>Linux</b>嵌入式系統(tǒng)的多<b class='flag-5'>進(jìn)程</b>并發(fā)服務(wù)器設(shè)計(jì)

    消息隊(duì)列的發(fā)展歷史

    上一篇我們用一個(gè)秒殺案例探討了我們?yōu)槭裁葱枰?b class='flag-5'>隊(duì)列。今天我們來(lái)回顧一消息隊(duì)列的發(fā)展歷史。
    的頭像 發(fā)表于 10-30 10:49 ?960次閱讀
    消息<b class='flag-5'>隊(duì)列</b>的發(fā)展歷史

    Linux TCP隊(duì)列相關(guān)參數(shù)的總結(jié)

    Linux上做網(wǎng)絡(luò)應(yīng)用的性能優(yōu)化時(shí),一般都會(huì)對(duì)TCP相關(guān)的內(nèi)核參數(shù)進(jìn)行調(diào)節(jié),特別是和緩沖、隊(duì)列有關(guān)的參數(shù)。很多文章會(huì)告訴你需要修改哪些參數(shù),但我們經(jīng)常是知其然而不知其所以然,每次照抄過(guò)來(lái)后,可能很快就忘記或混淆了它們的含義。
    發(fā)表于 10-30 10:12 ?812次閱讀
    <b class='flag-5'>Linux</b> TCP<b class='flag-5'>隊(duì)列</b>相關(guān)參數(shù)的總結(jié)