文档详情

unix共享内存消息队列常用命令.doc

发布:2017-06-10约2.18千字共3页下载文档
文本预览下载声明
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)
显示全部
相似文档