UNIXドメインソケット通信 vs INETドメインソケット通信 php-fpmで動作させる場合の違いについて

2021-01-10
phpapachenginxlinux
    

目次

概要

php-fpm の設定方法で調べた際にIPとポートで設定するパターンとUNIXソケットで設定するパターンの両方があったので それぞれの特徴やメリットデメリットを踏まえつつ違いを整理してまとめたものを記載します。

※ ここで言うUNIXドメインソケット通信は php-fpmで例えると

/run/php-fpm/php-fpm.sock

みたいなやつで、INETドメイン

127.0.0.1:9000

です。

結論

先に結論を書きます。

ApacheやNginxなどのリクエストを受けるサーバ(フロントサーバ)と同じマシンにでphp-fpmを利用する場合はUNIXドメインソケットを利用することが理にかなっています。 INETドメインは、フロントサーバとFPMサーバを分離する場合、FPMサーバのみスケールアップするといった運用ができる点で意味があります。

ソケット通信について

ソケットについて

  • ソケットを使うとHTTPよりも下のレイヤーのプロトコルを扱える

    • TCPやUDP (L4 トランスポート層) で動作するアプリケーションを作成できる
  • 独自のプロトコル/フォーマットによる通信が可能

ソケット通信の種類

ソケット通信は2種類あります。

  • INETドメイン(ネットワークソケット)

    • 自分とは異なるマシンに対してのプロセス間の通信を行うためのソケット
    • IP + ポートを利用する (127.0.0.1:9000)
  • UNIXドメイン

    • 同じマシン内でプロセス間の通信を行うためのソケット
    • ソケットファイルを利用する (/run/php-fpm/php-fpm.sock)

UNIXドメインソケットはさらに、「ファイルシステムパス名(pathname)」「無名(unnamed)」「抽象名前空間(abstract)」の3種類が存在する。

UNIXドメインソケット通信を行う場合のメリット

UNIXドメインソケット通信はINETドメインに比べ、スループットが優れているというデータがあります。 しかしながら、INETドメインもUNIXドメインもどちらも実戦で利用されている実績がるため、実装や保守がコストの面で導入が容易なものを利用するべきです。

参考にしたサイト

調べなきゃ寝れない!と調べたら余計に寝れなくなったソケットの話

nginx と PHP-FPM の仕組みをちゃんと理解しながら PHP の実行環境を構築する

What are the differences from running PHP-FPM over an Unix Socket vs a TCP/IP Socket?

Performance Analysis of Various Mechanisms for Inter-process Communication

INETドメインとUNIXドメイン

unix - sockets for local interprocess communication

PHPで学ぶソケットプログラミング入門

Nginx + PHP-FPM で unix ドメインソケットを使ったシンプルな docker-compose.yml を書きました。2

    

関連記事

AWS Amplify で コンテナベースのデプロイを行い REST API を構築
検証した環境 やってみる 初期準備 パイプラインを確認 終了処理 参考 AWS Amplify で コンテナベースのデプロイを行い REST API を構築した際のメモです。 検証した環境 amplify 5.1.…

Pythonでソケット通信を実装しメッセージの送受信を行う
ソース server.py client.py 動かしてみる 参考 Pythonでソケット通信を実現する方法です。 ソース server.py サーバ側のソースです。 client.py…

PostfixでメールリレーしてMailHogで受信する開発用Dockerコンテナの構築
環境 Dockerイメージ作成 コンテナの起動 telnetで送信テスト phpで送信テスト Postfixのリレーを介して送信されたメールをMailHog(開発用SMTPサーバ)でキャッチするDocker開発環境を構築した際のメモです。 環境 Docker…

php-fpmのステータスページを表示 Apache & htaccess
試した環境 php-fpm の pm.status_path について php-fpmのconfの設定 .htaccess の設定 アクセスしてみる 参考にしたサイト Apache環境で php-fpm のステータスページを htaccess…

Homebrew で php7.4 + Xdebug をインストール
php7.4のインストール Xdebugのインストール php.ini に追記 参考にさせていただいたサイト phpunitのカバレッジを算出を行うためにMacにHomebrewでphp7.4をインストールしようとした際の記録です。 php7.…

