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

dependabot[bot] c4582c698f ci: bump actions/download-artifact from 3 to 4 1 year ago
.github c4582c698f ci: bump actions/download-artifact from 3 to 4 1 year ago
C-Thread-Pool 3709c2a50b chore: switch to upstream C-Thread-Pool 1 year ago
caddy 64672a267a chore: bump deps (#429) 1 year ago
docs f6873efee4 Added Laravel Octane Documentation (#422) 1 year ago
internal aa1d968dcf refactor: faster $_SERVER variables creation 1 year ago
testdata f71f9875ca perf: add benchmark (#392) 1 year ago
.dockerignore 537f899939 feat: use tar to embed apps (#333) 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 5c9d7d3f6d docs: link to the website 1 year ago
Dockerfile fd6e28df2a ci: improve linker flags (#383) 1 year ago
LICENSE f8bdd640cf docs: add license (#24) 2 years ago
README.md 0054b92115 docs: link to TYPO3 skeleton 1 year ago
alpine.Dockerfile fd6e28df2a ci: improve linker flags (#383) 1 year ago
app.tar 537f899939 feat: use tar to embed apps (#333) 1 year ago
build-static.sh 9bf991ca88 ci: add igbinary extension and LZ4 support to static builds 1 year ago
cgi.go aa1d968dcf refactor: faster $_SERVER variables creation 1 year ago
dev-alpine.Dockerfile c9bf9940d1 ci: add Super-Linter (#323) 1 year ago
dev.Dockerfile c9bf9940d1 ci: add Super-Linter (#323) 1 year ago
docker-bake.hcl 67fdefc416 ci: build Linux aarch64 binaries (#432) 1 year ago
embed.go 537f899939 feat: use tar to embed apps (#333) 1 year ago
frankenphp.c 517e086786 fix: random crashes when reloading (#394) 1 year ago
frankenphp.go 7c5f18fe3f ci: fix changelog generation 1 year ago
frankenphp.h c9bf9940d1 ci: add Super-Linter (#323) 1 year ago
frankenphp.png 625ab8906f docs: update logo 2 years ago
frankenphp.stub.php 9ef3bd7c47 feat: add fastcgi_finish_request() support (#69) 2 years ago
frankenphp_arginfo.h c9bf9940d1 ci: add Super-Linter (#323) 1 year ago
frankenphp_test.go aa1d968dcf refactor: faster $_SERVER variables creation 1 year ago
go.mod 9b09be22be chore: bump github.com/stretchr/testify from 1.8.1 to 1.8.4 1 year ago
go.sum 9b09be22be chore: bump github.com/stretchr/testify from 1.8.1 to 1.8.4 1 year ago
options.go fb63099a88 feat: allow passing env vars to workers (#210) 1 year ago
recorder_test.go 5012ac30cd chore: improve tests and add missing file (#13) 2 years ago
release.sh 7c5f18fe3f ci: fix changelog generation 1 year ago
reload_test.sh 517e086786 fix: random crashes when reloading (#394) 1 year ago
request_options.go aa1d968dcf refactor: faster $_SERVER variables creation 1 year ago
static-builder.Dockerfile b7c8d4cd49 Add ctype and session PHP extensions to static builder 1 year ago
worker.go b4aa8038ff feat: detect when worker crashes or terminates normally (#315) 1 year ago
worker_test.go aa1d968dcf refactor: faster $_SERVER variables creation 1 year 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 Symfony and Laravel projects faster than ever thanks to the provided integration 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 $PWD:/app/public \
    -p 80:80 -p 443:443 \
    dunglas/frankenphp

Go to https://localhost, and enjoy!

[!TIP]

Do not attempt to use https://127.0.0.1. Use localhost and accept the self-signed certificate. Caddy has an automatic TLS handling that auto-trusts some local-based hostnames like localhost, but it does not apply to IP addresses. More details on Caddy's "automatic https" docs.

Standalone Binary

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

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