Go to file
Rob Landers 08e99fc85f
Some checks are pending
Lint Code Base / Lint Code Base (push) Waiting to run
Sanitizers / ${{ matrix.sanitizer }} (asan) (push) Waiting to run
Sanitizers / ${{ matrix.sanitizer }} (msan) (push) Waiting to run
Tests / tests (8.2) (push) Waiting to run
Tests / tests (8.3) (push) Waiting to run
Tests / tests (8.4) (push) Waiting to run
fix(metrics): handle the case where the worker is already assigned to a thread (#1171)
2024-11-21 13:23:41 +01:00
.github
caddy fix(metrics): handle the case where the worker is already assigned to a thread (#1171) 2024-11-21 13:23:41 +01:00
docs docs: update instructions for xcaddy in Dockerfile (#1170) 2024-11-18 13:45:11 +01:00
internal fix: missing build tag for fastabs 2024-11-13 20:08:42 +01:00
testdata fix: don’t ignore empty request headers (#1182) 2024-11-21 12:58:01 +01:00
.dockerignore
.gitignore
.hadolint.yaml
.markdown-lint.yaml
alpine.Dockerfile
app_checksum.txt
app.tar
build-static.sh fix: ignore watcher dir creation error if the watcher exists (#1165) 2024-11-14 23:45:59 +01:00
cgi.go
CONTRIBUTING.md
dev-alpine.Dockerfile
dev.Dockerfile
docker-bake.hcl
Dockerfile
embed.go
frankenphp_arginfo.h
frankenphp_test.go fix: don’t ignore empty request headers (#1182) 2024-11-21 12:58:01 +01:00
frankenphp.c fix: don’t ignore empty request headers (#1182) 2024-11-21 12:58:01 +01:00
frankenphp.go
frankenphp.h remove opcache_reset (#1173) 2024-11-17 19:19:53 +01:00
frankenphp.png
frankenphp.stub.php
go.mod
go.sum
install.sh
LICENSE
metrics_test.go
metrics.go
options.go
php_thread_test.go
php_thread.go fix(metrics): handle the case where the worker is already assigned to a thread (#1171) 2024-11-21 13:23:41 +01:00
README.md docs: simplify docker run command (#1168) 2024-11-15 15:21:03 +01:00
recorder_test.go
release.sh
reload_test.sh
request_options.go
SECURITY.md
static-builder.Dockerfile
watcher_test.go
worker_test.go
worker.go fix(metrics): handle the case where the worker is already assigned to a thread (#1171) 2024-11-21 13:23:41 +01:00

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.3 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