PHP가 프로세스 간에 통신하는 방법에는 여러 가지가 있습니다: 파이프(Pipe) 및 명명된 파이프(named Pipe), 신호(Signal), 메시지(Message) 큐(message queue), 공유 메모리, 세마포어 , 소켓.
이 글에는 유명 채널을 통해 소개할 내용이 나와 있습니다.
Pipe는 약어 간의 통신 데이터를 전달하는 데 사용됩니다. 이해를 돕기 위해 파이프를 파일과 비교할 수 있습니다. 프로세스 A는 파이프 P에 데이터를 쓴 다음 프로세스 B는 파이프 P에서 데이터를 읽습니다.
PHP에서 제공하는 파이프라인 작업 API는 파일 작업을 위한 API와 기본적으로 동일합니다. posix_mkfifo 함수를 사용하여 파이프라인을 생성한다는 점만 제외하면 읽기, 쓰기 작업은 파일 작업과 동일합니다. 기능.
물론 파일을 직접 사용하여 파이프라인을 시뮬레이션할 수는 있지만 파이프라인의 기능을 사용할 수는 없습니다.
파이프를 통한 통신의 일반적인 개념은 먼저 파이프를 만든 다음 하위 프로세스가 파이프에 정보를 쓰고 상위 프로세스가 파이프의 정보를 읽어 상위 프로세스가 파이프를 통해 통신하도록 하는 것입니다. 하위 프로세스는 직접 통신할 수 있습니다.
<?php /** * author: NickBai * createTime: 2016/12/2 0002 上午 11:12 */ //创建管道 $pipePath = "/tmp/test.pipe"; if( !file_exists( $pipePath ) ){ if( !posix_mkfifo( $pipePath, 0666 ) ){ exit('make pipe false!' . PHP_EOL); } } //创建进程,子进程写管道,父进程读管道 $pid = pcntl_fork(); if( $pid == 0 ){ //子进程写管道 $file = fopen( $pipePath, 'w' ); fwrite( $file, 'hello world' ); sleep(1); exit(); }else{ //父进程读管道 $file = fopen( $pipePath, 'r' ); //stream_set_blocking( $file, False ); //设置成读取非阻塞 echo fread( $file, 20 ) . PHP_EOL; pcntl_wait($status); //回收子进程 }
참고: 이 코드는 Linux 및 php-cli 모드에서만 실행할 수 있습니다.
Line 7: 파이프라인의 경로를 지정합니다. 이는 일반 파일과 다르지 않습니다.
Line 9: posix_mkfifo 함수를 통해 파이프를 생성하고 읽기 및 쓰기 권한을 0666
Line 15: pcntl_fork 함수를 통해 하위 프로세스 생성 . 이제부터 프로그램은 실행을 위해 두 개의 프로세스로 나누어집니다. pcntl_fork 함수는 일단 호출되면 여러 개의 반환 값을 갖습니다. 상위 프로세스에서: 하위 프로세스의 ID를 반환합니다. 이 값은 0보다 큽니다. 하위 프로세스에서는 0을 반환합니다. -1이 반환되면 생성 프로세스가 실패했음을 나타냅니다.
Line 17: 두 프로세스는 현재 프로세스에서 얻은 $pid의 서로 다른 값을 기반으로 서로 다른 분기에 들어갑니다.
18~22행: 하위 프로세스는 파이프를 열고 hello world를 쓴 다음 절전 모드로 들어가고 절전 모드가 끝나면 종료됩니다.
25~29행: 상위 프로세스가 파이프를 열고 읽은 후 마지막으로 코드 29행을 실행하여 하위 프로세스를 재활용합니다. 여기에는 두 개의 차단된 위치가 있습니다. 첫 번째는 기본 읽기 위치입니다. 데이터가 반환되기 전에 하위 프로세스가 종료 명령을 내릴 때까지 기다려야 합니다. 프로세스를 재활용하는 pcntl_wait 방법도 있습니다. 프로세스가 종료될 때까지 기다리십시오.
위 내용은 PHP 프로세스 간에 통신하는 방법에는 여러 가지가 있습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!