首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【进程间通信】IPC、管道pipe、命名管道FIFO

③ 如果父进程关闭管道读端,子进程关闭管道写端,此时父进程可以向管道中写入数据,子进程将管道中的数据读出,反之同理。...问题就在这里,虽然子进程已经变成了僵尸进程,但是父进程依然持有写端文件描述符,所以父进程就会认为还存在其他进程来写入管道,于是父进程就会等待写入,而不退出。...如果管道读端没有全部关闭 如果管道已满,write阻塞,(管道实际上是内核中的一个缓冲区,它是有大小的)。 如果管道未满,write将数据写入,并返回实际写入的字节数。...只能用于有血缘关系的进程间通信(父子、兄弟等有共同祖先的进程),有名管道可解决该问题。 三、FIFO命名管道 1. 什么是FIFO FIFO命名管道,也叫有名管道,来区分管道pipe。...实际上,创建一个FIFO命名管道的时候,内核会为FIFO(伪)文件开辟一个缓冲区,操作FIFO文件就相当于操作这个缓冲区,以此来实现进程间的通信,这种通信实际上就是文件读写的操作来实现的。

16910

linux系统编程之管道(三):命名管道FIFO和mkfifo函数

一、命名管道(FIFO) 匿名管道应用的一个限制就是只能在具有共同祖先(具有亲缘关系)的进程间通信。...如果我们想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,它经常被称为命名管道。...,mode_t mode); 二、命名管道和匿名管道 匿名管道由pipe函数创建并打开。...命名管道由mkfifo函数创建,打开用open。 FIFO(命名管道)与pipe(匿名管道)之间唯一的区别在它们创建与打开的方式不同,这些工作完成之后,它们具有相同的语义。...三、命名管道的打开规则 如果当前打开操作是为读而打开FIFO时 O_NONBLOCK disable:阻塞直到有相应进程为写而打开该FIFO O_NONBLOCK enable:立刻返回成功 如果当前打开操作是为写而打开

