Replacing expired certificates

If any of your TLS certs are approaching expiry and you are not relying on an external certificate management solution such as cert-manager, you can follow Manually Rotating Control Plane TLS Credentials to update them without incurring downtime. However, if any of your certificates have already expired, your mesh is already in an invalid state and any measures to avoid downtime are not guaranteed to give good results. Instead, you need to replace the expired certificates with valid certificates.

Replacing only the issuer certificate

It might be the case that your issuer certificate is expired. If this it true running linkerd check --proxy will produce output similar to:

  1. linkerd-identity
  2. ----------------
  3. certificate config is valid
  4. trust roots are using supported crypto algorithm
  5. trust roots are within their validity period
  6. trust roots are valid for at least 60 days
  7. issuer cert is using supported crypto algorithm
  8. × issuer cert is within its validity period
  9. issuer certificate is not valid anymore. Expired on 2019-12-19T09:21:08Z
  10. see https://linkerd.io/2/checks/#l5d-identity-issuer-cert-is-time-valid for hints

In this situation, if you have installed Linkerd with a manually supplied trust root and you have its key, you can follow the instructions to rotate your identity issuer certificate to update your expired certificate.

Replacing the root and issuer certificates

If your root certificate is expired or you do not have its key, you need to replace both your root and issuer certificates at the same time. If your root has expired linkerd check will indicate that by outputting an error similar to:

  1. linkerd-identity
  2. ----------------
  3. certificate config is valid
  4. trust roots are using supported crypto algorithm
  5. × trust roots are within their validity period
  6. Invalid roots:
  7. * 272080721524060688352608293567629376512 identity.linkerd.cluster.local not valid anymore. Expired on 2019-12-19T10:05:31Z
  8. see https://linkerd.io/2/checks/#l5d-identity-roots-are-time-valid for hints

You can follow Generating your own mTLS root certificates to create new root and issuer certificates. Then use the linkerd upgrade command:

  1. linkerd upgrade \
  2. --identity-issuer-certificate-file=./issuer-new.crt \
  3. --identity-issuer-key-file=./issuer-new.key \
  4. --identity-trust-anchors-file=./ca-new.crt \
  5. --force \
  6. | kubectl apply -f -

Usually upgrade will prevent you from using an issuer certificate that will not work with the roots your meshed pods are using. At that point we do not need this check as we are updating both the root and issuer certs at the same time. Therefore we use the --force flag to ignore this error.

If you run linkerd check --proxy while pods are restarting after the trust bundle is updated, you will probably see warnings about pods not having the current trust bundle:

  1. linkerd-identity
  2. ----------------
  3. certificate config is valid
  4. trust roots are using supported crypto algorithm
  5. trust roots are within their validity period
  6. trust roots are valid for at least 60 days
  7. issuer cert is using supported crypto algorithm
  8. issuer cert is within its validity period
  9. issuer cert is valid for at least 60 days
  10. issuer cert is issued by the trust root
  11. linkerd-identity-data-plane
  12. ---------------------------
  13. data plane proxies certificate match CA
  14. Some pods do not have the current trust bundle and must be restarted:
  15. * linkerd/linkerd-controller-5b69fd4fcc-7skqb
  16. * linkerd/linkerd-destination-749df5c74-brchg
  17. * linkerd/linkerd-prometheus-74cb4f4b69-kqtss
  18. * linkerd/linkerd-proxy-injector-cbd5545bd-rblq5
  19. * linkerd/linkerd-sp-validator-6ff949649f-gjgfl
  20. * linkerd/linkerd-tap-7b5bb954b6-zl9w6
  21. * linkerd/linkerd-web-84c555f78-v7t44
  22. see https://linkerd.io/2/checks/#l5d-identity-data-plane-proxies-certs-match-ca for hints

These warnings will disappear as restarts complete. Once they do, you can use kubectl rollout restart to restart your meshed workloads to bring their configuration up to date. After that is done, linkerd check should run with no warnings or errors:

  1. linkerd-identity
  2. ----------------
  3. certificate config is valid
  4. trust roots are using supported crypto algorithm
  5. trust roots are within their validity period
  6. trust roots are valid for at least 60 days
  7. issuer cert is using supported crypto algorithm
  8. issuer cert is within its validity period
  9. issuer cert is valid for at least 60 days
  10. issuer cert is issued by the trust root
  11. linkerd-identity-data-plane
  12. ---------------------------
  13. data plane proxies certificate match CA