CentOS で スマートにプロキシを設定する
コマンドライン上で通す よりスマートに設定する 設定ファイルに記述 CentOSでプロキシを通す設定のメモです。 プロキシ環境で yum/dnf でリポジトリを更新する場合や、curl/wget…

MySQL8.0 で利用できるパラメータを表示する方法
オプションの表示 mysql8.0でmy.cnfなどで利用できるパラメータ一覧を出す方法。 オプションの表示 オプションの表示は次のコマンドで実施できます mysqld — The MySQL Server 【MySQLパラメーター比較資料】MySQL 5.…

CentOS に MySQL8.0をインストールする
はじめに 環境 起動 MySQLインストール my.cnf の設定 プロセス立ち上げ エラー The designated data directory /var/lib/mysql/ is unusable. You can remove all files…

PHP-FPM(php7.4) Apache2.4 on Ubutnu20.04 Webサーバ構築
環境 パッケージの更新 Apache と PHP のインストール Apache のサービスを開始する PHPファイルを作成 参考にしたサイト Ubuntu20.04 に PHP7.4 + Apache2.4 をインストールしてWeb…

PHP-FPM(php7.4) Apache2.4 でWebサーバ構築 on CentOS8
環境 php7.4 のインストール apacheのインストール php-fpmの設定を変更する php-fpm の起動 apacheの起動 確認 おまけ: エラーと解決方法 "System has not been booted with systemd as…

最新の投稿

JavaScriptで優先度付きキューを実装する
優先度付きキューについて ソース 参考 JavaScriptで優先度付きキュー (プライオリティキュー) を実装する 優先度付きキューについて 具体的には次のような機能があります。 キューに対して要素を優先度付きで追加 (push…

AWS Amplify で コンテナベースのデプロイを行い REST API を構築
検証した環境 やってみる 初期準備 パイプラインを確認 終了処理 参考 AWS Amplify で コンテナベースのデプロイを行い REST API を構築した際のメモです。 検証した環境 amplify 5.1.…

Pythonでソケット通信を実装しメッセージの送受信を行う
ソース server.py client.py 動かしてみる 参考 Pythonでソケット通信を実現する方法です。 ソース server.py サーバ側のソースです。 client.py…

next_permutationをJSで実装する
ソース 使い方 参考 C++で提供されている順列を生成する next_permutation のJS実装です。 ソース 順列が存在する場合はtrueを返し、そうでなければfalse…

応用情報技術者試験の合格体験記
受験時のステータス 受験結果 対策 スケジュール 午前問題 午後問題 参考書等 令和…

[JS]ラジアンから度数に度数からラジアンに変換する
コード 度数からラジアンへ ラジアンから度数へ サンプル ラジアンから度数に度数からラジアンに変換する際のスニペット。 コード 度数からラジアンへ ラジアンから度数へ サンプル

CentOS8 に Python + OpenCV をインストール
インストール テスト CentOS8 で標準で提供されているパッケージで Python + OpenCV 環境を構築する方法です。 検証した環境は CentOS8.3 (Docker) です。 インストール まず opencv…

[Perl] CentOS8 に plenv をインストール
インストール Step1 事前準備 Step2 PATHを通す (README通りにインストール) Step2 PATHを通す ($HOME以外にplenvをインストール) Step3 Perlインストール Step4 cpanmインストール CentOS…

JS/TSのclassでclass名を取得する
コード JS/TSのconstructorを利用して自分自身のクラス名を取得する際のメモ。 コード このコードの結果は次のようになります。

CentOS6(Docker)でyum update できなくなった
エラー内容 対応 CentOS6.10 で yum update しようとしたところエラーが出てアップデートできなかったので対応した時の記録 エラー内容 以下のようなエラーが出ました。 対応 を以下のように変更したところ解決しました。

Tags

Dates

s-yoshiki
s-yoshiki
githubtwitterqiita
Web作ってますが、インタラクティブなプログラミングも好きです。
JavaScript / Vue / node.js / PHP / AWS / OpenCV
© 2021   404 motivation not found