>  기사  >  시스템 튜토리얼  >  Linux Named Pipes(FIFO): 프로세스 간 통신을 위한 간단하면서도 강력한 방법

Linux Named Pipes(FIFO): 프로세스 간 통신을 위한 간단하면서도 강력한 방법

WBOY
WBOY앞으로
2024-02-11 21:36:18732검색

Linux 시스템은 다중 작업의 동시 실행을 지원하는 운영 체제로, 동시에 여러 프로세스를 실행할 수 있어 시스템 활용도와 효율성이 향상됩니다. 그러나 이러한 프로세스 간에 데이터 교환 및 협업이 필요한 경우 신호, 메시지 큐, 공유 메모리, 세마포어 등과 같은 일부 프로세스 간 통신(IPC) 방법을 사용해야 합니다. 그 중 유명한 파이프(FIFO)는 비교적 간단하고 강력한 IPC 방식으로, 두 개 이상의 프로세스가 파일의 내용과 형식에 상관 없이 파일을 통해 데이터를 전송할 수 있도록 해줍니다. 이 기사에서는 유명한 파이프의 생성, 열기, 읽기, 쓰기, 닫기 및 삭제를 포함하여 Linux 시스템에서 유명한 파이프(FIFO)의 차단 및 비차단 읽기 및 쓰기 방법을 소개합니다.

Linux Named Pipes(FIFO): 프로세스 간 통신을 위한 간단하면서도 강력한 방법

//작성과정

#포함

#포함

#포함

#포함

#포함

#포함

#define FIFO_NAME “/tmp/myfifo”

메인()

{

int fd;

char w_buf[50];

int w_num;

// FIFO가 이미 존재한다면 직접 사용하고, 그렇지 않으면 생성하세요

if((mkfifo(FIFO_NAME,0777)

{

printf(“fifo…n을 생성할 수 없습니다.”);

출구(1);

}

//차단 쓰기 전용 모드에서 FIFO 열기

fd=열기(FIFO_NAME,O_WRONLY);

w_num=쓰기(fd,”abcdg

printf(“%dn”,w_num);

}

//읽는 과정

#포함

#포함

#포함

#포함

#define FIFO_NAME “/tmp/myfifo”

메인()

{

char r_buf[50];

int fd;

int r_num;

// FIFO가 이미 존재한다면 직접 사용하고, 그렇지 않으면 생성하세요

if((mkfifo(FIFO_NAME,0777)

{

printf(“fifo…n을 생성할 수 없습니다.”);

출구(1);

}

//차단 읽기 전용 모드에서 FIFO 열기

fd=열기(FIFO_NAME,O_RDONLY);

if(fd==-1)

{

printf(“읽기 오류로 인해 %s 열기”);

출구(1);

}

// 키보드를 통해 문자열을 입력하고 "exit"가 입력될 때까지 fifo에 씁니다

r_num=읽기(fd,r_buf,6);

printf(” %d바이트 읽음:%sn”,r_num,r_buf);

연결 해제(FIFO_NAME);//fifo 삭제

}

1. 쓰기 과정이 차단되고 읽기 과정이 차단됩니다.

쓰기 프로세스를 먼저 실행(차단)한 다음 읽기 프로세스를 실행하면 모든 것이 정상입니다.

먼저 읽기 프로세스(차단)를 실행한 다음 쓰기 프로세스를 실행하면 모든 것이 정상입니다.

2. 쓰기 과정은 차단되고 읽기 과정은 비차단입니다.

다음과 비슷하게 코드를 fd=open(FIFO_NAME,O_RDONLY | O_NONBLOCK)으로 변경하세요.

쓰기 프로세스를 먼저 실행(차단)한 다음 읽기 프로세스를 실행하면 모든 것이 정상입니다.

읽기 프로세스를 먼저 실행하면 프로그램이 직접 충돌합니다(세그먼트 오류(코어 덤프)). 생각할 것도 없고 기다리고 싶지도 않습니다.

3. 쓰기 과정은 비차단, 읽기 과정은 차단입니다.

쓰기 프로세스를 먼저 실행하면 열기 호출이 -1을 반환하고 열기가 실패합니다.

먼저 읽기 프로세스(차단)를 실행한 다음 쓰기 프로세스를 실행하면 모든 것이 정상입니다.

4. 쓰기 과정은 논블로킹(non-blocking)이고 읽기 과정은 논블로킹(non-blocking)입니다.

사실 위의 2, 3가지 항목 중 절반을 차지하는 비정상적인 상황입니다.

또한 /tmp 디렉터리의 ls -la 명령을 통해 파이프 파일 myfifo의 크기가 항상 0임을 알 수 있습니다. 이는 FIFO 파일이 파일 시스템에 존재하더라도 FIFO의 내용은 다음 위치에 저장되기 때문입니다. 메모리이므로 파일 크기는 항상 0입니다.

이 글에서는 유명한 파이프의 생성, 열기, 읽기, 쓰기, 닫기 및 삭제를 포함하여 Linux 시스템에서 유명한 파이프(FIFO)의 차단 및 비차단 읽기 및 쓰기 방법을 소개합니다. 이 지식을 이해하고 숙달함으로써 유명한 파이프(FIFO)를 더 잘 사용하여 프로세스 간 통신을 구현하고 시스템 성능과 안정성을 향상시킬 수 있습니다. 물론 Linux 시스템에는 유명한 파이프(FIFO)의 다른 많은 기능과 사용법이 있으므로 계속해서 배우고 탐구해야 합니다. 이 기사가 여러분에게 영감과 도움을 줄 수 있기를 바랍니다.

위 내용은 Linux Named Pipes(FIFO): 프로세스 간 통신을 위한 간단하면서도 강력한 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 lxlinux.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제