FrankenPHP is a modern application server for PHP that enhances the performance and capabilities of PHP applications. It is built on top of another server called Caddy web server, which helps developers to run PHP applications efficiently without the need for traditional web servers like Apache or Nginx.
FrankenPHP can make your PHP applications run faster by keeping your application in memory after the first load, so it doesn’t have to start from scratch with every request, which can lead to significant speed improvements.
With FrankenPHP, you don’t need to set up separate processes like PHP-FPM (FastCGI Process Manager) and a web server like Nginx or Apache. Everything runs in one place, making it easier to manage.
This guide walks you through the process of installing FrankenPHP on Ubuntu 24.04 in simple steps.
Step 1: Install PHP in Ubuntu 24.04
First, start by updating your system packages to ensure you have the latest software.
sudo apt update sudo apt upgrade -y
Next, you need to install some essential packages, including PHP and other required libraries.
sudo apt install zip unzip curl -y
Once the required dependencies are installed, you can install PHP 8.4 from Ondrej’s PPA, which provides the latest versions of PHP.
sudo add-apt-repository ppa:ondrej/php -y sudo apt update sudo apt install php8.4 php8.4-cli php8.4-fpm php8.4-{bz2,curl,mbstring,intl,xml} -y php -v
Step 2: Install FrankenPHP in Ubuntu 24.04
Now that PHP is installed, you can proceed with installing FrankenPHP using the following curl command.
curl https://frankenphp.dev/install.sh | sh sudo mv frankenphp /usr/local/bin/
Step 3: Running Your PHP Application
To serve your PHP application using FrankenPHP, create a directory and a simple php script for your web application.
mkdir -p ~/my-app && cd ~/my-app echo '<?php echo "Hello, FrankenPHP!"; ?>' > index.php
To serve the content of the current directory, run:
sudo frankenphp php-server
Open your browser and navigate to the following address to see the message “Hello, FrankenPHP!“.
http://localhost/ Or http://ip-address/
Step 4: Setting Up Nginx as a Reverse Proxy
Using a reverse proxy like Nginx improves request handling, adds an additional security layer, and simplifies SSL/TLS configuration.
sudo apt install -y nginx
Create a new configuration file.
sudo nano /etc/nginx/sites-available/frankenphp
Add the following configuration:
server { listen 80; server_name yourdomain.com www.yourdomain.com; location / { proxy_pass http://127.0.0.1:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } }
Replace yourdomain.com
with your actual domain name.
Next, enable the configuration and reload nginx.
sudo ln -s /etc/nginx/sites-available/frankenphp /etc/nginx/sites-enabled/ sudo nginx -t sudo systemctl reload nginx
Step 5: Configure SSL/TLS for Secure Connections
To ensure FrankenPHP performs efficiently and securely in a production environment, you need to install Certbot, which is a popular tool for obtaining and renewing free SSL certificates from Let’s Encrypt.
sudo apt install -y certbot sudo apt install -y python3-certbot-nginx sudo certbot --nginx -d yourdomain.com -d www.yourdomain.com sudo certbot renew --dry-run
Conclusion
FrankenPHP is now installed and running on your Ubuntu 24.04 system. By following these steps, you’ve set up a high-performance PHP runtime suitable for modern web applications.
For advanced configurations, refer to the FrankenPHP documentation.
One quick question: is FrankenPHP ready for production?
@pai,
FrankenPHP is still in active development, and while it shows promising features, it’s always best to thoroughly test it in a staging environment before using it in production.