Agent Service Config
The Agent Service Config object is an essential component of the Assisted Service addon included in MCE/ACM, responsible for Baremetal cluster deployment. When the addon is enabled, you must deploy an operand (CRD) named AgentServiceConfig
to configure it.
Agent Service Config Objects
You can find the CRD described here. In this context, we will focus on the main aspects to ensure its functionality in disconnected environments.
In addition to configuring the Agent Service Config, to ensure that Multicluster Engine functions properly in a disconnected environment, we need to include some additional ConfigMaps.
Custom Registries Configuration
This ConfigMap contains the disconnected details necessary to customize the deployment.
---
apiVersion: v1
kind: ConfigMap
metadata:
name: custom-registries
namespace: multicluster-engine
labels:
app: assisted-service
data:
ca-bundle.crt: |
-----BEGIN CERTIFICATE-----
-----END CERTIFICATE-----
registries.conf: |
unqualified-search-registries = ["registry.access.redhat.com", "docker.io"]
[[registry]]
prefix = ""
location = "registry.redhat.io/openshift4"
mirror-by-digest-only = true
[[registry.mirror]]
location = "registry.hypershiftbm.lab:5000/openshift4"
[[registry]]
prefix = ""
location = "registry.redhat.io/rhacm2"
mirror-by-digest-only = true
...
...
This object includes two fields:
- Custom CAs: This field contains the Certificate Authorities (CAs) that will be loaded into the various processes of the deployment.
- Registries: The
Registries.conf
field contains information about images and namespaces that need to be consumed from a mirror registry instead of the original source registry.
Assisted Service Customization
The Assisted Service Customization ConfigMap is consumed by the Assisted Service operator and contains variables that modify the behavior of the controllers.
---
apiVersion: v1
kind: ConfigMap
metadata:
name: assisted-service-config
namespace: multicluster-engine
data:
ALLOW_CONVERGED_FLOW: "false"
You can find documentation on how to customize the operator here.
Assisted Service Config
The Assisted Service Config object includes the necessary information to ensure the correct functioning of the operator.
---
apiVersion: agent-install.openshift.io/v1beta1
kind: AgentServiceConfig
metadata:
annotations:
unsupported.agent-install.openshift.io/assisted-service-configmap: assisted-service-config
name: agent
namespace: multicluster-engine
spec:
mirrorRegistryRef:
name: custom-registries
databaseStorage:
storageClassName: lvms-vg1
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 10Gi
filesystemStorage:
storageClassName: lvms-vg1
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 20Gi
osImages:
- cpuArchitecture: x86_64
openshiftVersion: "4.14"
rootFSUrl: http://registry.hypershiftbm.lab:8080/images/rhcos-414.92.202308281054-0-live-rootfs.x86_64.img
url: http://registry.hypershiftbm.lab:8080/images/rhcos-414.92.202308281054-0-live.x86_64.iso
version: 414.92.202308281054-0
If your mirror registry doesn't require authentication in your pull secret, see this document on how to add it to the unauthenticated list in the AgentServiceConfig CR.
In this section, we will emphasize the important aspects:
- The
metadata.annotations["unsupported.agent-install.openshift.io/assisted-service-configmap"]
Annotation references the ConfigMap name to be consumed by the operator for customizing behavior. - The
spec.mirrorRegistryRef.name
points to the ConfigMap containing disconnected registry information to be consumed by the Assisted Service Operator. This ConfigMap injects these resources during the deployment process. - The
spec.osImages
field contains different versions available for deployment by this operator. These fields are mandatory.
Let's fill in this section for the 4.14 dev preview ec4 version (sample):
Assuming you've already downloaded the RootFS and LiveIso files:
- cpuArchitecture: x86_64
openshiftVersion: "4.14"
rootFSUrl: http://registry.hypershiftbm.lab:8080/images/rhcos-414.92.202309101331-0-live-rootfs.x86_64.img
url: http://registry.hypershiftbm.lab:8080/images/rhcos-414.92.202309101331-0-live.x86_64.iso
version: 414.92.202307250657-0
Deployment
To deploy all these objects, simply concatenate them into a single file and apply them to the Management Cluster.
oc apply -f agentServiceConfig.yaml
This will trigger 2 pods
assisted-image-service-0 1/1 Running 2 11d
assisted-service-668b49548-9m7xw 2/2 Running 5 11d
Note
The Assisted Image Service
pod is responsible for creating the RHCOS Boot Image template, which will be customized for each cluster you deploy.
The Assisted Service
refers to the operator.