pfSense running ACME and HAProxy can be a great combination to protect your network, allow for a publicly trusted certificate on your website, and avoid directly exposing HTTP and HTTPS connections to your web servers. The only exception is what happens when ACME doesn’t automatically renew your certificate. This might be caused by HAProxy not allowing ACME to serve the verification page to Let’s Encrypt to verify that you own the domain or sub-domain. While below isn’t a permanent fix to the problem, it can help you get back up and running without the untrusted page warnings your users get when the certificate does expire.


  1. Login to your pfSense Admin interface
  2. Go to Services > HAProxy
  3. Once the page is loaded, stop the HAProxy service
  4. Go to Services > Acme
  5. Go to the Certificates tab, go ahead and attempt to do a Issue/Renew
  6. As long as the verification method is Standalone HTTP Server or Webroot, then the renewal should work
  7. Once done with the renewals, go to General settings and you can try to check the Enable Acme client renewal job…
  8. Go back to Services > HAProxy
  9. Make sure to start the HAProxy service
  10. You should be good to go with a renewed certificate
  11. Consider switching from a local HTTP verification to a DNS based verification if your DNS provider supports it