Linux进程间通信(IPC)的几种方式

概述:

进程间通信(IPC,Inter-Process Communication),指至少两个进程或线程间传送数据或信号的一些技术或方法。进程是计算机系统分配资源的最小单位(进程是分配资源最小的单位,而线程是调度的最小单位,线程共用进程资源)。每个进程都有自己的一部分独立的系统资源,彼此是隔离的。为了能使不同的进程互相访问资源并进行协调工作,才有了进程间通信。


主要方法:

管道:

分为两种,

软管道: 如 ps -ef | grep xxxx,

硬管道:

消息队列:

内核创建一个消息队列,操作系统中的多个进程都可以操作这个消息队列.可以向其发送消息,也可从中接收消息.

共享内存:

每个进程都有一个虚拟内存地址和物理内存地址的映射,一般两个进程的映射的物理内存地址是不同的,共享内存即是将其映射的物理内存地址变成一样的.这样两个进程就可以访问相同的物理内存,也就可以实现进程之间的通信.

套接字:

非常常见,如通过3306端口访问某个远程mysql服务, 我访问mysql的这个进程,和远程的这个mysql服务的进程之间的通信,就是通过3306端口创建的TCP的套接字.

如果是访问本机的mysql服务,则不会走TCP套接字,而是走Linux底层的套接字

信号量:

类似一个计数器.控制多个进程对一个共享资源的访问.

信号:

一个进程可以向另一个进程发送一个信号.通过kill -l指令可以列出所有的信号

(64种死法...)

Linux中的信号 大多数作用是把一个进程杀死,于是叫kill了..

tail -f xxx文件时,是会一直是阻塞. 如何结束? 一般会按ctrl+c,

其实该命令就是当前的shell($$可以看到当前shell的pid),向tail -f进程发送了一个信号,该信号值是2,即SIGINT

kill -9 pid, 9号信号是SIGKILL.

如果不加,则默认15号信号SIGTERM(即Terminal)

9号信号即kill信号是不能被捕捉的,必须强制停止. 其他信号可以在程序中捕捉到.

ctrl+c : SIGINT

kill不带参数: SIGTERM

KILL -9: SIGKILL


各个编号的含义,可参见
linux kill -l 信号列表

相关推荐
灰勒塔德4 分钟前
Linux文件IO
linux·运维·服务器
编码浪子41 分钟前
构建一个rust生产应用读书笔记7-确认邮件2
开发语言·后端·rust
昙鱼1 小时前
springboot创建web项目
java·前端·spring boot·后端·spring·maven
白宇横流学长1 小时前
基于SpringBoot的停车场管理系统设计与实现【源码+文档+部署讲解】
java·spring boot·后端
kirito学长-Java1 小时前
springboot/ssm太原学院商铺管理系统Java代码编写web在线购物商城
java·spring boot·后端
花姐夫Jun1 小时前
在 CentOS 8 系统上安装 Jenkins 的全过程
linux·centos·jenkins
是店小二呀2 小时前
【Linux】Linux开发利器:make与Makefile自动化构建详解
linux·运维·自动化
程序猿-瑞瑞2 小时前
24 go语言(golang) - gorm框架安装及使用案例详解
开发语言·后端·golang·gorm
组合缺一2 小时前
Solon v3.0.5 发布!(Spring 可以退休了吗?)
java·后端·spring·solon
猿来入此小猿2 小时前
基于SpringBoot在线音乐系统平台功能实现十二
java·spring boot·后端·毕业设计·音乐系统·音乐平台·毕业源码