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

Kévin Dunglas c25c269ca7 lint 6 месяцев назад
.github 7aaea72f14 ci: fix linter 1 месяц назад
caddy c3031ea07f chore: prepare release 1.4.0 2 недель назад
docs c25c269ca7 lint 2 недель назад
internal 0328d0600e fix: missing build tag for fastabs 2 месяцев назад
testdata 2b7b3d1e4b perf: put all $_SERVER vars into one function call. (#1303) 2 недель назад
.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 a3e5af523c docs: update CONTRIBUTING.md (#1270) 1 месяц назад
Dockerfile 69c43ee43d chore: use upstream e-dant/watcher headers and build system (#1119) 2 месяцев назад
LICENSE f8bdd640cf docs: add license (#24) 2 лет назад
README.md af99959880 docs: X-Sendfile/X-Accel-Redirect 2 недель назад
SECURITY.md 17e57287eb docs: fix link in SECURITY.md (#1111) 3 месяцев назад
alpine.Dockerfile 69c43ee43d chore: use upstream e-dant/watcher headers and build system (#1119) 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) 2 месяцев назад
backoff_test.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 2 месяцев назад
build-static.sh 5b86f2c554 ci: fix build-static.sh CS 2 недель назад
cgi.go 2b7b3d1e4b perf: put all $_SERVER vars into one function call. (#1303) 2 недель назад
dev-alpine.Dockerfile 8a199bb4d7 chore: remove useless EDANT_WATCHER_VERSION Docker ARG 1 месяц назад
dev.Dockerfile 8a199bb4d7 chore: remove useless EDANT_WATCHER_VERSION Docker ARG 1 месяц назад
docker-bake.hcl 8a199bb4d7 chore: remove useless EDANT_WATCHER_VERSION Docker ARG 1 месяц назад
embed.go d53f909d20 chore: various cleanups 3 месяцев назад
env.go 1e279bc348 refactor: simplify exponential backoff and refactor env (#1185) 2 месяцев назад
frankenphp.c 2b7b3d1e4b perf: put all $_SERVER vars into one function call. (#1303) 2 недель назад
frankenphp.go 479ba0a063 fix: log error if FrankenPHP is not properly started (#1314) 2 недель назад
frankenphp.h 2b7b3d1e4b perf: put all $_SERVER vars into one function call. (#1303) 2 недель назад
frankenphp.png 625ab8906f docs: update logo 2 лет назад
frankenphp.stub.php ea5e19ff4b fix: getallheaders() must return request headers (#772) 8 месяцев назад
frankenphp_arginfo.h f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
frankenphp_test.go 8cf6616ed6 fix: SIGSEGV when an env var is empty (#1271) 1 месяц назад
go.mod 19344a0dfe chore: bump deps 2 недель назад
go.sum 19344a0dfe chore: bump deps 2 недель назад
install.sh cda74730ae fix: term capability code may not be available 3 месяцев назад
metrics.go 843d199469 perf: cache computations in WithRequestDocumentRoot (#1154) 2 месяцев назад
metrics_test.go aa585f7da0 handle worker failures gracefully (#1038) 3 месяцев назад
options.go 8d9b6e755b feat: restart workers when on source changes (#1013) 3 месяцев назад
phpmainthread.go 92f95342d1 fix: SIGSEGV with env vars (#1278) 1 месяц назад
phpmainthread_test.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
phpthread.go 92f95342d1 fix: SIGSEGV with env vars (#1278) 1 месяц назад
recorder_test.go 75dab8f33d chore: bump deps and misc improvements (#1135) 2 месяцев назад
release.sh 0fc6ccc5ce ci: automatically create the Brew formula PR on release 1 месяц назад
reload_test.sh 6c708be99d ci: upgrade to super-linter 6 (#952) 5 месяцев назад
request_options.go 2b7b3d1e4b perf: put all $_SERVER vars into one function call. (#1303) 2 недель назад
state.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
state_test.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
static-builder.Dockerfile d276032e20 feat(static): add custom Caddy modules support (#1210) 1 месяц назад
thread-inactive.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
thread-regular.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
thread-worker.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
watcher_test.go afedeb9d58 refactor: use build tags to disable, instead of to enable a feature (#1113) 3 месяцев назад
worker.go f592e0f47b refactor: decouple worker threads from non-worker threads (#1137) 1 месяц назад
worker_test.go 75dab8f33d chore: bump deps and misc improvements (#1135) 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

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