Configuring a custom PKI

    You can leverage the Proxy API to add cluster-wide trusted CA certificates. You must do this either during installation or at runtime.

    • During installation, configure the cluster-wide proxy. You must define your privately signed CA certificates in the file’s additionalTrustBundle setting.

      The installation program generates a ConfigMap that is named user-ca-bundle that contains the additional CA certificates you defined. The Cluster Network Operator then creates a trusted-ca-bundle ConfigMap that merges these CA certificates with the Fedora CoreOS (FCOS) trust bundle; this ConfigMap is referenced in the Proxy object’s trustedCA field.

    • At runtime, (part of cluster’s proxy enablement workflow). This involves creating a ConfigMap that contains the privately signed CA certificates that should be trusted by the cluster, and then modifying the proxy resource with the trustedCA referencing the privately signed certificates’ ConfigMap.

    Production environments can deny direct access to the internet and instead have an HTTP or HTTPS proxy available. You can configure a new OKD cluster to use a proxy by configuring the proxy settings in the install-config.yaml file.

    Prerequisites

    • You have an existing install-config.yaml file.

    • You reviewed the sites that your cluster requires access to and determined whether any of them need to bypass the proxy. By default, all cluster egress traffic is proxied, including calls to hosting cloud provider APIs. You added sites to the Proxy object’s spec.noProxy field to bypass the proxy if necessary.

      The Proxy object status.noProxy field is populated with the values of the networking.machineNetwork[].cidr, networking.clusterNetwork[].cidr, and networking.serviceNetwork[] fields from your installation configuration.

      For installations on Amazon Web Services (AWS), Google Cloud Platform (GCP), Microsoft Azure, and Red Hat OpenStack Platform (RHOSP), the Proxy object status.noProxy field is also populated with the instance metadata endpoint (169.254.169.254).

    • If your cluster is on AWS, you added the ec2.<region>.amazonaws.com, elasticloadbalancing.<region>.amazonaws.com, and s3.<region>.amazonaws.com endpoints to your VPC endpoint. These endpoints are required to complete requests from the nodes to the AWS EC2 API. Because the proxy works on the container level, not the node level, you must route these requests to the AWS EC2 API through the AWS private network. Adding the public IP address of the EC2 API to your allowlist in your proxy server is not sufficient.

    1. Edit your install-config.yaml file and add the proxy settings. For example:

      1A proxy URL to use for creating HTTP connections outside the cluster. The URL scheme must be http. If you use an MITM transparent proxy network that does not require additional proxy configuration but requires additional CAs, you must not specify an httpProxy value.
      2A proxy URL to use for creating HTTPS connections outside the cluster. If you use an MITM transparent proxy network that does not require additional proxy configuration but requires additional CAs, you must not specify an httpsProxy value.
      3A comma-separated list of destination domain names, IP addresses, or other network CIDRs to exclude from proxying. Preface a domain with . to match subdomains only. For example, .y.com matches x.y.com, but not y.com. Use * to bypass the proxy for all destinations.
      4If provided, the installation program generates a config map that is named user-ca-bundle in the openshift-config namespace that contains one or more additional CA certificates that are required for proxying HTTPS connections. The Cluster Network Operator then creates a trusted-ca-bundle config map that merges these contents with the Fedora CoreOS (FCOS) trust bundle, and this config map is referenced in the field of the Proxy object. The additionalTrustBundle field is required unless the proxy’s identity certificate is signed by an authority from the FCOS trust bundle. If you use an MITM transparent proxy network that does not require additional proxy configuration but requires additional CAs, you must provide the MITM CA certificate.
    2. Save the file and reference it when installing OKD.

    The installation program creates a cluster-wide proxy that is named cluster that uses the proxy settings in the provided install-config.yaml file. If no proxy settings are provided, a cluster Proxy object is still created, but it will have a nil spec.

    Only the Proxy object named cluster is supported, and no additional proxies can be created.

    The Proxy object is used to manage the cluster-wide egress proxy. When a cluster is installed or upgraded without the proxy configured, a Proxy object is still generated but it will have a nil spec. For example:

    1. apiVersion: config.openshift.io/v1
    2. kind: Proxy
    3. metadata:
    4. name: cluster
    5. spec:
    6. trustedCA:
    7. name: ""
    8. status:

    A cluster administrator can configure the proxy for OKD by modifying this cluster Proxy object.

    Only the Proxy object named cluster is supported, and no additional proxies can be created.

    Prerequisites

    • Cluster administrator permissions

    • OKD oc CLI tool installed

    Procedure

    1. Use the oc edit command to modify the Proxy object:

    2. Configure the necessary fields for the proxy:

      1. apiVersion: config.openshift.io/v1
      2. kind: Proxy
      3. metadata:
      4. name: cluster
      5. spec:
      6. httpProxy: http://<username>:<pswd>@<ip>:<port> (1)
      7. httpsProxy: http://<username>:<pswd>@<ip>:<port> (2)
      8. noProxy: example.com (3)
      9. readinessEndpoints:
      10. - http://www.google.com (4)
      11. - https://www.google.com
      12. name: user-ca-bundle (5)
    3. Save the file to apply the changes.

    The URL scheme must be http. The https scheme is currently not supported.

    Once your custom CA certificate is added to the cluster via ConfigMap, the Cluster Network Operator merges the user-provided and system CA certificates into a single bundle and injects the merged bundle into the Operator requesting the trust bundle injection.

    Operators request this injection by creating an empty ConfigMap with the following label:

    The Operator mounts this ConfigMap into the container’s local trust store.

    Adding a trusted CA certificate is only needed if the certificate is not included in the Fedora CoreOS (FCOS) trust bundle.

    Certificate injection is not limited to Operators. The Cluster Network Operator injects certificates across any namespace when an empty ConfigMap is created with the config.openshift.io/inject-trusted-cabundle=true label.

    1. apiVersion: apps/v1
    2. metadata:
    3. name: my-example-custom-ca-deployment
    4. namespace: my-example-custom-ca-ns
    5. spec:
    6. ...
    7. spec:
    8. ...
    9. containers:
    10. - name: my-container-that-needs-custom-ca
    11. volumeMounts:
    12. - name: trusted-ca
    13. mountPath: /etc/pki/ca-trust/extracted/pem
    14. readOnly: true
    15. volumes:
    16. - name: trusted-ca
    17. configMap:
    18. name: trusted-ca
    19. items:
    20. - key: ca-bundle.crt (1)
    21. path: tls-ca-bundle.pem (2)