【PHP8.x】posix_mkfifo関数の使い方

posix_mkfifo関数の使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

posix_mkfifo関数は、UNIX系オペレーティングシステムにおいて、プロセス間でデータをやり取りするための「名前付きパイプ」(FIFO: First-In, First-Out)を作成する関数です。名前付きパイプは、通常のファイルとは異なり、ディスク上にデータを永続的に保存するのではなく、複数のプロセスが互いに通信するための特殊なファイルインターフェースとして機能します。この関数は、最初の引数として作成する名前付きパイプのパスを文字列で指定し、第二引数としてそのパイプのアクセス権限(パーミッション)を整数値で指定します。パーミッションは、他のファイルと同様に、例えば0644のように8進数で指定することが一般的です。posix_mkfifo関数は、名前付きパイプの作成に成功した場合にtrueを返し、失敗した場合にはfalseを返します。失敗の例としては、指定されたパスにすでにファイルが存在する場合や、十分な権限がない場合が挙げられます。これにより、PHPアプリケーションから、関連性のない異なるプロセス間でデータの送受信を行うための経路を確立できます。関数がfalseを返した際には、エラー処理を行うことが重要です。

構文(syntax)

1<?php
2$fifoPath = '/tmp/my_php_fifo';
3$permissions = 0644;
4
5if (posix_mkfifo($fifoPath, $permissions)) {
6    echo "FIFOスペシャルファイル '{$fifoPath}' が作成されました。\n";
7} else {
8    echo "FIFOスペシャルファイル '{$fifoPath}' の作成に失敗しました。\n";
9}
10?>

引数(parameters)

string $filename, int $permissions

  • string $filename: 作成するFIFO(名前付きパイプ)のパスを指定する文字列
  • int $permissions: FIFOのパーミッションを指定する整数(0から0777の範囲)

戻り値(return)

bool

名前付きパイプ(FIFO)を作成し、成功した場合は true を、失敗した場合は false を返します。

関連コンテンツ

関連プログラミング言語

【PHP8.x】posix_mkfifo関数の使い方 | いっしー@Webエンジニア