I've been using caddy as a web server and reverse proxy for a few years and am generally happy with it, though the process of installing it is never simple. As I write this, I am moving my web server/rprox to a new box, so I'm going to document it for the next time I do it. I'll probably be using caddy2 at that point, and none of this will be relevant.
Stuff Needed
I keep a ~/caddyMess directory with:
- a caddy binary
- an example Caddyfile
This is enough to get started. I don't move certs or logs.
Go
- Put the binary in /usr/local/bin/caddy
sudo cp caddy /usr/local/bin/caddy
- Let the binary bind privileged ports
sudo setcap 'cap_net_bind_service=+ep' /usr/local/bin/caddy
- Set up the user, group, and directories
sudo groupadd -g 33 www-data sudo useradd \ -g www-data --no-user-group \ --home-dir /var/www --no-create-home \ --shell /usr/sbin/nologin \ --system --uid 33 www-data sudo mkdir /etc/caddy sudo chown -R root:root /etc/caddy sudo mkdir /etc/ssl/caddy sudo chown -R root:www-data /etc/ssl/caddy sudo chmod 0770 /etc/ssl/caddy
- Install the service file
sudo cp caddy.service /etc/systemd/system/ sudo chown root:root /etc/systemd/system/caddy.service sudo chmod 644 /etc/systemd/system/caddy.service sudo systemctl daemon-reload
- Install the caddyfile (edit as needed obvs)
sudo cp Caddyfile /etc/caddy/Caddyfile
- Start and enable the service
sudo systemctl --now enable caddy ; sudo systemctl status caddy