>  기사  >  백엔드 개발  >  PHP 멀티스레드 파이프라인 통신 적용

PHP 멀티스레드 파이프라인 통신 적용

*文
*文원래의
2017-12-25 17:06:421726검색

이 글은 주로 PHP 멀티스레드 프로그래밍에서의 파이프라인 통신을 소개합니다. 파이프라인 통신의 원리와 사용법을 예제와 함께 분석하여 모든 사람의 파이프라인 통신 이해에 도움이 되기를 바랍니다.

하나의 스레드가 개인의 영웅주의라면, 여러 스레드는 집단주의입니다. 당신은 더 이상 고독한 레인저가 아니라 지휘자입니다.

파이프라인 통신:
1. 파이프라인은 대기열로 생각할 수 있으며, 다양한 스레드가 대기열에 내용을 쓰고 읽을 수 있습니다. 쓰기는 대기열 끝에 추가하는 것을 의미하고, 읽기는 대기열의 선두에서 삭제를 의미합니다.

2. 파이프에는 일반적으로 크기가 있으며 기본값은 일반적으로 4K입니다. 즉, 내용이 4K를 초과하면 읽을 수만 있고 쓸 수는 없습니다.

3. 기본적으로 파이프에 쓴 후에는 이를 읽는 프로그램이 데이터 읽기를 마칠 때까지 차단됩니다. 프로세스가 파이프에 데이터를 쓸 때까지 읽기 스레드도 차단됩니다. 물론 이 기본 속성을 변경하고 stream_set_block 함수를 사용하여 비차단 모드로 설정할 수 있습니다.

다음은 제가 캡슐화한 파이프 클래스입니다. (이 클래스의 네이밍에 문제가 있어서 통일이 안되어 통일된 것으로 바꿀 시간이 없네요. 저는 주로 테스트 코드를 먼저 작성해서 캡슐화합니다. 마지막이므로 이름이 통일되지 않을 수 있습니다.):


<?php
class Pipe
{
  public $fifoPath;
  private $w_pipe;
  private $r_pipe;
 
  /**
   * 自动创建一个管道
   *
   * @param string $name 管道名字
   * @param int $mode 管道的权限,默认任何用户组可以读写
   */
  function __construct($name = &#39;pipe&#39;, $mode = 0666)
  {
    $fifoPath = "/tmp/$name." . posix_getpid();
    if (!file_exists($fifoPath)) {
      if (!posix_mkfifo($fifoPath, $mode)) {
        error("create new pipe ($name) error.");
        return false;
      }
    } else {
      error( "pipe ($name) has exit.");
      return false;
    }
    $this->fifoPath = $fifoPath;
  }
///////////////////////////////////////////////////
// 写管道函数开始
///////////////////////////////////////////////////
  function open_write()
  {
    $this->w_pipe = fopen($this->fifoPath, &#39;w&#39;);
    if ($this->w_pipe == NULL) {
      error("open pipe {$this->fifoPath} for write error.");
      return false;
    }
    return true;
  }
 
  function write($data)
  {
    return fwrite($this->w_pipe, $data);
  }
 
  function write_all($data)
  {
    $w_pipe = fopen($this->fifoPath, &#39;w&#39;);
    fwrite($w_pipe, $data);
    fclose($w_pipe);
  }
 
  function close_write()
  {
    return fclose($this->w_pipe);
  }
/////////////////////////////////////////////////////////
/// 读管道相关函数开始
////////////////////////////////////////////////////////
  function open_read()
  {
    $this->r_pipe = fopen($this->fifoPath, &#39;r&#39;);
    if ($this->r_pipe == NULL) {
      error("open pipe {$this->fifoPath} for read error.");
      return false;
    }
    return true;
  }
  function read($byte = 1024)
  {
    return fread($this->r_pipe, $byte);
  }
  function read_all()
  {
    $r_pipe = fopen($this->fifoPath, &#39;r&#39;);
    $data = &#39;&#39;;
    while (!feof($r_pipe)) {
      //echo "read one K\n";
      $data .= fread($r_pipe, 1024);
    }
    fclose($r_pipe);
    return $data;
  }
  function close_read()
  {
    return fclose($this->r_pipe);
  }
  /**
   * 删除管道
   *
   * @return boolean is success
   */
  function rm_pipe()
  {
    return unlink($this->fifoPath);
  }
}
?>
 /*
有了这个类,就可以实现简单的管道通信了。*/

관련 권장 사항:

PHP 멀티 스레딩의 멋진 사용법을 이해하세요

PHP 멀티 스레딩에 대한 자세한 설명

PHP 프로세스 간 통신 - 유명한 파이프

위 내용은 PHP 멀티스레드 파이프라인 통신 적용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.