unix共享内存消息队列常用命令.doc
文本预览下载声明
unix共享内存、消息队列常用命令
一、共享内存、消息队列基本常识
共享内存指在多处理器的中,可以被不同中央处理器(CPU)访问的大容量内存。由于多个CPU需要快速访问存储器,这样就要对存储器进行缓存(Cache)。任何一个缓存的数据被更新后,由于其他处理器也可能要存取,共享内存就需要立即更新,否则不同的处理器可能用到不同的数据。共享内存 (shared memory)是 Unix下的多进程之间的通信方法 ,这种方法通常用于一个程序的多进程间通信,实际上多个程序间也可以通过共享内存来传递信息。
消息队列就是一个消息的链表。可以把消息看作一个记录,具有特定的格式以及特定的优先级。对消息队列有写权限的进程可以向中按照一定的规则添加新消息;对消息队列有读权限的进程则可以从消息队列中读走消息。Ipcs 共享内存、消息队列查询命令
不带参数为显示所有共享内存、消息队列基本信息
Ipcs –a 显示所有共享内存、消息队列详细信息
Ipcs –am 显示所有共享内存详细信息,关键信息ID、KEY、OWNER、SEGSZ
Ipcs –aq 显示所有消息队列详细信息,关键信息ID、KEY、OWNER、QNUM、QBYTES
2. Ipcrm 共享内存、消息队列清除命令
Ipcrm –M KEY值 或者 ipcrm -m ID值
----可以删除对应的共享内存
Ipcrm –Q KEY值 或者 ipcrm –q ID值
----可以删除对应的消息队列
三、OCS常用命令
1. r5ipc消息队列、内存工具,调用消息队列、共享内存的c函数编写的小工具
Usage : r5ipc [-q] [-m] [-c filename] [-i filename] [-p filename] [-t filename] [-h] [-v]
-h Show help
-v Show version
-q message queue, (-q or -m one must specify)
-m share memory, (-q or -m one must specify)
-c create queue
-i get infomation of queue
-d delete all records in queue
r5ipc -q –c 句柄路径
可以创建消息队列
r5ipc -q -i 句柄路径
可以查看消息队列内容
r5ipc -q -d 句柄路径
可以清空消息队列内容,但不会删除消息队列。
r5ipc –m –c 句柄路径
可以创建共享内存
ri5p –m –d 句柄路径
可以删除共享内存,直接删除
r5ipc 不支持查看共享内存内容
2. ipclook 输入句柄路径得到对应的key值,调用C系统函数ftok得到的key值,主要可用于反查消息队列或共享内存的句柄。
Usage:
ipclook pathname
ipclook 句柄路径 得到对应的key值
反查消息队列或共享内存的方法,首先查到共享内存或消息队列的key1值和owner,确定是哪个用户创建的,再调用iplook查询该用户可能的句柄文件的key2值,可以和key1值相匹配的,即是要查找的句柄
实际反查消息队列或共享内存时,可结合shell来循环查询,加快查找的速度,如快速列出etc路径下所有文件名包含SHM文件的key值,可以使用:
ls | grep SHM | while read line; do ipclook $line; done
ipclook的源代码为:
#includeiostream
# include sys/types.h
# include sys/ipc.h
//##includeerror.h
using namespace std;
int main(int argc,char **argv)
{
if(argc!=2)
{
printf(Usage:\n\t%s pathname\n,argv[0]);
exit (0);
}
key_t kt= ftok(argv[1], 1);
if(kt == (key_t)-1)
显示全部