このページはコミュニティによって翻訳されたもので、最新ではない可能性があります。参照用のバージョンをご覧ください。

このページはコミュニティによって翻訳されたもので、最新ではない可能性があります。参照用のバージョンをご覧ください。

このページはコミュニティによって翻訳されたもので、最新ではない可能性があります。参照用のバージョンをご覧ください。

提供
設定

設定

FrankenPHP、Caddy、そしてMercureやVulcainモジュールは、Caddyでサポートされる形式を使用して設定できます。

Dockerイメージでは、Caddyfile/etc/frankenphp/Caddyfileに配置されています。 静的バイナリは、frankenphp runコマンドを実行したディレクトリ内のCaddyfileを参照します。 また、-cまたは--configオプションでカスタムのパスを指定できます。

PHP自体の設定はphp.ini ファイルを使用して行えます。

インストール方法に応じて、PHPインタープリターは上記いずれかの場所にある設定ファイルを参照します。

# Docker

  • php.ini: /usr/local/etc/php/php.ini(デフォルトではphp.iniは含まれていません)
  • 追加の設定ファイル: /usr/local/etc/php/conf.d/*.ini
  • PHP拡張モジュール: /usr/local/lib/php/extensions/no-debug-zts-<YYYYMMDD>/
  • PHPプロジェクトが提供する公式テンプレートをコピーすることを推奨します:
FROM dunglas/frankenphp

# 本番環境:
RUN cp $PHP_INI_DIR/php.ini-production $PHP_INI_DIR/php.ini

# または開発環境:
RUN cp $PHP_INI_DIR/php.ini-development $PHP_INI_DIR/php.ini

# RPMおよびDebianパッケージ

  • php.ini: /etc/frankenphp/php.ini(本番環境向けのプリセットのphp.iniファイルがデフォルトで提供されます)
  • 追加の設定ファイル: /etc/frankenphp/php.d/*.ini
  • PHP拡張モジュール: /usr/lib/frankenphp/modules/

# 静的バイナリ

  • php.ini: frankenphp runまたはfrankenphp php-serverを実行したディレクトリ内、なければ/etc/frankenphp/php.iniを参照
  • 追加の設定ファイル: /etc/frankenphp/php.d/*.ini
  • PHP拡張モジュール: ロードできません、バイナリ自体にバンドルする必要があります
  • PHPソースで提供されるphp.ini-productionまたはphp.ini-developmentのいずれかをコピーしてください

# Caddyfileの設定

php_serverまたはphpHTTPディレクティブは、サイトブロック内で使用してPHPアプリを配信できます。

最小構成の例:

localhost {
	# 圧縮を有効化(オプション)
	encode zstd br gzip
	# 現在のディレクトリ内のPHPファイルを実行し、アセットを配信
	php_server
}

グローバルオプションを使用してFrankenPHPを明示的に設定することもできます: frankenphpグローバルオプションを使用してFrankenPHPを構成できます。

{
	frankenphp {
		num_threads <num_threads> # 開始するPHPスレッド数を設定します。デフォルト: 利用可能なCPU数の2倍。
		max_threads <num_threads> # 実行時に追加で開始できるPHPスレッドの最大数を制限します。デフォルト: num_threads。 'auto'を設定可能。
		max_wait_time <duration> # リクエストがタイムアウトする前にPHPのスレッドが空くのを待つ最大時間を設定します。デフォルト: 無効。
		php_ini <key> <value> # php.iniのディレクティブを設定します。複数のディレクティブを設定するために何度でも使用できます。
		worker {
			file <path> # ワーカースクリプトのパスを設定します。
			num <num> # 開始するPHPスレッド数を設定します。デフォルト: 利用可能なCPU数の2倍。
			env <key> <value> # 追加の環境変数を指定された値に設定する。複数の環境変数に対して複数回指定することができます。
			watch <path> # ファイル変更を監視するパスを設定します。複数のパスに対して複数回指定できます。
			name <name> # ワーカーの名前を設定します。ログとメトリクスで使用されます。デフォルト: ワーカーファイルの絶対パス
			max_consecutive_failures <num> # workerが不健全とみなされるまでの、連続失敗の最大回数を設定します。 -1 はワーカーを常に再起動することを意味します。デフォルトは 6 です。
		}
	}
}

# ...

代わりに、workerオプションのワンライナー形式を使用することもできます:

{
	frankenphp {
		worker <file> <num>
	}
}

# ...

同じサーバーで複数のアプリを提供する場合は、複数のワーカーを定義することもできます:

app.example.com {
    root /path/to/app/public
	php_server {
		root /path/to/app/public # キャッシュ効率を高める
		worker index.php <num>
	}
}

other.example.com {
    root /path/to/other/public
	php_server {
		root /path/to/other/public
		worker index.php <num>
	}
}

# ...

通常はphp_serverディレクティブを使えば十分ですが、 より細かい制御が必要な場合は、より低レベルのphpディレクティブを使用できます。 phpディレクティブは、対象がPHPファイルかどうかを確認せず、すべての入力をPHPに渡します。 詳しくはパフォーマンスページをお読みください。

php_serverディレクティブの使用は、以下の設定と同等です:

route {
	# ディレクトリへのリクエストに末尾スラッシュを追加
	@canonicalPath {
		file {path}/index.php
		not path */
	}
	redir @canonicalPath {path}/ 308
	# 要求されたファイルが存在しない場合は、indexファイルを試行
	@indexFiles file {
		try_files {path} {path}/index.php index.php
		split_path .php
	}
	rewrite @indexFiles {http.matchers.file.relative}
	# FrankenPHP!
	@phpFiles path *.php
	php @phpFiles
	file_server
}

