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

Kévin Dunglas 34262949d7 ci: fix push or Docker dev images 9 месяцев назад
.github 34262949d7 ci: fix push or Docker dev images 9 месяцев назад
C-Thread-Pool 3709c2a50b chore: switch to upstream C-Thread-Pool 11 месяцев назад
caddy 175b9a0296 feat: add Brotli compression support (#524) 9 месяцев назад
docs 3d9f344a50 docs: Docker image updates and tags 9 месяцев назад
internal aa1d968dcf refactor: faster $_SERVER variables creation 1 год назад
testdata 5a8e5f9518 feat: add apache_response_headers() function (#530) 9 месяцев назад
.dockerignore 6f108a4203 fix: do not extract embedded app on every execution (#488) 10 месяцев назад
.gitignore 2e72b50d10 ci: add Apple Silicon build script (#313) 1 год назад
.hadolint.yaml c9bf9940d1 ci: add Super-Linter (#323) 11 месяцев назад
.markdown-lint.yaml c9bf9940d1 ci: add Super-Linter (#323) 11 месяцев назад
CONTRIBUTING.md b624a13430 docs: improve HTTPS documentation (#480) 10 месяцев назад
Dockerfile 175b9a0296 feat: add Brotli compression support (#524) 9 месяцев назад
LICENSE f8bdd640cf docs: add license (#24) 2 лет назад
README.md b624a13430 docs: improve HTTPS documentation (#480) 10 месяцев назад
alpine.Dockerfile 175b9a0296 feat: add Brotli compression support (#524) 9 месяцев назад
app.tar 537f899939 feat: use tar to embed apps (#333) 11 месяцев назад
app_checksum.txt 6f108a4203 fix: do not extract embedded app on every execution (#488) 10 месяцев назад
build-static.sh 175b9a0296 feat: add Brotli compression support (#524) 9 месяцев назад
cgi.go aa1d968dcf refactor: faster $_SERVER variables creation 1 год назад
dev-alpine.Dockerfile 175b9a0296 feat: add Brotli compression support (#524) 9 месяцев назад
dev.Dockerfile 175b9a0296 feat: add Brotli compression support (#524) 9 месяцев назад
docker-bake.hcl 67fdefc416 ci: build Linux aarch64 binaries (#432) 11 месяцев назад
embed.go 6f108a4203 fix: do not extract embedded app on every execution (#488) 10 месяцев назад
frankenphp.c fe7e9e7c79 fix: crash when using apache_request_headers() (#536) 9 месяцев назад
frankenphp.go fe7e9e7c79 fix: crash when using apache_request_headers() (#536) 9 месяцев назад
frankenphp.h 49baf02035 feat: add go_apache_request_headers() 10 месяцев назад
frankenphp.png 625ab8906f docs: update logo 2 лет назад
frankenphp.stub.php 5a8e5f9518 feat: add apache_response_headers() function (#530) 9 месяцев назад
frankenphp_arginfo.h 5a8e5f9518 feat: add apache_response_headers() function (#530) 9 месяцев назад
frankenphp_test.go 6dee113a01 perf: add $_SERVER creation benchmark 9 месяцев назад
go.mod 9b09be22be chore: bump github.com/stretchr/testify from 1.8.1 to 1.8.4 11 месяцев назад
go.sum 9b09be22be chore: bump github.com/stretchr/testify from 1.8.1 to 1.8.4 11 месяцев назад
options.go fb63099a88 feat: allow passing env vars to workers (#210) 1 год назад
recorder_test.go 5012ac30cd chore: improve tests and add missing file (#13) 2 лет назад
release.sh 7c5f18fe3f ci: fix changelog generation 11 месяцев назад
reload_test.sh 517e086786 fix: random crashes when reloading (#394) 11 месяцев назад
request_options.go aa1d968dcf refactor: faster $_SERVER variables creation 1 год назад
smartpointer.go 5bda50cbd7 Fix memory leak (#442) 11 месяцев назад
static-builder.Dockerfile 36a6daa8ba docs: use tabs instead of spaces in Dockerfiles 9 месяцев назад
worker.go 7830aae549 Ensure we don't modify a shared env (#452) 10 месяцев назад
worker_test.go aa1d968dcf refactor: faster $_SERVER variables creation 1 год назад

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 -p 443:443/udp \
    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. 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.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