Python 프로 세 스 간 통신 의 이름 파 이 프 를 자세히 설명 합 니 다.

파 이 프 는 간단 한 FIFO 통신 채널 로 단 방향 통신 이다.보통 프로 세 스 를 시작 하여 파 이 프 를 만 든 다음 에 이 프로 세 스 는 하나 이상 의 프로 세 스 를 만 들 고 파이프 정 보 를 받 습 니 다.파 이 프 는 단 방향 통신 이기 때문에 두 개의 파 이 프 를 만들어 서 양 방향 통신 을 실현 해 야 합 니 다.
이름 파 이 프 는 전통 적 인 파이프 에 대한 확장 입 니 다.기본 파 이 프 는 익명 파이프 로 프로그램 이 실 행 될 때 만 존재 합 니 다.이름 이 붙 은 파 이 프 는 지속 적 이 며 필요 하지 않 을 때 삭제 해 야 합 니 다.
이름 파 이 프 는 파일 시스템 을 사용 하여 mkfifo()방법 으로 만 듭 니 다.만 들 면 두 개의 독립 된 프로 세 스 가 접근 할 수 있 습 니 다.하 나 는 읽 고 다른 하 나 는 쓸 수 있 습 니 다.
이름 파 이 프 는 읽 기와 쓰기 막 기 동작 을 지원 합 니 다.프로 세 스 가 파일 을 열 면 다른 프로 세 스 가 쓸 때 까지 막 힙 니 다.하지만 우 리 는 O 를 지정 할 수 있다.NONBLOCK 옵션 을 사용 하면 비 차단 모드 를 사용 합 니 다.
이름 파 이 프 는 읽 기 전용 또는 쓰기 전용 모드 로 열 어야 합 니 다.읽 기+쓰기 모드 로 열 수 없습니다.단 방향 으로 통신 하기 때 문 입 니 다.양 방향 통신 을 실현 하려 면 두 개의 이름 파 이 프 를 열 어야 한다.
다음은 Python 이 프로 세 스 간 통신 을 위해 이름 파 이 프 를 사용 하 는 예 입 니 다.
서버 엔 드

import os, time

read_path = "/tmp/pipe.in"
write_path = "/tmp/pipe.out"

if os.path.exists(read_path):
  os.remove(read_path)
if os.path.exists(write_path):
  os.remove(write_path)

os.mkfifo(write_path)
os.mkfifo(read_path)

rf = os.open(read_path, os.O_RDONLY)
wf = os.open(write_path, os.O_SYNC | os.O_CREAT | os.O_RDWR)

while True:
  s = os.read(rf, 1024)
  print "received msg: %s" % s
  if len(s) == 0:
    time.sleep(1)
    continue

  if "exit" in s:
    break

  os.write(wf, s)

os.close(rf)
os.close(wf)

클 라 이언 트 엔 드

import os
import time

write_path = "/tmp/pipe.in"
read_path = "/tmp/pipe.out"

wf = os.open(write_path, os.O_SYNC | os.O_CREAT | os.O_RDWR)
rf = None

for i in range(1, 11):
  msg = "msg " + str(i)
  len_send = os.write(wf, msg)
  print "sent msg: %s" % msg

  if rf is None:
    rf = os.open(read_path, os.O_RDONLY)

  s = os.read(rf, 1024)
  if len(s) == 0:
    break
  print "received msg: %s" % s

  time.sleep(1)

os.write(wf, 'exit')

os.close(rf)
os.close(wf)


테스트
  • 먼저 server.py
  • 를 실행 합 니 다.
  • 그리고 client.py
  • 를 실행 합 니 다.
    이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

    좋은 웹페이지 즐겨찾기