Configuring a Broker UAI class consists of the following actions:
namespace
set to uas
default
set to false
volume_mounts
set to the list of customization volume-ids created abovepublic_ip
set to true
uai_compute_network
set to false
uai_creation_class
set to the class-id of the End-User UAI classThe basic contents of a Broker UAI Class is discussed in UAI Classes. Familiarity with that information is assumed in the example below.
Broker UAIs authenticate each user using SSH, and pass the SSH connection on to the selected or created End-User UAI for that user. An authentication source is required to authenticate users. For sites that use LDAP as a directory server for authentication, connecting Broker UAIs to LDAP is simply a matter of replicating the LDAP configuration used by other nodes or systems at the site (UANs can be a good source of this configuration) inside the Broker UAI. This section shows how to do that using volumes, which permits the standard Broker UAI image to be used out of the box and reconfigured at the site without direct modification.
While it would be possible to make the configuration available as files volume mounted from the host node of the Broker UAI, this is difficult to set up and maintain because it means that the configuration files must be present and synchronized across all UAI host nodes. A more practical approach to this is to install the configuration files in Kubernetes as secrets, and then mount them from Kubernetes directly. This ensures that no matter where a Broker UAI runs, it has access to the configuration.
This example uses Kubernetes secrets and assumes that the Broker UAIs run in the uas
Kubernetes namespace. If a different namespace is used, the creation of the ConfigMaps is different but the contents are the same.
Using a namespace other than uas
for Broker UAIs has implications beyond secrets and ConfigMaps; it is not recommended and is beyond the scope of this document.
Configure LDAP and determine which files need to be changed in the Broker UAI and what their contents should be.
In this example, the file is /etc/sssd/sssd.conf
and its contents are representative but sanitized. Substitute your own site specific contents:
[sssd]
config_file_version = 2
services = nss, pam
domains = My_DC
[nss]
filter_users = root
filter_groups = root
[pam]
[domain/My_DC]
ldap_search_base=dc=datacenter,dc=mydomain,dc=com
ldap_uri=ldap://10.1.1.5,ldap://10.1.2.5
id_provider = ldap
ldap_tls_reqcert = allow
ldap_schema = rfc2307
cache_credentials = True
entry_cache_timeout = 60
enumerate = False
Add the content from the previous step to a secret.
Create a file with the appropriate content.
ncn-m001-pit# cat <<EOF > sssd.conf
[sssd]
config_file_version = 2
services = nss, pam
domains = My_DC
[nss]
filter_users = root
filter_groups = root
[pam]
[domain/My_DC]
ldap_search_base=dc=datacenter,dc=mydomain,dc=com
ldap_uri=ldap://10.1.1.5,ldap://10.1.2.5
id_provider = ldap
ldap_tls_reqcert = allow
ldap_schema = rfc2307
cache_credentials = True
entry_cache_timeout = 60
enumerate = False
EOF
Make a secret from the file.
ncn-m001-pit# kubectl create secret generic -n uas broker-sssd-conf --from-file=sssd.conf
Make a volume for the secret in the UAS configuration.
ncn-m001-pit# cray uas admin config volumes create \
--mount-path /etc/sssd \
--volume-description \
'{"secret": {"secret_name": "broker-sssd-conf", "default_mode": 384}}' \
--volumename broker-sssd-config
Example output:
mount_path = "/etc/sssd"
volume_id = "1ec36af0-d5b6-4ad9-b3e8-755729765d76"
volumename = "broker-sssd-config"
[volume_description.secret]
default_mode = 384
secret_name = "broker-sssd-conf"
Two important things to notice here are:
/etc/sssd
not the file /etc/sssd/sssd.conf
because Kubernetes does not permit the replacement of an existing regular file with a volume but does allow overriding a directory384
is used here for the default mode of the file instead of 0600
, which would be easier to read, because JSON does not accept octal numbers in the leading zero formMake a volume to hold an empty and writable /etc/sssd/conf.d
in the Broker UAI:
ncn-m001# cray uas admin config volumes create --mount-path /etc/sssd/conf.d --volume-description '{"empty_dir": {"medium": "Memory"}}' --volumename sssd-conf-d --format yaml
Example output:
mount_path: /etc/sssd/conf.d
volume_description:
empty_dir:
medium: Memory
volume_id: 541980f9-fadc-41cd-8222-e2ffdb6421c4
volumename: sssd-conf-d
Obtain the information needed to create a UAI class for the Broker UAI containing the updated configuration in the volume list.
The image-id of the Broker UAI image, the volume-ids of the volumes to be added to the broker class, and the class-id of the End-User UAI class managed by the broker are required:
ncn-m001-pit# cray uas admin config images list
Example output:
[[results]]
default = true
image_id = "1996c7f7-ca45-4588-bc41-0422fe2a1c3d"
imagename = "registry.local/cray/cray-uai-sles15sp2:1.2.4"
[[results]]
default = false
image_id = "5d2dd6a3-e9d3-43f1-aa3e-b9bf1589217d"
imagename = "registry.local/cray/cray-uai-sanity-test:1.2.4"
[[results]]
default = false
image_id = "8f180ddc-37e5-4ead-b261-2b401914a79f"
imagename = "registry.local/cray/cray-uai-broker:1.2.4"
ncn-m001-pit# cray uas admin config volumes list
[[results]]
mount_path = "/etc/localtime"
volume_id = "11a4a22a-9644-4529-9434-d296eef2dc48"
volumename = "timezone"
[results.volume_description.host_path]
path = "/etc/localtime"
type = "FileOrCreate"
[[results]]
mount_path = "/etc/sssd"
volume_id = "1ec36af0-d5b6-4ad9-b3e8-755729765d76"
volumename = "broker-sssd-config"
[results.volume_description.secret]
default_mode = 384
secret_name = "broker-sssd-conf"
[[results]]
mount_path = "/lus"
volume_id = "a3b149fd-c477-41f0-8f8d-bfcee87fdd0a"
volumename = "lustre"
[results.volume_description.host_path]
path = "/lus"
type = "DirectoryOrCreate"
[[results]]
mount_path = "/etc/sssd/conf.d"
volume_id = "541980f9-fadc-41cd-8222-e2ffdb6421c4"
volumename = "sssd-conf-d"
[results.volume_description.empty_dir]
medium = "Memory"
Create the Broker UAI class with the content retrieved in the previous step.
ncn-m001-pit#cray uas admin config classes create \
--image-id 8f180ddc-37e5-4ead-b261-2b401914a79f \
--volume-list 11a4a22a-9644-4529-9434-d296eef2dc48,1ec36af0-d5b6-4ad9-b3e8-755729765d76,a3b149fd-c477-41f0-8f8d-bfcee87fdd0a,541980f9-fadc-41cd-8222-e2ffdb6421c4 \
--replicas 3 \
--namespace uas \
--uai-compute-network no \
--public-ip yes \
--comment "UAI broker class" \
--uai-creation-class bdb4988b-c061-48fa-a005-34f8571b88b4
Example output:
class_id = "d764c880-41b8-41e8-bacc-f94f7c5b053d"
comment = "UAI broker class"
default = false
image_id = "8f180ddc-37e5-4ead-b261-2b401914a79f"
namespace = "uas"
opt_ports = []
priority_class_name = "uai-priority"
public_ip = true
replicas = 3
uai_compute_network = false
uai_creation_class = "bdb4988b-c061-48fa-a005-34f8571b88b4"
volume_list = [ "11a4a22a-9644-4529-9434-d296eef2dc48", "1ec36af0-d5b6-4ad9-b3e8-755729765d76", "a3b149fd-c477-41f0-8f8d-bfcee87fdd0a","541980f9-fadc-41cd-8222-e2ffdb6421c4"]
[[volume_mounts]]
mount_path = "/etc/localtime"
volume_id = "11a4a22a-9644-4529-9434-d296eef2dc48"
volumename = "timezone"
[volume_mounts.volume_description.host_path]
path = "/etc/localtime"
type = "FileOrCreate"
[[volume_mounts]]
mount_path = "/etc/sssd"
volume_id = "1ec36af0-d5b6-4ad9-b3e8-755729765d76"
volumename = "broker-sssd-config"
[volume_mounts.volume_description.secret]
default_mode = 384
secret_name = "broker-sssd-conf"
[[volume_mounts]]
mount_path = "/lus"
volume_id = "a3b149fd-c477-41f0-8f8d-bfcee87fdd0a"
volumename = "lustre"
[volume_mounts.volume_description.host_path]
path = "/lus"
type = "DirectoryOrCreate"
[[results.volume_mounts]]
mount_path = "/etc/sssd/conf.d"
volume_id = "541980f9-fadc-41cd-8222-e2ffdb6421c4"
volumename = "sssd-conf-d"
[results.volume_mounts.volume_description.empty_dir]
medium = "Memory"
[uai_image]
default = false
image_id = "8f180ddc-37e5-4ead-b261-2b401914a79f"
imagename = "registry.local/cray/cray-uai-broker:1.2.4"
NOTE: In some versions of UAS, SSSD will not start correctly when customized as described above because /etc/sssd/sssd.conf
is mounted with the wrong mode in spite of being configured with the right mode.
If SSSD is not working in a Broker UAI, refer to this troubleshooting section.