Files
frankenphp/docs/ru
Marc bbbfdb31b5 ci: build .rpm and .deb packages (#1497)
* add ./create-rpm.sh file to build a "frankenphp" rpm package

* also build a deb package

* renamed to build-packages

* linter...

* add depends

* linter again?

* linter number 3

* linter number 4

* set default locations for ini file, conf files and extensions

* set unified path for modules that should be ok on all dists

* add default content into "package" folder

* make file executable

* worker is in public folder

* what on earth did I do x)

* use same FRANKENPHP_VERSION and make sure to let pr's run the rpm generation too (version 0.0.0) to see issues

* install ruby, fpm and rpm-build

* move to after changing base urls because it would fail with packages not found

* ruby 3 build needs gcc 10

* rpm-build is necessary too...

* and I forgot to link the package folder

* create directories if they don't exist

* copy out all frankenphp* files?

* lint fix

* only copy frankenphp-* files

* only copy frankenphp-* files

* the .deb file is name frankenphp_1.5.0... - create output folder instead and upload all things inside that
will simplify things when later adding xdebug.so and ffi.so

* update the last two steps to use the gh-output directory

* add post install script to set frankenphp able to bind to port 80 for non-root users

* dnf over yum, I think the yum alias was removed in RH 9.5

* newlines

* newlines

* add text what missing libcap means

* copy php.ini-production from php-src, linter, update ruby version

* move Caddyfile to /etc/frankenphp/Caddyfile

* linter

* fix a copy and paste error

* better describe fallback to 0.0.0

* linter

* copy installation scripts from official caddy packages, change user to frankenphp too

* bombombom

* make files executable

* tabs

* linter

* linter again

* use empty directory for three different destinations instead of keeping three empty local directories

* caddy says the file is incorrectly formatted without these spaces

* remove wildcard matcher from root directive

* Apply suggestions from code review

commit suggested changes to preinstall/postinstall scripts

Co-authored-by: Kévin Dunglas <kevin@dunglas.fr>

* Update dev.Dockerfile

Co-authored-by: Kévin Dunglas <kevin@dunglas.fr>

* remove misleading comment

* update documentation for paths

* update documentation for paths some more

* fix musl opcache-jit issue

* markdown linter

* the damn tab

* Apply suggestions from code review

Co-authored-by: Kévin Dunglas <kevin@dunglas.fr>

* drop dev.Dockerfile php location from config.md

* add php config note to CONTRIBUTING.md

* dashes instead of asterisks in chinese docs

* fix package building

* create frankenphp user in case it doesn't exist for deb packages

* create users if they don't exist, delete them again if they didn't exist

* satisfy linter

* create the user with the same commands as the postinst/preinstall scripts

* Removes toolchain requirements.

* trigger

* Removes explicit calls to go get

* trigger

* setcap by default

* simplify example project

* bring page more in line with the caddy / apache / nginx default page

* update to html 5

* oopsies

* revert style to original

* remove https:// (caddy uses http:// on RHEL, :80 on Debian)

---------

Co-authored-by: Kévin Dunglas <kevin@dunglas.fr>
Co-authored-by: Alliballibaba <alliballibaba@gmail.com>
2025-05-14 07:33:05 +02:00
..
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00
2025-02-17 23:46:11 +01:00
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00
2025-04-23 01:02:44 +02:00

FrankenPHP: Современный сервер приложений для PHP

FrankenPHP

FrankenPHP — это современный сервер приложений для PHP, построенный на базе веб-сервера Caddy.

FrankenPHP добавляет новые возможности вашим PHP-приложениям благодаря следующим функциям: Early Hints, Worker режим, Real-time режим, автоматическая поддержка HTTPS, HTTP/2 и HTTP/3.

FrankenPHP совместим с любыми PHP-приложениями и значительно ускоряет ваши проекты на Laravel и Symfony благодаря их официальной поддержке в worker режиме.

FrankenPHP также может использоваться как автономная Go-библиотека для встраивания PHP в любое приложение с использованием net/http.

Узнайте больше на сайте frankenphp.dev или из этой презентации:

Slides

Начало работы

Docker

docker run -v .:/app/public \
    -p 80:80 -p 443:443 -p 443:443/udp \
    dunglas/frankenphp

Перейдите по адресу https://localhost и наслаждайтесь!

Tip

Не используйте https://127.0.0.1. Используйте https://localhost и настройте самоподписанный сертификат.
Чтобы изменить используемый домен, настройте переменную окружения SERVER_NAME.

Автономный бинарный файл

Если вы предпочитаете не использовать Docker, мы предоставляем автономный бинарный файл FrankenPHP для Linux и macOS, включающий PHP 8.4 и большинство популярных PHP-расширений.

Для Windows используйте WSL для запуска FrankenPHP.

Скачать FrankenPHP или выполните следующую команду для автоматической установки подходящей версии:

curl https://frankenphp.dev/install.sh | sh
mv frankenphp /usr/local/bin/

Для запуска содержимого текущей директории выполните:

frankenphp php-server

Вы также можете запускать CLI-скрипты:

frankenphp php-cli /path/to/your/script.php

Документация

Примеры и шаблоны