php_serverphpディレクティブには以下のオプションがあります:

php_server [<matcher>] {
	root <directory> # サイトのルートフォルダを設定します。デフォルト: `root`ディレクティブ。
	split_path <delim...> # URIを2つの部分に分割するための部分文字列を設定します。最初にマッチする部分文字列がURIから「パス情報」を分割するために使用されます。最初の部分はマッチする部分文字列で接尾辞が付けられ、実際のリソース(CGIスクリプト)名とみなされます。2番目の部分はスクリプトが使用する PATH_INFO に設定されます。デフォルト: `.php`
	resolve_root_symlink false # シンボリックリンクが存在する場合`root`ディレクトリをシンボリックリンクの評価によって実際の値に解決することを無効にする(デフォルトで有効)。
	env <key> <value> # 追加の環境変数を指定された値に設定する。複数の環境変数を指定する場合は、複数回指定することができます。
	file_server off # 組み込みのfile_serverディレクティブを無効にします。
	worker { # このサーバー固有のワーカーを作成します。複数のワーカーに対して複数回指定できます。
		file <path> # ワーカースクリプトへのパスを設定します。php_serverのルートからの相対パスとなります。
		num <num> # 起動するPHPスレッド数を設定します。デフォルトは利用可能なスレッド数の 2 倍です。
		name <name> # ログとメトリクスで使用されるワーカーの名前を設定します。デフォルト: ワーカーファイルの絶対パス。php_server ブロックで定義されている場合は、常にm#で始まります。
		watch <path> # ファイルの変更を監視するパスを設定する。複数のパスに対して複数回指定することができる。
		env <key> <value> # 追加の環境変数を指定された値に設定する。複数の環境変数を指定する場合は、複数回指定することができます。このワーカーの環境変数もphp_serverの親から継承されますが、 ここで上書きすることもできます。
		match <path> # ワーカーをパスパターンにマッチさせます。try_filesを上書きし、php_serverディレクティブでのみ使用できます。
	}
	worker <other_file> <num> # グローバルfrankenphpブロックのような短縮形式も使用できます。
}

# ファイルの変更監視

ワーカーはアプリケーションを一度だけ起動してメモリに保持するため、 PHPファイルに変更を加えても即座には反映されません。

代わりに、watchディレクティブを使用してファイル変更時にワーカーを再起動させることができます。 これは開発環境において有用です。

{
	frankenphp {
		worker {
			file  /path/to/app/public/worker.php
			watch
		}
	}
}

watchディレクトリが指定されていない場合、./**/*.{php,yaml,yml,twig,env}にフォールバックします。 これは、FrankenPHPプロセスが開始されたディレクトリおよびそのサブディレクトリ内のすべての.php.yaml.yml.twig.envファイルすべてを監視します。 代わりに、シェルのファイル名パターンを使用して 1つ以上のディレクトリを指定することもできます:

