进程间通信与ipcs使用7例
进程间通信(IPC, inter-process communication)实现进程间消息的传递,对于用户地址空间相互独立的两个进程而言,实现通信可以通过以下方式:
- 由内核层面分配内存,两进程共享该段内存
- 两进程读/写同一磁盘文件,通过文件内容实现通信
Linux提供了以下具体方法:
- 管道(pipes):一个进程可通过管道向另一个进程传递消息,不同机器上的进程可通过命名管道相互通信
- 共享内存(shared memory):进程可通过共享内存交换数据,一个进程负责创建共享内存,其他进程可以连接该块内存
- 消息队列(message queue):由队列结构管理的内存块,其中内存块中放置进程数据
- 信号(semaphores):在进程访问共享资源时,信号提供同步机制,其不负责传递其他信息
ipcs是Unix/Linux中的一个用于显示进程间通信信息的命令,其可列出进程间的共享内存、消息队列、信号信息,下面是ipcs的具体用法。
1.列出ipc列表
使用 -a 选项将列出所有ipc信息:
# ipcs -a ------ Shared Memory Segments -------- key shmid owner perms bytes nattch status 0xc616cc44 1056800768 oracle 660 4096 0 0x0103f577 323158020 root 664 966 1 0x0000270f 325713925 root 666 1 2 ------ Semaphore Arrays -------- key semid owner perms nsems 0x0103eefd 0 root 664 1 0x0103eefe 32769 root 664 1 0x4b0d4514 1094844418 oracle 660 204 ------ Message Queues -------- key msqid owner perms used-bytes messages 0x000005a4 32768 root 644 0 0
以上列出了进程间共享内存、信号和消息队列,注意每种 ipc 以 key 和 id 进行标识。-m选项单独列出共享内存信息,-s选项单独列出信号信息,-q选项单独列出消息队列信息。
2.显示ipc信息详情
使用 -i 选项可以显示某 id 的ipc信息详情,如以下显示shmid为65537的共享内存详情:
# ipcs -m -i 65537 Shared memory Segment shmid=65537 uid=1000 gid=100 cuid=1000 cgid=100 mode=01600 access_perms=0600 bytes=393216 lpid=3406 cpid=3400 nattch=2 att_time=Mon Apr 8 13:45:50 2013 det_time=Mon Apr 8 13:45:50 2013 change_time=Mon Apr 8 13:45:50 2013
3.查看ipc限制
内核对各种ipc有一些限制,例如最大的共享内存块数,每块共享内存最大/最小值,使用 -l 选项可显示这些限制:
# ipcs -m -l ------ Shared Memory Limits -------- max number of segments = max seg size (kbytes) = max total shared memory (kbytes) = min seg size (bytes) =
直接使用 ipcs -l 可查看到对三种ipc的限制。
4.显示ipc创建者与拥有者详情
-c 选项可以显示ipc创建者和ipc拥有者的 userid、groupid:
# ipcs -m -c ------ Shared Memory Segment Creators/Owners -------- shmid perms cuid cgid uid gid root root root root lx users lx users lx users lx users
5.显示最近访问ipc的进程pid
-p 选项可以显示哪些进程最近访问了某类ipc:
# ipcs -m -p ------ Shared Memory Creator/Last-op -------- shmid owner cpid lpid root lx
6.显示最近访问时间点
-t 选项显示对ipc最近的操作或连接时间点,对不同的ipc有不同的含义:
- 对于消息队列, -t 显示最近接收和发送时间点
- 对于共享内存,-t 显示最近开始访问和结束访问时间点
- 对于信号,-t 显示最近操作和信号变更时间点
# ipcs -s -t ------ Semaphore Operation/Change Times -------- semid owner last-op last-changed lx Mon Apr :: Mon Apr ::
7.显示当前使用状态
使用 -u 选项可以显示ipc当前使用状况:
# ipcs -u ------ Shared Memory Status -------- segments allocated pages allocated pages resident pages swapped Swap performance: attempts successes ------ Semaphore Status -------- used arrays = allocated semaphores = ------ Messages: Status -------- allocated queues = used headers = used space = bytes
Reference: 10 IPCS Command Examples (With IPC Introduction)
进程间通信与ipcs使用7例的更多相关文章
- 一起talk C栗子吧(第九十 三回:C语言实例--进程间通信之临界资源)
各位看官们.大家好,前面章回中咱们说的是使用信号和管道进行进程间通信的样例.这一回咱们说的样例是:进程间通信之临界资源.闲话休提,言归正转.让我们一起talk C栗子吧! 我们首先介绍一下,什么是临界 ...
- Linux工具参考篇(网摘)
Linux工具参考篇 原文出处:[Linux Tools Quick Tutorial] 1. gdb 调试利器 2. ldd 查看程序依赖库 3. lsof 一切皆文件 4. ps 进程查看器 5. ...
- 进程间通信 ipcs
在linux系统上借助ipcs命令可以方便地查看进程间通信状态 操作系统:centos7.3 x86_64 应用软件: oracle12c
- Linux进程间通信 共享内存+信号量+简单样例
每个进程都有着自己独立的地址空间,比方程序之前申请了一块内存.当调用fork函数之后.父进程和子进程所使用的是不同的内存. 因此进程间的通信,不像线程间通信那么简单.可是共享内存编程接口能够让一个进程 ...
- 运维ps语法---》ps、pstree、top、htop、nice、renice、kill、ulimit、w 和 who 和 whoami、pgrep、fg 和 bg、ipcs
Linux中的ps命令是Process Status的缩写.ps命令用来列出系统中当前运行的那些进程.ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信 ...
- 进程间通信之-共享内存Shared Memory--linux内核剖析(十一)
共享内存 共享内存是进程间通信中最简单的方式之中的一个. 共享内存是系统出于多个进程之间通讯的考虑,而预留的的一块内存区. 共享内存同意两个或很多其他进程訪问同一块内存,就如同 malloc() 函数 ...
- Linux系统编程——进程间通信:共享内存
概述 url=MdyPihmS_tWLwgWL5CMzaTrwDFHu6euAJJUAjKvlzbJmRw7RfhmkBWwAloo7Y65hLY-kQdHsbqWYP2wc2fk8yq"& ...
- Linux命令:ipcs/ipcrm命令
ipcs/ipcrm命令 是linux/uinx上提供关于一些进程间通信方式的信息,包括共享内存,消息队列,信号 多进程间通信常用的技术手段包括共享内存.消息队列.信号量等等,Linux系统下自带的 ...
- 【windows 操作系统】进程间通信(IPC)简述|无名管道和命名管道 消息队列、信号量、共享存储、Socket、Streams等
一.进程间通信简述 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区,进 ...
随机推荐
- concat的应用
今天遇到一个问题,有一张车辆信息表,一张车辆品牌表,他们之间的品牌进行关联, 但是车辆信息表中品牌的名称较长,而品牌表名称较短.例如:车辆表:东风标致:品牌表:标致. 为了达到两种表的“模糊关联”. ...
- django基础知识之中间件:
中间件 是一个轻量级.底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出 激活:添加到Django配置文件中的MIDDLEWARE_CLASSES元组中 每个中间件 ...
- 对http请求进行过滤处理,转换成接收着需要的格式
需要在Global.asax的Application中进行初始化处理 这样:GlobalConfiguration.Configuration.MessageHandlers.Add(new Defa ...
- Perm排列计数(新博客试水,写的不好,各路大神见谅)
B. Perm 排列计数 内存限制:512 MiB 时间限制:1000 ms 标准输入输出 题目描述 称一个1,2,...,N的排列P1,P2...,Pn是Magic的,当且仅当2<=i&l ...
- 一个内存不能被written的问题
C程序面试中曾经面试过这样一道题: #include <stdio.h> int main() { char *p = "12345"; *p = '6'; print ...
- mac 部署安装接口自动化持续集成 jmeter+ant+jenkins
由于前段时间刚换的工作,公司用的是mac电脑办公,之前办公都是windows系统.刚开始使用时连基本的操作都要去找度娘,很不习惯,新电脑开始就是安装相关的工作工具 下面就说说遇到的哪些坑. 1. m ...
- Vue匿名组件使用keep-alive后动态清除缓存
在使用Vue开发管理系统项目的时候,为了保存页面的浏览状态,我们可以使用内置组件keep-alive来缓存组件内部状态,避免重新渲染. <keep-alive> <router-vi ...
- 个人永久性免费-Excel催化剂功能第22波-Excel文件类型、密码批量修改,补齐PowerQuery短板
Excel的多工作薄.多工作表批量合并功能,Excel用户很多这方面的使用场景,也促使了各大Excel各大插件们都在此功能上有所开发,体验程度不一,但总体能够满足大多数的应用场景,本人之前也开发个单独 ...
- http面试笔试常考知识点(二)
接上一篇随笔 1. https协议为什么比http安全? 内容加密:建立一个信息安全通道,确保信息传输安全: 身份认证:确保网站的真实性: 数据完整性校验:防止内容被第三方冒充或者篡改 2.常见状态码 ...
- 2019杭电多校第一场hdu6581 Vacation
Vacation 题目传送门 update(O(n)) 看了那个O(n)的方法,感觉自己想的那个O(nlogn)的好傻,awsl. 0车最终通过停车线的时候,状态一定是某个车堵住后面的所有车(这个车也 ...