Chapter 12. Configuring endpoints
Learn how to configure endpoints for Red Hat Advanced Cluster Security for Kubernetes (RHACS) by using a YAML configuration file.
You can use a YAML configuration file to configure exposed endpoints. You can use this configuration file to define one or more endpoints for Red Hat Advanced Cluster Security for Kubernetes and customize the TLS settings for each endpoint, or disable the TLS for specific endpoints. You can also define if client authentication is required, and which client certificates to accept.
12.1. Custom YAML configuration
Red Hat Advanced Cluster Security for Kubernetes uses the YAML configuration as a ConfigMap
, making configurations easier to change and manage.
When you use the custom YAML configuration file, you can configure the following for each endpoint:
-
The protocols to use, such as
HTTP
,gRPC
, or both. - Enable or disable TLS.
- Specify server certificates.
- Client Certificate Authorities (CA) to trust for client authentication.
-
Specify if client certificate authentication (
mTLS
) is required.
You can use the configuration file to specify endpoints either during the installation or on an existing instance of Red Hat Advanced Cluster Security for Kubernetes. However, if you expose any additional ports other than the default port 8443
, you must create network policies that allow traffic on those additional ports.
The following is a sample endpoints.yaml
configuration file for Red Hat Advanced Cluster Security for Kubernetes:
# Sample endpoints.yaml configuration for Central. # # # CAREFUL: If the following line is uncommented, do not expose the default endpoint on port 8443 by default. # # This will break normal operation. # disableDefault: true # if true, do not serve on :8443 1 endpoints: 2 # Serve plaintext HTTP only on port 8080 - listen: ":8080" 3 # Backend protocols, possible values are 'http' and 'grpc'. If unset or empty, assume both. protocols: 4 - http tls: 5 # Disable TLS. If this is not specified, assume TLS is enabled. disable: true 6 # Serve HTTP and gRPC for sensors only on port 8444 - listen: ":8444" 7 tls: 8 # Which TLS certificates to serve, possible values are 'service' (For service certificates that Red Hat Advanced Cluster Security for Kubernetes generates) # and 'default' (user-configured default TLS certificate). If unset or empty, assume both. serverCerts: 9 - default - service # Client authentication settings. clientAuth: 10 # Enforce TLS client authentication. If unset, do not enforce, only request certificates # opportunistically. required: true 11 # Which TLS client CAs to serve, possible values are 'service' (CA for service # certificates that Red Hat Advanced Cluster Security for Kubernetes generates) and 'user' (CAs for PKI auth providers). If unset or empty, assume both. certAuthorities: 12 # if not set, assume ["user", "service"] - service
- 1
- Use
true
to disable exposure on the default port number8443
. The default value isfalse
; changing it totrue
might break existing functionality. - 2
- A list of additional endpoints for exposing Central.
- 3 7
- The address and port number on which to listen. You must specify this value if you are using
endpoints
. You can use the formatport
,:port
, oraddress:port
to specify values. For example,-
8080
or:8080
- listen on port8080
on all interfaces. -
0.0.0.0:8080
- listen on port8080
on all IPv4 (not IPv6) interfaces. -
127.0.0.1:8080
- listen on port8080
on the local loopback device only.
-
- 4
- Protocols to use for the specified endpoint. Acceptable values are
http
andgrpc
. If you do not specify a value, Central listens to both HTTP and gRPC traffic on the specified port. If you want to expose an endpoint exclusively for the RHACS portal, usehttp
. However, you will not be able to use the endpoint for service-to-service communication or for theroxctl
CLI, because these clients require both gRPC and HTTP. Red Hat recommends that you do not specify a value of this key, to enable both HTTP and gRPC protocols for the endpoint. If you want to restrict an endpoint to Red Hat Advanced Cluster Security for Kubernetes services only, use the clientAuth option. - 5 8
- Use it to specify the TLS settings for the endpoint. If you do not specify a value, Red Hat Advanced Cluster Security for Kubernetes enables TLS with the default settings for all the following nested keys.
- 6
- Use
true
to disable TLS on the specified endpoint. The default value isfalse
. When you set it totrue
, you cannot specify values forserverCerts
andclientAuth
. - 9
- Specify a list of sources from which to configure server TLS certificates. The
serverCerts
list is order-dependent, it means that the first item in the list determines the certificate that Central uses by default, when there is no matching SNI (Server Name Indication). You can use this to specify multiple certificates and Central automatically selects the right certificate based on SNI. Acceptable values are:-
default
: use the already configured custom TLS certificate if it exists. -
service
: use the internal service certificate that Red Hat Advanced Cluster Security for Kubernetes generates.
-
- 10
- Use it to configure the behavior of the TLS-enabled endpoint’s client certificate authentication.
- 11
- Use
true
to only allow clients with a valid client certificate. The default value isfalse
. You can usetrue
in conjunction with a thecertAuthorities
setting ofservice
to only allow Red Hat Advanced Cluster Security for Kubernetes services to connect to this endpoint. - 12
- A list of CA to verify client certificates. The default value is
["service", "user"]
. ThecertAuthorities
list is order-independent, it means that the position of the items in this list does not matter. Also, setting it as empty list[]
disables client certificate authentication for the endpoint, which is different from leaving this value unset. Acceptable values are:-
service
: CA for service certificates that Red Hat Advanced Cluster Security for Kubernetes generates. -
user
: CAs configured by PKI authentication providers.
-
12.2. Configuring endpoints during a new installation
When you install Red Hat Advanced Cluster Security for Kubernetes by using the roxctl
CLI, it creates a folder named central-bundle
, which contains the necessary YAML manifests and scripts to deploy Central.
Procedure
-
After you generate the
central-bundle
, open the./central-bundle/central/02-endpoints-config.yaml
file. -
In this file, add your custom YAML configuration under the
data:
section of the keyendpoints.yaml
. Make sure that you maintain a 4 space indentation for the YAML configuration. - Continue the installation instructions as usual. Red Hat Advanced Cluster Security for Kubernetes uses the specified configuration.
If you expose any additional ports other than the default port 8443
, you must create network policies that allow traffic on those additional ports.
12.3. Configuring endpoints for an existing instance
You can configure endpoints for an existing instance of Red Hat Advanced Cluster Security for Kubernetes.
Procedure
Download the existing config map:
$ oc -n stackrox get cm/central-endpoints -o go-template='{{index .data "endpoints.yaml"}}' > <directory_path>/central_endpoints.yaml
-
In the downloaded
central_endpoints.yaml
file, specify your custom YAML configuration. Upload and apply the modified
central_endpoints.yaml
configuration file:$ oc -n stackrox create cm central-endpoints --from-file=endpoints.yaml=<directory-path>/central-endpoints.yaml -o yaml --dry-run | \ oc label -f - --local -o yaml app.kubernetes.io/name=stackrox | \ oc apply -f -
- Restart Central.
If you expose any additional ports other than the default port 8443
, you must create network policies that allow traffic on those additional ports.
12.3.1. Restarting the Central container
You can restart the Central container by killing the Central container or by deleting the Central pod.
Procedure
Run the following command to kill the Central container:
NoteYou must wait for at least 1 minute, until OpenShift Container Platform propagates your changes and restarts the Central container.
$ oc -n stackrox exec deploy/central -c central -- kill 1
Or, run the following command to delete the Central pod:
$ oc -n stackrox delete pod -lapp=central
12.4. Enabling traffic flow through custom ports
If you are exposing a port to another service running in the same cluster or to an ingress controller, you must only allow traffic from the services in your cluster or from the proxy of the ingress controller. Otherwise, if you are exposing a port by using a load balancer service, you might want to allow traffic from all sources, including external sources. Use the procedure listed in this section to allow traffic from all sources.
Procedure
Clone the
allow-ext-to-central
Kubernetes network policy:$ oc -n stackrox get networkpolicy.networking.k8s.io/allow-ext-to-central -o yaml > <directory_path>/allow-ext-to-central-custom-port.yaml
-
Use it as a reference to create your network policy, and in that policy, specify the port number you want to expose. Make sure to change the name of your network policy in the
metadata
section of the YAML file, so that it does not interfere with the built-inallow-ext-to-central
policy.