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

Alliballibaba f35f5c4dcc Shortens the configuration. 2 weeks ago
.github 7aaea72f14 ci: fix linter 1 month ago
caddy c2ca4dbf03 feat(caddy): use new first_exist_fallback try policy 2 weeks ago
docs f35f5c4dcc Shortens the configuration. 2 weeks ago
internal 0328d0600e fix: missing build tag for fastabs 2 months ago
testdata 8cf6616ed6 fix: SIGSEGV when an env var is empty (#1271) 1 month 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 a3e5af523c docs: update CONTRIBUTING.md (#1270) 1 month ago
Dockerfile 69c43ee43d chore: use upstream e-dant/watcher headers and build system (#1119) 2 months ago
LICENSE f8bdd640cf docs: add license (#24) 2 years ago
README.md a396e64ad6 feat: build static binaries with 8.4 (#1193) 2 months ago
SECURITY.md 17e57287eb docs: fix link in SECURITY.md (#1111) 3 months ago
alpine.Dockerfile 69c43ee43d chore: use upstream e-dant/watcher headers and build system (#1119) 2 months 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) 2 months ago
backoff_test.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 2 months ago
build-static.sh 851ff9976e fix(static): ARM Linux builds 1 month ago
cgi.go 045ce00c15 perf: remove some useless string pinning (#1295) 2 weeks ago
dev-alpine.Dockerfile 8a199bb4d7 chore: remove useless EDANT_WATCHER_VERSION Docker ARG 1 month ago
dev.Dockerfile 8a199bb4d7 chore: remove useless EDANT_WATCHER_VERSION Docker ARG 1 month ago
docker-bake.hcl 8a199bb4d7 chore: remove useless EDANT_WATCHER_VERSION Docker ARG 1 month ago
embed.go d53f909d20 chore: various cleanups 3 months ago
env.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 2 months ago
frankenphp.c f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
frankenphp.go fbbc129e4d fix: graceful shutdown (#1242) 1 month ago
frankenphp.h f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
frankenphp.png 625ab8906f docs: update logo 2 years ago
frankenphp.stub.php ea5e19ff4b fix: getallheaders() must return request headers (#772) 8 months ago
frankenphp_arginfo.h f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
frankenphp_test.go 8cf6616ed6 fix: SIGSEGV when an env var is empty (#1271) 1 month ago
go.mod 2276129c6d feat(caddy): upgrade to Caddy 2.9.0 2 weeks ago
go.sum 2276129c6d feat(caddy): upgrade to Caddy 2.9.0 2 weeks ago
install.sh cda74730ae fix: term capability code may not be available 3 months ago
metrics.go 843d199469 perf: cache computations in WithRequestDocumentRoot (#1154) 2 months ago
metrics_test.go aa585f7da0 handle worker failures gracefully (#1038) 3 months ago
options.go 8d9b6e755b feat: restart workers when on source changes (#1013) 3 months ago
phpmainthread.go 92f95342d1 fix: SIGSEGV with env vars (#1278) 1 month ago
phpmainthread_test.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
phpthread.go 92f95342d1 fix: SIGSEGV with env vars (#1278) 1 month ago
recorder_test.go 75dab8f33d chore: bump deps and misc improvements (#1135) 2 months ago
release.sh 0fc6ccc5ce ci: automatically create the Brew formula PR on release 1 month ago
reload_test.sh 6c708be99d ci: upgrade to super-linter 6 (#952) 5 months ago
request_options.go 843d199469 perf: cache computations in WithRequestDocumentRoot (#1154) 2 months ago
state.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
state_test.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
static-builder.Dockerfile d276032e20 feat(static): add custom Caddy modules support (#1210) 1 month ago
thread-inactive.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
thread-regular.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
thread-worker.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
watcher_test.go afedeb9d58 refactor: use build tags to disable, instead of to enable a feature (#1113) 3 months ago
worker.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 month ago
worker_test.go 75dab8f33d chore: bump deps and misc improvements (#1135) 2 months 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