3.7K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux 进程间通信之管道(pipe)、命名管道(FIFO)与信号(Signal)

    为了解决这一问题,Linux提供了FIFO方式连接进程。FIFO又叫做命名管道(named PIPE)。...FIFO只是借用了文件系统(file system,命名管道是一种特殊类型的文件,因为Linux中所有事物都是文件,它在文件系统中以文件名的形式存在。)来为管道命名。...写模式的进程向FIFO文件中写入,而读模式的进程从FIFO文件中读出。 当删除FIFO文件时,管道连接也随之消失。...FIFO读写规则 1.从FIFO中读取数据:约定:如果一个进程为了从FIFO中读取数据而阻塞打开了FIFO,那么称该进程内的读操作为设置了阻塞标志的读操作 2.从FIFO中写入数据:约定:如果一个进程为了向...FIFO中写入数据而阻塞打开FIFO,那么称该进程内的写操作为设置了阻塞标志的写操作。

    2.5K30

    匿名管道和命名管道

    毫不相关的进程进程间通信::命名管道 命名管道 https://blog.csdn.net/2401_83427936/article/details/142603367​​​​​​​ 首先自己要用用户层缓冲区...mkfifo命名管道 1号手册是指令,。...2号系统调用接口 创建一个管道,p开头就是命名管道,并不会直接刷新到磁盘中,实际是个符号 这样会阻塞 这样会显示出来(先输入左边的,再输入右边的就会显示),左右两边是两个进程 >>追加写入的方式,但空间一直是...make一下生成两个可执行程序,因为是server控制的,所以要先运行server 运行后就会多一个myfifo命名管道 命名管道的删除 想删除这个myfifo用unlink(成功返回0 ,失败返回-...exit(FIFO_CREATE_ERR); } } ~Init() { //删除命名管道 int m = unlink(FIFO_FILE

    15610

    【Linux】管道通信——命名管道

    命名管道 什么是命名管道 命名管道,也称为 FIFO(First In First Out),是一种 进程间通信(IPC) 机制,它允许不相关的进程(即没有父子关系的进程)通过文件系统中的特殊文件进行数据传输...命名管道 vs....无名管道 类型 说明 适用场景 匿名管道 pipe() 创建,仅限于父子进程之间通信 适用于父进程创建子进程并通信 命名管道 mkfifo() 创建,存在于文件系统中,可用于任意进程间通信 适用于独立进程间通信...如何创建命名管道 手动创建命名管道: mkfifo FIFO 这个FIFO也是一个文件,被操作系统特殊标记过,是管道文件。...通过 mkfifo 创建命名管道,我们可以实现进程间的数据流动,而不必使用共享内存或消息队列等复杂机制。命名管道不仅支持流式数据传输,还能够跨终端、跨进程进行数据交互,极大简化了进程间通信的实现。

    10910

    命名管道Linux

    管道是 毫不相关的进程进程间通信::命名管道 管道 首先自己要用用户层缓冲区,还得把用户层缓冲区拷贝到管道里,(从键盘里输入数据到用户层缓冲区里面),然后用户层缓冲区通过系统调用(write)写到管道里...mkfifo命名管道 1号手册是指令,。...2号系统调用接口 创建一个管道,p开头就是命名管道,并不会直接刷新到磁盘中,实际是个符号 这样会阻塞 这样会显示出来(先输入左边的,再输入右边的就会显示),左右两边是两个进程 >>追加写入的方式,但空间一直是...make一下生成两个可执行程序,因为是server控制的,所以要先运行server 运行后就会多一个myfifo命名管道 命名管道的删除 想删除这个myfifo用unlink(成功返回0 ,失败返回-...exit(FIFO_CREATE_ERR); } } ~Init() { //删除命名管道 int m = unlink(FIFO_FILE

    7210

    【Linux】命名管道

    一、命名管道 1、与匿名管道的关系 命名管道由mkfifo创建,是一个文件,打开要用open打开 命名管道与匿名管道之间唯一的区别就是它们创建和打开的方式不同,其他基本上相同 命名管道也只能和有“血缘...其中这个刷盘的过程就是文件缓冲区中的数据刷新到硬盘上的过程,而我们的fifo文件即命名管道文件是没有刷盘的,所以数据只会待在文件缓冲区里,因为在Linux中,多个进程打开同一个文件所指向的文件缓冲区只有一个...= EEXIST) { perror("mkfifo"); return 1; } } // 打开命名管道以进行写入操作...fgets(message, BUFFER_SIZE, stdin); message[strcspn(message, "\n")] = 0; // 移除换行符 // 向命名管道写入消息...close(fd); // 删除命名管道 if (unlink(FIFO_NAME) == -1) { perror("unlink");

    6610

    mkfifo - 创建FIFO(命名管道)

    1、管道 我们来看⼀一条 Linux 的语句句 netstat -tulnp | grep 8080  学过 Linux 命名的估计都懂这条语句句的含义,其中”|“是管道的意思,它的作⽤用就是把前⼀一条命令的输出...如 果两个进程要进⾏行行通信的话,就可以⽤用这种管道来进⾏行行通信了了,并且我们可以知道这条竖线是没有名字 的,所以我们把这种通信⽅方式称之为匿匿名管道。...居然有匿匿名管道,那也意味着有命名管道,下⾯面我们来创建⼀一个命名管道。 mkfifo - 创建FIFO(命名管道) makefifo test 这条命令创建了了⼀一个名字为 test 的命名管道。...接下来我们⽤用⼀一个进程向这个管道⾥里里⾯面写数据,然后有另外⼀一个进程把⾥里里⾯面的数据读出来。...从上⾯面的例例⼦子可以看出,管道的通知机制类似于缓存,就像⼀一个进程把数据放在某个缓存区域,然后等 着另外⼀一个进程去拿,并且是管道是单向传输的。 这种通信⽅方式有什什么缺点呢?

    89120

    初识Linux · 命名管道

    前言: 有了前文匿名管道的基础,我们介绍匿名管道的时候就轻松许多了,匿名管道和命名管道的区别主要是在于,匿名管道不需要文件路径,并且匿名管道常用于父子进程这种具有血缘关系的场景,使用命名管道的时候,我们常常用于的情况是两个进程毫无联系...对于匿名管道来说,我们知道文件对象以及文件对象里面的文件对象里面属性集合,操作集合都不会重新创建,对于命名管道来说也是一样的,所以对于内核级别的文件缓冲区也是这个样子的,OS就没有必要创建两个了,毕竟浪费空间时间的事...以上其实算是对于命名管道的原理的部分的简单介绍,其实和匿名管道差不多,本文的主要内容其实还是命名管道的代码编写。...代码编写 那么准备工作是先创建三个文件,分别表示客服端,服务端,以及创建管道的文件,创建命名管道之后,让另外两个进程分别打开管道。...那么我们的第一个任务是了解创建命名管道的函数->mkfifo: 直接man mkfifo查询到的是1号手册的mkfifo,那么我们可以使用试试: 创建了对应管道文件之后,我们可以发现几个特征点,它的名字后面带有

    6510

    浅谈 windows 命名管道

    顾名思义,管道是一个有两端的对象。一个进程向管道写入信息,而另外一个进程从管道读取信息。进程可以从这个对象的一个端口写数据,从另一个端口读数据。...简单一点,可以通过命令行利用重定向符号直接把内容写入到命名管道中 echo “test” > \\....举一个例子: 首先,我们在远程计算机开启一个管道 ? 使用本地计算机尝试往管道内写入内容,此时会提示用户名密码不正确 ?...if (WriteFile(hPipe, buffer, strlen(buffer), &WriteNum, NULL) == FALSE) { cout 写入管道失败...管道的每一个终端都有从另一个终端读取和写入的能力,即,将 Payload 运行(注入)后,创建了自定义命名管道(作服务端),等待连接即可,这一过程被称为 " 绑定 "(Bind)连接。

    10.1K30

    【Linux】IPC:匿名管道、命名管道、共享内存

    管道写端关闭&&读端继续,读端读到0,表示读到文件结尾。 管道读端关闭&&写端继续,OS杀掉写入的进程。 特性: 面向字节流。不关心对面是如何写的,按需读取。...可以看到管道文件fifo的大小依旧为0,所以两个进程间通信的数据并没有刷新保存到磁盘中。...命名管道的原理: 为什么叫做命名管道,因为有名字,是真实存在的文件,既然是真实存在的文件,就一定有路径+文件名,而路径+文件名具有唯一性。...命名管道和普通文件的区别: 这么看来命名管道和普通文件好像除了创建方式不同外也没多大区别,而普通文件好像也能实现进程间通信,但是普通文件有两个问题,我们往普通文件中写入的数据会被刷新到磁盘中保存,另外普通文件也没有被特殊保护...,也就是我们可以往里写大量的数据,在写的过程中也有可能被其他进程读,这两个问题是命名管道需要重点处理的,所以命名管道和普通文件有很大的区别,是特殊设计的。

    6800

    Linux进程间通信--管道(pipe和fifo)

    pipe        首先先来说一下pipe,这是一个匿名管道(为啥叫匿名呢,下面讲命名管道的时候就知道了),实现方式是循环队列,它只能用于有血缘关系的进程间通信。...当读管道时,如果管道中没有数据,则会阻塞,直到管道另一端写入数据。           2....当管道读端关闭时,如果写端在写入数据时,产生SIGPIPE信号,写进程默认情况下会终止进程。        ...fifo        fifo用来创建一个命名管道,可以解决非血缘关系的进程间通信,它的底层的实现原理和匿名管道相同,只不过是生成了一个可见的管道文件。...因为这个管道有一个所有进程都可以访问到的管道文件,所以fifo叫做命名管道,那么同理,pipe就只能通过fork的方式来复制文件描述符表来共享管道,而其他的进程却访问不到,所以叫做匿名管道。

    3.8K30

    【Linux】IPC 进程间通信(一):管道(匿名管道&命名管道)

    命名管道 4.1 介绍 匿名管道应用的一个限制就是只能在具有共同祖先(具有亲缘关系)的进程间通信。 如果我们想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,它经常被称为命名管道。...这种通信方式是单向的,即数据写入FIFO的一端,可以从另一端读取出来,按照先进先出的顺序。...命名管道由 mkfifo函数 创建,打开用open。 FIFO(命名管道)与pipe(匿名管道)之间唯一的区别在它们创建与打开的方式不同,一但这些工作完成之后,它们具有相同的语义。...4.5 命名管道的打开规则 如果当前打开操作是为读而打开FIFO时 O_NONBLOCK disable:阻塞直到有相应进程为写而打开该FIFO O_NONBLOCK enable:立刻返回成功 如果当前打开操作是为写而打开...管道分为两种类型:无名管道和命名管道 无名管道主要用于具有亲缘关系的进程(如父子进程),在创建时不需要名称,只能通过文件描述符进行访问 命名管道(FIFO)则可以在任何进程之间通信,使用文件系统中的路径来标识

    13810

    Linux命名管道及函数

    管道(pipe)应用的一大局限是没有名字,只能用于具有亲缘关系进程之间的通信。而命名管道,也称FIFO,实质是一种文件类型,通过FIFO可以用于任何两个进程间的通信。...命名管道的创建 命令方式 在shell中可以使用mkfifo命令创建一个命名管道,格式为: mkfifo [option] name 其中option选项用于选择创建FIFO的模式,使用形式为-m mode...”的命名管道。...命名管道的读写 一般的文件I/O函数均可用于FIFO操作,如open、close、read、write等,若要删除一个命名管道,则使用系统调用unlink。...测试之前先使用mkfifo命令创建一个名为fifo1的命名管道: mkfifo -m 666 fifo1 然后打开两个shell窗口,依次运行write_fifo和read_fifo两个程序。

    2.7K10

    红队 | Windows命名管道

    .当一个进程往Piple当中写入信息时,另一个进程便可以从这个Pipe读出这个信息。...因此管道客户端Pipe Client要想连接管道服务端Pipe Server,就必须得知道服务端的管道名称。 命名管道的创建与访问 创建命名管道只能在本机上创建,且得具有一定的权限。...\\pipe\\") 命令可以查看到我们创建的SD命名管道 ? 命名管道的访问 虽然命名管道支持跨计算机跨网的访问连接,但是会受到访问控制列表(ACL)或者说本地策略限制。...命名管道还常被用作 C2 信道,通讯执行命令。 如图所示,每个终端将为每个直接连接的子终端提供一个命名管道服务器和一个命名管道客户端。服务器监听管道名称,并等待客户端的连接。...管道的每一个终端都有从另一个终端读取和写入的能力,即,将 Payload 运行(注入)后,创建了自定义命名管道(作服务端),等待连接即可,这一过程被称为 " 绑定 "(Bind)连接。

    2.1K20

    【Linux】 管道扩展 — 开始使用命名管道

    命名管道的功能实现 1 命名管道的原理 2 代码实现 2.1 系统调用 2.2 命名管道的封装 2.3 开始使用 3回归概念 Thanks♪(・ω・)ノ谢谢阅读!!! 下一篇文章见!!!...这是因为当读端退出了,操作系统会自动释放写端进程,操作系统不会做无用功(不会在一个没有读取的管道文件了一直写入) 当然这样的通信也就只能用来演示,我们先要通过命名管道来使我们创建的两个毫不相干的进程完成通信工作...,我们在写一下相应的函数: 读取 ReadNamedPipe(std::string *out) 设置缓冲区 从管道里读取 向缓冲区写入数据 命名管道对于读端而言 , 如果我们打开文件,但是写端还没有...&& write fd没有关闭: 读取条件不具备,读取进程会被阻塞 – wait 等待条件具备(写入了数据) 3回归概念 总结一下,命名管道的通信原理依然是:让两个不同的进程看到同一份资源(通过文件路径...如果我们想在不相关的进程之间交换数据,可以使用命名管道(FIFO文件)来做这项工作.

    10210

    【Linux】进程间通信——命名管道

    @TOC 命名管道 匿名管道只能用来进行进程间通信,让具有血缘关系的进程进行通信 让毫不相关的进程之间进行通信,就需要采用命名管道通信 因为该文件有文件名称的,而且必须要有,所以叫做命名管道 1....见一见管道文件 mkfifo函数 输入 man mkfifo 指令 制作一个 FIFOS ,表示命名管道 ---- mkfifo fifo 制作一个管道 ,并命名为 fifo 文件类型以p开头...0,失败返回-1 ---- 管道文件的使用 将hello world 重定向到fifo管道中 但是好像并不会写入 fifo只代表一种符号,向符号写入消息并不会刷新到磁盘上,而是只会把hello world.../fifo";//管道名字为当前路径创建的fifo mode_t mode=0666;//默认权限为0666 这样 server文件和client文件就会调用同一份文件路径了 server.cc 服务端...创建一个管道文件 创建server.cc文件,使用mkfifo函数创建管道文件 ---- 此时运行可执行程序,即可生成fifo管道文件 ---- 权限变为664 ,可是在comm.hpp中设置的权限为

    1.9K30

    Linux进程间通信【命名管道】

    umask 掩码计算 不难发现,mkfifo 和 mkdir 非常像,其实 mkfifo 可以直接在命令行中运行 创建一个名为 fifo 的命名管道文件 mkfifo fifo 成功解锁了一种新的特殊类型文件...: echo 可以进行数据写入,可以重定向至 fifo cat 可以进行数据读取,同样也可以重定向于 fifo 打开两个终端窗口(两个进程),即可进行通信 当然也可以通过程序实现两个独立进程 IPC...服务端启动后,因为是读端,所以会阻塞等待 客户端(写端)写入数据 客户端写入数据时,因为 '\n' 也被读取了,所以要去除此字符 通信结束后,需要服务端主动删除管道文件 unlink 命令管道文件名 /...,这样就实现了文件的拷贝 目标:利用命名管道,向空文件 target.txt 中写入数据,即拷贝源文件 file.txt 公共资源 common.h #pragma once #include...char buff[1024]; int n = fread(buff, sizeof(char), sizeof(buff), fp); //IPC区域 // 4、写入源文件至命名管道

    40020

    Windows进程间通信—命名管道

    大家好,又见面了,我是全栈君 命名管道是通过网络来完成进程间的通信,它屏蔽了底层的网络协议细节。我们在不了解网络协议的情况下,也可以利用命名管道来实现进程间的通信。...与Socket网络通信相比,命名管道不再需要编写身份验证的代码。将命名管道作为一种网络编程方案时,它实际上建立了一个C/S通信体系,并在其中可靠的传输数据。...命名管道服务器和客户机的区别在于:服务器是唯一一个有权创建命名管道的进程,也只有它能接受管道客户机的连接请求。而客户机只能同一个现成的命名管道服务器建立连接。...命名管道服务器只能在WindowsNT或Windows2000上创建,不过可以是客户机。命名管道提供了两种基本通信模式,字节模式和消息模式。...服务端代码流程: 1、创建命名管道:CreateNamedPipe 2、等待客户端连接:ConnectNamedPipe 3、读取客户端请求数据:ReadFile 4、向客户端回复数据:WriteFile

    1.4K10

    【Linux】进程间通信——命名管道

    使用mkfifo更为常见和简单: mkfifo /path/to/your/fifo 这里,/path/to/your/fifo是你要创建的命名管道的路径。...创建后,这个路径将作为一个特殊类型的文件存在,其类型为p(pipe);如下图所示,在当前路径下创建名为mypipe的管道文件。 写入数据到命名管道 一个进程可以打开命名管道并写入数据。...例如,使用echo命令向命名管道写入文本: echo "Hello, FIFO!"...这通常也是通过标准输入输出重定向完成的: cat fifo 同样地,如果此时没有进程向命名管道写入数据,那么执行读操作的命令也会处于等待状态。...删除命名管道 一旦不再需要命名管道,可以直接使用rm命令删除它: rm /path/to/your/fifo 记住,命名管道必须在没有任何进程打开的情况下才能被成功删除。

    13710
    领券