【Linux】进程通信之命名管道mkfifo

2023-12-08 06:36

本文主要是介绍【Linux】进程通信之命名管道mkfifo,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.认识命名管道

  • 匿名管道应用的一个限制就是只能在具有共同祖先(具有亲缘关系)的进程间通信。
  • 如果我们想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,它经常被称为命名管道。
  • 命名管道是一种特殊类型的文件

2.在命令行上创建命名管道

基本语法:mkfifo fifoname
在这里插入图片描述
创建完命名管道后,进行简单的通信,如下图:
在这里插入图片描述

3.匿名管道与命名管道的区别

  • 匿名管道由pipe函数创建并打开。
  • 命名管道由mkfifo函数创建,打开用open
  • FIFO(命名管道)与pipe(匿名管道)之间唯一的区别在它们创建与打开的方式不同,一但这些工作完成之后,它们具有相同的语义。

4.命名管道的打开规则

4.1如果当前打开操作是为读而打开FIFO时

  1. O_NONBLOCK disable:阻塞直到有相应进程为写而打开该FIFO
  2. O_NONBLOCK enable:立刻返回成功

4.2如果当前打开操作是为写而打开FIFO时
3. O_NONBLOCK disable:阻塞直到有相应进程为读而打开该FIFO
4. O_NONBLOCK enable:立刻返回失败,错误码为ENXIO

5.用命名管道实现server&client通信

  1. 先定义公共的同文件,代码块如下:
#pragma once#include <stdio.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <fcntl.h>#define MY_FIFO "./fifo"
  1. 编写server模块,代码如下:
#include "comm.h"
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/wait.h>int main()
{//该命令用来设置限制新文件权限的掩码。umask(0);//创建命名管道if(mkfifo(MY_FIFO, 0666) < 0){perror("mkfifo");return 1;}//命名管道本质就是文件的一种,只需要文件操作即可int fd = open(MY_FIFO, O_RDONLY);if(fd < 0){perror("open");return 2;}//业务逻辑,可以进行对应的读写了while(1){char buffer[64] = {0};sleep(50);ssize_t s = read(fd, buffer, sizeof(buffer)-1); //键盘输入的时候,\n也是输入字符的一部分if(s > 0){//successbuffer[s] = 0;if(strcmp(buffer, "show") == 0){if(fork() == 0){execl("/usr/bin/ls", "ls", "-l", NULL);exit(1);}waitpid(-1, NULL, 0);}else if(strcmp(buffer, "run") == 0){if(fork() == 0){execl("/usr/bin/sl", "sl", NULL);}waitpid(-1, NULL, 0);}else{printf("client# %s\n", buffer);}}else if(s == 0){//peer closeprintf("client quit ...\n");break;}else{//errorperror("read");break;}}close(fd);return 0;
}
  1. 编写client模块,代码如下:
#include "comm.h" 
#include <string.h>int main()
{//用不用在创建fifo?? 我只要获取即可int fd = open(MY_FIFO, O_WRONLY); //不需要O_CREATif(fd < 0){perror("open");return 1;}//业务逻辑while(1){printf("请输入# ");fflush(stdout);char buffer[64] = {0};//先把数据从标准输入拿到我们的client进程内部ssize_t s = read(0, buffer, sizeof(buffer)-1);if(s > 0){buffer[s-1] = 0;printf("%s\n", buffer);//拿到了数据write(fd, buffer, strlen(buffer)); //要不要-1,不需要}}close(fd);return 0;
}

这篇关于【Linux】进程通信之命名管道mkfifo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/468876

相关文章

linux本机进程间通信之UDS详解

《linux本机进程间通信之UDS详解》文章介绍了Unix域套接字(UDS)的使用方法,这是一种在同一台主机上不同进程间通信的方式,UDS支持三种套接字类型:SOCK_STREAM、SOCK_DGRA... 目录基础概念本机进程间通信socket实现AF_INET数据收发示意图AF_Unix数据收发流程图A

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

linux打包解压命令方式

《linux打包解压命令方式》文章介绍了Linux系统中常用的打包和解压命令,包括tar和zip,使用tar命令可以创建和解压tar格式的归档文件,使用zip命令可以创建和解压zip格式的压缩文件,每... 目录Lijavascriptnux 打包和解压命令打包命令解压命令总结linux 打包和解压命令打

linux如何复制文件夹并重命名

《linux如何复制文件夹并重命名》在Linux系统中,复制文件夹并重命名可以通过使用“cp”和“mv”命令来实现,使用“cp-r”命令可以递归复制整个文件夹及其子文件夹和文件,而使用“mv”命令可以... 目录linux复制文件夹并重命名我们需要使用“cp”命令来复制文件夹我们还可以结合使用“mv”命令总

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

Linux使用cut进行文本提取的操作方法

《Linux使用cut进行文本提取的操作方法》Linux中的cut命令是一个命令行实用程序,用于从文件或标准输入中提取文本行的部分,本文给大家介绍了Linux使用cut进行文本提取的操作方法,文中有详... 目录简介基础语法常用选项范围选择示例用法-f:字段选择-d:分隔符-c:字符选择-b:字节选择--c

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块