Skip to content

Latest commit

 

History

History
45 lines (35 loc) · 1.92 KB

lets_encrypt_prod_switch.md

File metadata and controls

45 lines (35 loc) · 1.92 KB

Switch from Let's Encrypt Staging to Production Environment

Let's Encrypt provides a staging platform to test against and this is the environment the package will request certificates from. Once you have verified the staging certificates have been issued correctly, the user must switch to requesting certificates from Let's Encrypt's production environment to receive trusted certificates.

The package automatically installs a cluster issuer for both the staging and production environments is cluster-issuer.yaml, switching the issuers involves switching the cert-manager annotations in config.yaml.

In config.yaml, you will find the following code block:

ingress:
  enabled: true
  annotations:
    kubernetes.io/tls-acme: "true"
    kubernetes.io/ingress.class: nginx
    cert-manager.io/cluster-issuer: "letsencrypt-staging"
    https:
      enabled: true
      type: nginx
  host:
    - <host-name>
  tls:
    - secretName: <secret-name>
      hosts:
        - <host-name>

🚨 This code block will actually appear twice in config.yaml. Once for the binder ingress, and again for the hub ingress. 🚨

Update the cert-manager.io/cluster-issuer annotation from letsencrypt-staging to letsencrypt-prod.

🚨 Remember to perform this change in both places where the annotation appears! 🚨

Now upgrade your cluster using upgrade.sh or the helm command:

helm upgrade BINDERHUB_NAME jupyterhub/binderhub \
  --version=BINDERHUB_VERSION \
  -f /path/to/secret.yaml \
  -f /path/to/config.yaml \
  --wait

Congratulations, you should now be issued trusted certificates from the Let's Encrypt production environment!