{
	frankenphp {
		worker {
			file  /path/to/app/public/worker.php
			watch /path/to/app # /path/to/app以下すべてのサブディレクトリのファイルを監視
			watch /path/to/app/*.php # /path/to/app内の.phpで終わるファイルを監視
			watch /path/to/app/**/*.php # /path/to/appおよびサブディレクトリのPHPファイルを監視
			watch /path/to/app/**/*.{php,twig} # /path/to/appおよびサブディレクトリ内のPHPとTwigファイルを監視
		}
	}
}
  • ** パターンは再帰的な監視を意味します
  • ディレクトリは相対パス(FrankenPHPプロセスの開始ディレクトリから)にもできます
  • 複数のワーカーが定義されている場合、いずれかのファイルが変更されるとすべてのワーカーが再起動されます
  • 実行時に生成されるファイル(ログなど)を監視対象に含めると、意図しないワーカーの再起動を引き起こす可能性があるため注意が必要です

ファイルウォッチャーはe-dant/watcherに基づいています。

# パスにワーカーをマッチさせる

従来のPHPアプリケーションでは、スクリプトは常にpublicディレクトリに配置されます。 これはワーカースクリプトにも当てはまり、他のPHPスクリプトと同様に扱われます。 ワーカースクリプトをpublicディレクトリの外に配置したい場合は、matchディレクティブを使用して実現できます。

matchディレクティブは、try_filesの最適化された代替手段であり、php_serverおよびphpの中でのみ使用できます。 次の例では、public ディレクトリ内にファイルが存在すればそれを配信し、 存在しなければ、パスパターンに一致するワーカーにリクエストを転送します。

{
	frankenphp {
		php_server {
			worker {
				file /path/to/worker.php # ファイルはpublicパス外でも可
				match /api/* # /api/で始まるすべてのリクエストはこのワーカーで処理される
			}
		}
	}
}

# フルデュプレックス(HTTP/1)

HTTP/1.xを使用する場合、全体のボディが読み取られる前にレスポンスを書き込めるようにするため、 フルデュプレックスモードを有効にすることが望ましい場合があります(例:WebSocket、Server-Sent Eventsなど)。

これは明示的に有効化する必要がある設定で、Caddyfileのグローバルオプションに追加する必要があります:

{
  servers {
    enable_full_duplex
  }
}

Caution

このオプションを有効にすると、フルデュプレックスをサポートしない古いHTTP/1.xクライアントでデッドロックが発生する可能性があります。 これはCADDY_GLOBAL_OPTIONS環境設定を使用しても設定できます:

CADDY_GLOBAL_OPTIONS="servers {
  enable_full_duplex
}"

この設定の詳細については、Caddyドキュメントをご覧ください。

# 環境変数

以下の環境変数を使用することで、Caddyfileを直接変更せずにCaddyディレクティブを注入できます:

  • SERVER_NAME: 待ち受けアドレスを変更し、指定したホスト名はTLS証明書の生成にも使用されます
  • SERVER_ROOT: サイトのルートディレクトリを変更します。デフォルトはpublic/
  • CADDY_GLOBAL_OPTIONS: グローバルオプションを注入します
  • FRANKENPHP_CONFIG: frankenphpディレクティブの下に設定を注入します

FPM や CLI SAPI と同様に、環境変数はデフォルトで$_SERVERスーパーグローバルで公開されます。

variables_order PHPディレクティブS値は、このディレクティブ内でのEの位置にかかわらず常にESと同等です。

# PHP設定

追加のPHP設定ファイルを読み込むには、 PHP_INI_SCAN_DIR環境変数を使用できます。 設定されると、PHPは指定されたディレクトリに存在する.ini拡張子を持つすべてのファイルを読み込みます。

また、Caddyfilephp_iniディレクティブを使用してPHP設定を変更することもできます:

{
    frankenphp {
        php_ini memory_limit 256M

        # または

        php_ini {
            memory_limit 256M
            max_execution_time 15
        }
    }
}

# デバッグモードの有効化

Dockerイメージを使用する場合、CADDY_GLOBAL_OPTIONS環境変数にdebugを設定するとデバッグモードが有効になります:

docker run -v $PWD:/app/public \
    -e CADDY_GLOBAL_OPTIONS=debug \
    -p 80:80 -p 443:443 -p 443:443/udp \
    dunglas/frankenphp
このページを編集