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

Alliballibaba 66d52c2408 test123 1 неделя назад
.github 424ca426cb fix: timeouts handling on macOS (#1435) 1 неделя назад
caddy 6203d207fa chore(caddy): bump github.com/caddyserver/certmagic in /caddy 1 неделя назад
docs 78824107f0 docs: Homebrew installation instructions 3 недель назад
internal 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
testdata c57f741d83 fix: concurrent env access (#1409) 3 недель назад
.dockerignore 6f108a4203 fix: do not extract embedded app on every execution (#488) 1 год назад
.gitignore 2e72b50d10 ci: add Apple Silicon build script (#313) 1 год назад
.hadolint.yaml c9bf9940d1 ci: add Super-Linter (#323) 1 год назад
.markdown-lint.yaml c9bf9940d1 ci: add Super-Linter (#323) 1 год назад
CONTRIBUTING.md 424ca426cb fix: timeouts handling on macOS (#1435) 1 неделя назад
Dockerfile 69c43ee43d chore: use upstream e-dant/watcher headers and build system (#1119) 4 месяцев назад
LICENSE f8bdd640cf docs: add license (#24) 2 лет назад
README.md 78824107f0 docs: Homebrew installation instructions 3 недель назад
SECURITY.md 17e57287eb docs: fix link in SECURITY.md (#1111) 5 месяцев назад
alpine.Dockerfile 16bb790d52 fix: rollback to stock Go version 2 месяцев назад
app.tar 537f899939 feat: use tar to embed apps (#333) 1 год назад
app_checksum.txt 6f108a4203 fix: do not extract embedded app on every execution (#488) 1 год назад
backoff.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 3 месяцев назад
backoff_test.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 3 месяцев назад
build-static.sh f2bae25a78 chore: update static build cli PHP version to 8.4 (#1425) 1 неделя назад
cgi.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
context.go 66d52c2408 test123 1 неделя назад
debugstate.go 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
dev-alpine.Dockerfile f61bc180c4 chore: upgrade to Go 1.24 1 месяц назад
dev.Dockerfile f61bc180c4 chore: upgrade to Go 1.24 1 месяц назад
docker-bake.hcl f61bc180c4 chore: upgrade to Go 1.24 1 месяц назад
embed.go d53f909d20 chore: various cleanups 5 месяцев назад
env.go c57f741d83 fix: concurrent env access (#1409) 3 недель назад
frankenphp.c 66d52c2408 test123 1 неделя назад
frankenphp.go 8d9ce15849 fix: log worker failures (#1437) 1 неделя назад
frankenphp.h 66d52c2408 test123 1 неделя назад
frankenphp.png 625ab8906f docs: update logo 2 лет назад
frankenphp.stub.php ea5e19ff4b fix: getallheaders() must return request headers (#772) 10 месяцев назад
frankenphp_arginfo.h f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 3 месяцев назад
frankenphp_test.go a9cf944b62 ci: env test remediation (#1436) 1 неделя назад
go.mod 409c0fdf5f chore: bump deps (#1434) 1 неделя назад
go.sum 409c0fdf5f chore: bump deps (#1434) 1 неделя назад
install.sh cda74730ae fix: term capability code may not be available 5 месяцев назад
metrics.go 3ba4e257a1 fix: only drain workers on graceful shutdown (#1405) 3 недель назад
metrics_test.go 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
options.go 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
phpmainthread.go 66d52c2408 test123 1 неделя назад
phpmainthread_test.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
phpthread.go 66d52c2408 test123 1 неделя назад
recorder_test.go 75dab8f33d chore: bump deps and misc improvements (#1135) 4 месяцев назад
release.sh 0fc6ccc5ce ci: automatically create the Brew formula PR on release 3 месяцев назад
reload_test.sh 6c708be99d ci: upgrade to super-linter 6 (#952) 7 месяцев назад
request_options.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
scaling.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
scaling_test.go 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
state.go 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
state_test.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 3 месяцев назад
static-builder.Dockerfile f2bae25a78 chore: update static build cli PHP version to 8.4 (#1425) 1 неделя назад
threadinactive.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
threadregular.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
threadworker.go 66d52c2408 test123 1 неделя назад
watcher_test.go 072151dfee feat: Adds automatic thread scaling at runtime and php_ini configuration in Caddyfile (#1266) 1 месяц назад
worker.go f50248a7d2 refactor: removes context on the C side (#1404) 1 неделя назад
worker_test.go ece420c569 chore: fix typos (#1328) 2 месяцев назад

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

Standalone Binary

We provide static 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

![WARNING]

In production, prefer using the Docker images, the Brew package or compiling FrankenPHP from sources. The standalone binary is provided for development and testing purposes.

Docker

Alternatively, Docker images are available:

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.

Homebrew

FrankenPHP is also available as a Homebrew package for macOS and Linux.

To install it:

brew install dunglas/frankenphp/frankenphp

To serve the content of the current directory, run:

frankenphp php-server

Docs

Examples and Skeletons