

Is there a way I can get Let’s Encrypt to dole out a wildcard certificate
Yep. Just specify the domains yourdomain.com
and *.yourdomain.com
in the certbot request. Wildcard domains require the DNS-based challenge, but you’ve said you’re already good there. You don’t technically need the apex domain (yourdomain.com
) but I always add it since I do have services running there.
Any subdomains under the wildcard can use internal DNS or internal IPs on the public DNS (I do the former, but the latter works too).
I used to run an internal CA, and it wasn’t too hard to setup a CA and distribute my root cert. Except on mobile devices. On Android it was easy, but there was a persistent warning that my network traffic could be intercepted (which is true when there’s a custom root cert installed), but it since it was my cert, it got annoying seeing that all the time. Not sure if Apple devices can even do that, but regardless, it wasn’t practical for friends who wanted to use my self-hosted services to install a custom cert when they were over.
I have a single Nginx setup which is the frontend for all my web services. So I only need to deploy it there (and to its HA partner). My renewal script just
scp
’s it to the secondary and does annginx -s reload
on both.I do generate separate certs/keys for my non-web servers, but there’s only two of those.
You could also, if you wanted, just generate one cert and distribute it and its key to everything with a script or other automation tool (Ansible is what I used to use).