Goで書かれたPHPアプリケーションサーバーであるFrankenPHPを触ってみました。
2023/12/11にバージョン1.0.0がリリースされたPHPアプリケーションサーバーです。やっと触れました。
FrankenPHPとは
公式より
FrankenPHP is a modern application server for PHP built on top of the Caddy web server.
FrankenPHPは、Caddy Webサーバー(※1)の上に構築されたPHP用のモダンなアプリケーションサーバーです。
FrankenPHP gives superpowers to your PHP apps thanks to its stunning features: Early Hints, worker mode, real-time capabilities, automatic HTTPS, HTTP/2, and HTTP/3 support…
FrankenPHPは素晴らしい機能で、あなたのPHPアプリケーションにスーパーパワーを与えます: アーリーヒント(※2)、ワーカーモード、リアルタイム機能、自動HTTPS、HTTP/2、HTTP/3のサポート
FrankenPHP works with any PHP app and makes your Symfony projects faster than ever thanks to the provided integration with the worker mode (Laravel Octane support coming).
FrankenPHPはどのようなPHPアプリでも動作し、ワーカーモードとの統合によりSymfonyプロジェクトをこれまで以上に高速化します。
(LaravelのOctaneサポートも予定されているようです。)
FrankenPHP can also be used as a standalone Go library to embed PHP in any app using net/http.
FrankenPHPは、スタンドアローンのGoライブラリとしても使用でき、net/httpを使用するアプリケーションにPHPを組み込むことができます。
補足
※1 Goで実装されたWEBサーバー
公式
※2 HTTP Status Code 103 Early Hints とはWebの読み込みを30%以上高速化させることが期待されている新しいWeb標準のステータスコード
おすすめブログ
ネイティブサポート
主要なフレームワークやCMSに対応しています。
- Laravel
- Symfony
- WordPress
- Drupal
etc.
FrankenPHPの機能
- PHP 8.2以降のほとんどのPHP機能拡張、およびすべてのCaddyモジュールと互換性を持っている
- アプリケーションを起動しメモリに保持しておくワーカーモード
- 1つのサービス、1つのバイナリだけでPHP-FPMを必要としない(Nginxも不要)。独自のSAPIを利用
- PHPアプリをスタンドアロンで自己実行可能な静的バイナリとしてパッケージ化することも可
- Early Hintsをサポートする唯一のPHP SAPI
- Mercure ハブを内蔵し、イベントをWebブラウザへ送信、JavaScriptイベントとしてペイロードを受け取れる
- ZstandardおよびGzip圧縮
- 構造化されたログ
- HTTPS・HTTP/2・HTTP/3のネイティブサポート
- Prometheusサポート
- HTTPS証明書の自動生成や更新
- グレースフル・リロードにより、ダウンタイムなしでアプリをデプロイ可能
Let's try
今回は公式の手順に従ってDockerでの起動を試してみます。
Dockerfileで書きたい、もっと拡張したいなどは公式のdocker.md見ると良さそうです。
docker run -v $PWD:/app/public \
-p 80:80 -p 443:443 \
dunglas/frankenphp
バインドのローカルパスは$PWD
が指定されているので、コマンド実行する時にお気をつけください。
$PWD:/app/public
ログを見るとPHPのバージョンは8.3.0
が利用されています。(ログはJSONになってます)
{"level":"info","ts":1702945366.1317804,"msg":"FrankenPHP started 🐘","php_version":"8.3.0"}
公式に従ってhttps://localhost
にアクセスします。
Go to https://localhost, and enjoy!
しっかりエラーログも確認できました。何もないので404となったようです。
ERROR http.log.access.log0 handled request {"request": {"remote_ip": "***.***.***.***", "remote_port": "*****", "client_ip": "***.***.***.***", "proto": "HTTP/2.0", "method": "GET", "host": "localhost", "uri": "/", "headers": {"Accept": ["text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7"], "Sec-Fetch-Dest": ["document"], "Sec-Ch-Ua-Mobile": ["?0"], "Sec-Fetch-Mode": ["navigate"], "Accept-Language": ["ja"], "Sec-Fetch-User": ["?1"], "Cache-Control": ["max-age=0"], "Dnt": ["1"], "Upgrade-Insecure-Requests": ["1"], "Sec-Fetch-Site": ["none"], "Sec-Ch-Ua": ["\"Not_A Brand\";v=\"8\", \"Chromium\";v=\"120\", \"Google Chrome\";v=\"120\""], "Sec-Ch-Ua-Platform": ["\"macOS\""], "User-Agent": ["Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"], "Accept-Encoding": ["gzip, deflate, br"]}, "tls": {"resumed": false, "version": 772, "cipher_suite": 4865, "proto": "h2", "server_name": "localhost"}}, "bytes_read": 0, "user_id": "", "duration": 0.001238042, "size": 0, "status": 404, "resp_headers": {"Server": ["Caddy"], "Alt-Svc": ["h3=\":443\"; ma=2592000"]}}
Dockerコンテナの中を探検
※ Docker Desktopのダッシュボードを利用しています。
OSはDebian bookworm、カーネルは6.4.16-linuxkitが使われています。
# cat /etc/os-release
PRETTY_NAME="Debian GNU/Linux 12 (bookworm)"
NAME="Debian GNU/Linux"
VERSION_ID="12"
VERSION="12 (bookworm)"
VERSION_CODENAME=bookworm
ID=debian
HOME_URL="https://www.debian.org/"
SUPPORT_URL="https://www.debian.org/support"
BUG_REPORT_URL="https://bugs.debian.org/"
# cat /proc/version
Linux version 6.4.16-linuxkit (root@buildkitsandbox) (gcc (Alpine 12.2.1_git20220924-r10) 12.2.1 20220924, GNU ld (GNU Binutils) 2.40) #1 SMP PREEMPT Thu Nov 16 10:49:20 UTC 2023
# openssl version
OpenSSL 3.0.11 19 Sep 2023 (Library: OpenSSL 3.0.11 19 Sep 2023)
PHPのバージョンは上述のように8.3.0が利用されていて、PDOをなどをはじめとしてPHP拡張モジュールも多く入っています。
# php -v
PHP 8.3.0 (cli) (built: Dec 16 2023 02:04:34) (ZTS)
Copyright (c) The PHP Group
Zend Engine v4.3.0, Copyright (c) Zend Technologies
# php -m
[PHP Modules]
Core
ctype
curl
date
dom
fileinfo
filter
ftp
hash
iconv
json
libxml
mbstring
mysqlnd
openssl
pcre
PDO
pdo_sqlite
Phar
posix
random
readline
Reflection
session
SimpleXML
sodium
SPL
sqlite3
standard
tokenizer
xml
xmlreader
xmlwriter
zlib
[Zend Modules]
何か表示させてみる!!
コンテナの/app/public
に.phpファイルを置いてみました。
# pwd
/app/public
# ls
example.php
# cat example.php
<?php
echo "Hello FrankenPHP!!";
おわりに
なかなか時間がなくDockerコンテナを起動させるだけに留まってしました。
(これだとただPHPコンテナ起動したのと同じじゃん。。。)
近いうちにStatic BuildとLaravelのアプリケーションをFrankenPHPを使って作成してみようと思います。(Laravelはすぐできそう)
Caddyも深掘りしてみたいし、個人的にはEarly Hintsもちゃんと勉強しようと思いました。キャッチアップ大変だけど、面白いですね😄
一緒に働いてくれる仲間募集中
GoQSystemでは一緒に働いてくれるPHPエンジニアを募集中です!