Setup Caddy on Ubuntu to work with PHP

Introduction

Caddy is a very promising webserver (written in Go) that allows HTTP/2. It is a full-featured web server that includes the ability to enable HTTPS automatically. This allows for web server creation with high flexibility and low overhead. Creator claims caddy to be designed for human and it is probably the only of its kind. The purpose of Caddy is to streamline an authentic web development, deployment, and hosting workflow so that anyone can host their own web sites without requiring special technical knowledge. If you are designer, blogger and developer prefer to have a simple yet webserver with HTTP/2 support by default, Caddy is definitely worth checking out.

Installation

You can run auto Caddy installation instead of download the file archive by running the following code in your terminal.

curl https://getcaddy.com | bash

The command above will install caddy to /usr/local/bin/caddy

System Setup

Allow caddy to use standard internal network post

sudo setcap cap_net_bind_service=+ep /usr/local/bin/caddy

PHP Setup

Install PHP-fpm by running the following command:

PHP5

sudo apt-get install php5-fpm php5-cli curl

PHP7

sudo apt-get install php7.0-fpm php7.0-cli curl
Site Configuration

Create web server root directory to store all of your webpages like .php, .html, ect.

sudo mkdir -p /opt/www
sudo chown -R www-data:www-data

Caddy Configuration

Create the directory we’ll be using to store Caddyfile and ssl, give user perms to write to it:

sudo mkdir /etc/caddy
sudo chown -R root:www-data /etc/caddy
sudo mkdir /etc/ssl/caddy
sudo chown -R www-data:root /etc/ssl/caddy
chmod 0770 /etc/ssl/caddy

Create Caddyfile which the main configuration file of Caddy.

sudo vim /etc/caddy/Caddyfile

Put the following code:

yourdomain.com {
root /opt/www
tls your@yourdomain.com.com
}
  • root /opt/www : point the web server root directory to /opt/www
  • tls your@yourdomain.com : configures HTTPS connections

To configure php settings with more granularity, you can use the fastcgi directive.

fastcgi / /var/run/php/php7.0-fpm.sock {
    ext     .php
    split    .php
    index    index.php
}
  • ext : if requested file has the .php extension use fastcgi proxy
  • split : To store anything after .php in the PATH_INFO CGI variable
  • index: To check for index.php if no file is specified in the URL

Note:
Use the following socket path for PHP5

/var/run/php5-fpm.sock

Server Configuration

Now we create a systemd configuration file /etc/systemd/system/caddy.service, which looks like this:

[Unit]
Description=Caddy HTTP/2 web server
Documentation=https://caddyserver.com/docs
After=network-online.target
Wants=network-online.target systemd-networkd-wait-online.service

[Service]
Restart=on-failure

User=www-data
Group=www-data

Environment=HOME=/etc/ssl/caddy

ExecStart=/usr/local/bin/caddy -log stdout -agree=true -conf=/etc/caddy/Caddyfile -root=/var/tmp
ExecReload=/bin/kill -USR1 $MAINPID

LimitNOFILE=4096
LimitNPROC=64

PrivateTmp=true
PrivateDevices=true
ProtectHome=true
ProtectSystem=full
ReadWriteDirectories=/etc/ssl/caddy

CapabilityBoundingSet=CAP_NET_BIND_SERVICE
AmbientCapabilities=CAP_NET_BIND_SERVICE
NoNewPrivileges=true

[Install]
WantedBy=multi-user.target

Testing PHP

With a Caddy web server configured and the PHP packages installed, we should be able to verify that PHP is up and running. Begin by checking the installed version of PHP at the command line:

$ php -v
PHP 7.0.8-0ubuntu0.16.04.2 (cli) ( NTS )
Copyright (c) 1997-2016 The PHP Group
Zend Engine v3.0.0, Copyright (c) 1998-2016 Zend Technologies
    with Zend OPcache v7.0.8-0ubuntu0.16.04.2, Copyright (c) 1999-2016, by Zend Technologies

You can also create a test file in the web server root directory, which is /opt/www

Using Vim, create the file called into.php in the web server root directory

sudo vim /opt/www/tes.php

Paste the following code into tes.php

<?php
phpinfo();
?>

Exit and save tes.php from your editor. Now, load the following address in your browser:

https://yourdomain.com/tes.php

You should see PHP version and configuration info for PHP. Once you’ve double-checked this, it’s safest to to delete testing file.

sudo rm -r /opt/www/tes.php

CONCLUSION

Now, you have working Caddy web server with PHP feature.