前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >详解Linux共享内存的管理

详解Linux共享内存的管理

作者头像
用户8705036
修改2021-06-08 10:53:19
3.5K0
修改2021-06-08 10:53:19
举报
文章被收录于专栏:linux百科小宇宙linux百科小宇宙

在进程通信应用中会用到共享内存,这就涉及到了IPC,与IPC相关的命令包括:ipcs、ipcrm(释放IPC)。IPCS命令是Linux下显示进程间通信设施状态的工具。我们知道,系统进行进程间通信(IPC)的时候,可用的方式包括信号量、共享内存、消息队列、管道、信号(signal)、套接字等形式[2]。使用IPCS可以查看共享内存、信号量、消息队列的状态。

当下系统是Ubuntu Linux 18.04,执行ipcs命令查看

linuxidc@linuxidc:~/linuxidc.com$ ipcs

--------- 消息队列 -----------

键        msqid      拥有者  权限    已用字节数 消息     

------------ 共享内存段 --------------

键        shmid      拥有者  权限    字节    连接数  状态     

0x00000000 393217    linuxidc  600        524288    2          目标     

0x00000000 425986    linuxidc  600        524288    2          目标     

0x00000000 458755    linuxidc  600        524288    2          目标     

0x00000000 1867780    linuxidc  600        16777216  2          目标     

0x00000000 4456453    linuxidc  600        16777216  2          目标     

0x00000000 557062    linuxidc  600        524288    2          目标     

0x00000000 4554759    linuxidc  600        4194304    2          目标     

0x00000000 1048591    linuxidc  600        67108864  2          目标     

--------- 信号量数组 -----------

键        semid      拥有者  权限    nsems 

 

说明:

第一列就是共享内存的key;

第二列是共享内存的编号shmid;

第三列就是创建的用户owner;

第四列就是权限perms;

第五列为创建的大小bytes;

第六列为连接到共享内存的进程数nattach;

第七列是共享内存的状态status。其中显示“dest”表示共享内存段已经被删除,但是还有用户在使用它,当该段内存的mode字段设置为 SHM_DEST时就会显示“dest”。当用户调用shmctl的IPC_RMID时,内存先查看多少个进程与这个内存关联着,如果关联数为0,就会销 毁这段共享内存,否者设置这段内存的mod的mode位为SHM_DEST,如果所有进程都不用则删除这段共享内存。

具体的用法总结如下:

1、显示所有的IPC设施

linuxidc@linuxidc:~/linuxidc.com$ ipcs -a

--------- 消息队列 -----------

键        msqid      拥有者  权限    已用字节数 消息     

------------ 共享内存段 --------------

键        shmid      拥有者  权限    字节    连接数  状态     

0x00000000 4784128    linuxidc  600        524288    2          目标     

0x00000000 393217    linuxidc  600        524288    2          目标     

0x00000000 425986    linuxidc  600        524288    2          目标     

0x00000000 458755    linuxidc  600        524288    2          目标     

0x00000000 1867780    linuxidc  600        16777216  2          目标     

0x00000000 4816901    linuxidc  600        16777216  2          目标     

0x00000000 557062    linuxidc  600        524288    2          目标     

0x00000000 4554759    linuxidc  600        4194304    2          目标     

0x00000000 1048591    linuxidc  600        67108864  2          目标     

--------- 信号量数组 -----------

键        semid      拥有者  权限    nsems   

2、显示所有的消息队列Message Queue

# ipcs -q

3、显示所有的信号量

# ipcs -s

4、显示所有的共享内存

# ipcs -m

5、显示IPC设施的详细信息

# ipcs -q -i id

id 对应shmid、semid、msgid等。-q对应设施的类型(队列),查看信号量详细情况使用-s,查看共享内存使用-m。

6、显示IPC设施的限制大小

# ipcs -m -l

-m对应设施类型,可选参数包括-q、-m、-s。

7、显示IPC设施的权限关系

# ipcs -c

# ipcs -m -c

# ipcs -q -c

# ipcs -s -c

8、显示最近访问过IPC设施的进程ID。

# ipcs -p

# ipcs -m -p

# ipcs -q -p

9、显示IPC设施的最后操作时间

# ipcs -t

# ipcs -q -t

# ipcs -m -t

# ipcs -s -t

10、显示IPC设施的当前状态

linuxidc@linuxidc:~/linuxidc.com$ ipcs -u

---------- 消息状态 -----------

已分配队列数 = 0

已用消息头(header)数 = 0

已用空间 = 0 字节

---------- 共享内存状态 ------------

段已分配 11

页已分配 27256

页驻留  7083

页交换  0

交换性能:0 次尝试  0 次成功

--------- 信号量状态 -----------

已使用数组 = 0

已分配信号量数 = 0

Linux上的ipcs命令,不支持UNIX上的-b、-o指令,同样UNIX中不支持-l、-u指令,所以在编写跨平台的脚本时,需要注意这个问题。

删除IPC

ipcrm -m| -q| -s shm_id

例如,我们在以0x12345678为KEY创建了一个共享内存,可以直接使用ipcrm -M 0x12345678来删除共享内存区域。

下面的命令可以释放所有已分配的共享内存:

ipcs -m | awk '$2 ~ /[0-9]+/ {print $2}' | while read s; do sudo ipcrm -m $s; done

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
消息队列 CMQ 版
消息队列 CMQ 版(TDMQ for CMQ,简称 TDMQ CMQ 版)是一款分布式高可用的消息队列服务,它能够提供可靠的,基于消息的异步通信机制,能够将分布式部署的不同应用(或同一应用的不同组件)中的信息传递,存储在可靠有效的 CMQ 队列中,防止消息丢失。TDMQ CMQ 版支持多进程同时读写,收发互不干扰,无需各应用或组件始终处于运行状态。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档