src/docs/markdown/quick-starts/caddyfile.md
Create a new text file named Caddyfile (no extension).
The first thing to type in a Caddyfile is your site's address:
localhost
If the HTTP and HTTPS ports (80 and 443, respectively) are privileged ports on your OS, you will either need to run with elevated privileges or use higher ports. To gain permission, run as root with sudo -E or use sudo setcap cap_net_bind_service=+ep $(which caddy). Alternatively, to use higher ports, just change the address to something like localhost:2080 and change the HTTP port using the http_port Caddyfile option.
Then hit enter and type what you want it to do, so it looks like this:
localhost
respond "Hello, world!"
Save this and run Caddy from the same folder that contains your Caddyfile:
<pre><code class="cmd bash">caddy start</code></pre>You will probably be asked for your password, because Caddy serves all sites -- even local ones -- over HTTPS by default. (The password prompt should only happen the first time!)
<aside class="tip">For local HTTPS, Caddy automatically generates certificates and unique private keys for you. The root certificate is added to your system's trust store, which is why the password prompt is necessary. It allows you to develop locally over HTTPS without certificate errors.
</aside>(If you get permission errors, you may need to run with elevated privileges or choose a port higher than 1023.)
Either open your browser to localhost or curl it:
You can define multiple sites in a Caddyfile by wrapping them in curly braces { }. Change your Caddyfile to be:
localhost {
respond "Hello, world!"
}
localhost:2016 {
respond "Goodbye, world!"
}
You can give Caddy the updated configuration two ways, either with the API directly:
<pre><code class="cmd bash">curl localhost:2019/load \ -H "Content-Type: text/caddyfile" \ --data-binary @Caddyfile </code></pre>or with the reload command, which does the same API request for you:
<pre><code class="cmd bash">caddy reload</code></pre>Try out your new "goodbye" endpoint in your browser or with curl to make sure it works:
When you are done with Caddy, make sure to stop it:
<pre><code class="cmd bash">caddy stop</code></pre>