When trying to monitor an SSL enabled endpoint it seems like Heartbeat is setting the ServerName to the IP address instead of the hostname. For setups where the certificate is only signed with the domain (and not all IP addresses) this causes verification to fail. For setups where different certificates are served depending on hostname (Kubernetes nginx-ingress being a popular example) it means that Heartbeat tries to verify the invalid fake certificate that is returned when no matching domains are found.
Looking through the code and docs I can't find a way to have the verified ServerName be the domain instead of the resolved IP address.
- type: "tcp" name: "elastic.co" schedule: "@every 60s" hosts: ["tls://elastic.co:443"] ssl: enabled: true
x509: cannot validate certificate for 188.8.131.52 because it doesn't contain any IP SANs"
Here is the section which is setting the ServerName
host string which gets passed in actually ends up being the resolved IP address.
To confirm that this was the issue I hard coded it to "elastic.co" allows the certificate to be verified properly.
config.ServerName = "elastic.co"
I have reproduced this with the latest releases version (running from official Docker images) and also with the latest builds from the master branch.