The modern PHP app server https://frankenphp.dev/

Alliballibaba 7ff632285f Merge branch 'main' into feat/auto-scale-clock-time 2 days ago
.github 7ff632285f Merge branch 'main' into feat/auto-scale-clock-time 2 days ago
caddy 7ff632285f Merge branch 'main' into feat/auto-scale-clock-time 2 days ago
docs 7ff632285f Merge branch 'main' into feat/auto-scale-clock-time 2 days ago
internal 7ff632285f Merge branch 'main' into feat/auto-scale-clock-time 2 days ago
testdata 7adc465923 Removes sleep. 2 weeks ago
.dockerignore 6f108a4203 fix: do not extract embedded app on every execution (#488) 1 year ago
.gitignore 2e72b50d10 ci: add Apple Silicon build script (#313) 1 year ago
.hadolint.yaml c9bf9940d1 ci: add Super-Linter (#323) 1 year ago
.markdown-lint.yaml c9bf9940d1 ci: add Super-Linter (#323) 1 year ago
CONTRIBUTING.md 233753ca6b docs: update docs for first-time contributor (#1368) 4 days ago
Dockerfile 69c43ee43d chore: use upstream e-dant/watcher headers and build system (#1119) 3 months ago
LICENSE f8bdd640cf docs: add license (#24) 2 years ago
README.md 9dd05b0b1b docs: link metrics docs to website (#1370) 4 days ago
SECURITY.md 17e57287eb docs: fix link in SECURITY.md (#1111) 4 months ago
alpine.Dockerfile 16bb790d52 fix: rollback to stock Go version 1 month ago
app.tar 537f899939 feat: use tar to embed apps (#333) 1 year ago
app_checksum.txt 6f108a4203 fix: do not extract embedded app on every execution (#488) 1 year ago
backoff.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 3 months ago
backoff_test.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 3 months ago
build-static.sh 5b86f2c554 ci: fix build-static.sh CS 1 month ago
cgi.go dd250e3bda perf: optimized request headers (#1335) 3 weeks ago
debugstate.go 319f61c4cb Removes request locking. 5 days ago
dev-alpine.Dockerfile f61bc180c4 chore: upgrade to Go 1.24 3 days ago
dev.Dockerfile f61bc180c4 chore: upgrade to Go 1.24 3 days ago
docker-bake.hcl f61bc180c4 chore: upgrade to Go 1.24 3 days ago
embed.go d53f909d20 chore: various cleanups 4 months ago
env.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 3 months ago
frankenphp.c 7ff632285f Merge branch 'main' into feat/auto-scale-clock-time 2 days ago
frankenphp.go b3fd756838 Merge branch 'main' into feat/auto-scale-clock-time 3 weeks ago
frankenphp.h b3fd756838 Merge branch 'main' into feat/auto-scale-clock-time 3 weeks ago
frankenphp.png 625ab8906f docs: update logo 2 years ago
frankenphp.stub.php ea5e19ff4b fix: getallheaders() must return request headers (#772) 9 months ago
frankenphp_arginfo.h c080608661 Applies suggestions by @dunglas 2 months ago
frankenphp_test.go dd250e3bda perf: optimized request headers (#1335) 3 weeks ago
go.mod f61bc180c4 chore: upgrade to Go 1.24 3 days ago
go.sum f61bc180c4 chore: upgrade to Go 1.24 3 days ago
install.sh cda74730ae fix: term capability code may not be available 4 months ago
metrics.go 5282e3202b Resets strategy and fixes tests. 1 month ago
metrics_test.go 5282e3202b Resets strategy and fixes tests. 1 month ago
options.go 7de097241a phpIniOverrides -> phpIni 1 month ago
phpmainthread.go 4e03be1d06 Turns the debug state into json. 2 weeks ago
phpmainthread_test.go deec7eed63 Adds suggestions by @dunglas. 2 weeks ago
phpthread.go 319f61c4cb Removes request locking. 5 days ago
recorder_test.go 75dab8f33d chore: bump deps and misc improvements (#1135) 3 months ago
release.sh 0fc6ccc5ce ci: automatically create the Brew formula PR on release 2 months ago
reload_test.sh 6c708be99d ci: upgrade to super-linter 6 (#952) 6 months ago
request_options.go 2b7b3d1e4b perf: put all $_SERVER vars into one function call. (#1303) 1 month ago
scaling.go 319f61c4cb Removes request locking. 5 days ago
scaling_test.go 83e0c0806c Adjusts scaling logic and comments. 1 month ago
state.go 319f61c4cb Removes request locking. 5 days ago
state_test.go 3672c60fa0 Also adds compareAndSwap to the test. 2 months ago
static-builder.Dockerfile 16bb790d52 fix: rollback to stock Go version 1 month ago
threadinactive.go 4e03be1d06 Turns the debug state into json. 2 weeks ago
threadregular.go 319f61c4cb Removes request locking. 5 days ago
threadworker.go 319f61c4cb Removes request locking. 5 days ago
watcher_test.go b3fd756838 Merge branch 'main' into feat/auto-scale-clock-time 3 weeks ago
worker.go a1f89e3c4d Resets opcache_reset logic. 2 weeks ago
worker_test.go ece420c569 chore: fix typos (#1328) 1 month ago

README.md

FrankenPHP: Modern App Server for PHP

FrankenPHP

FrankenPHP is a modern application server for PHP built on top of the Caddy web server.

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 works with any PHP app and makes your Laravel and Symfony projects faster than ever thanks to their official integrations with the worker mode.

FrankenPHP can also be used as a standalone Go library to embed PHP in any app using net/http.

Learn more on frankenphp.dev and in this slide deck:

Slides

Getting Started

Docker

docker run -v .:/app/public \
    -p 80:80 -p 443:443 -p 443:443/udp \
    dunglas/frankenphp

Go to https://localhost, and enjoy!

[!TIP]

Do not attempt to use https://127.0.0.1. Use https://localhost and accept the self-signed certificate. Use the SERVER_NAME environment variable to change the domain to use.

Standalone Binary

If you prefer not to use Docker, we provide standalone FrankenPHP binaries for Linux and macOS containing PHP 8.4 and most popular PHP extensions.

On Windows, use WSL to run FrankenPHP.

Download FrankenPHP or copy this line into your terminal to automatically install the version appropriate for your platform:

curl https://frankenphp.dev/install.sh | sh
mv frankenphp /usr/local/bin/

To serve the content of the current directory, run:

frankenphp php-server

You can also run command-line scripts with:

frankenphp php-cli /path/to/your/script.php

Docs

Examples and Skeletons