Change the SSH keys for users on non-compute nodes (NCNs) on the system using
the rotate-ssh-keys-mgmt-nodes.yml
Ansible playbook provided by CSM or through
NCN node personalization (site.yml
).
The NCNs deploy with SSH keys for the root user that are changed during the system install. See Change NCN Image Root Password and SSH Keys for more information on changing the default keys during install. It is a recommended best practice for system security to change the SSH keys after the install is complete on a schedule. This procedure defines how to change the keys once the system is operational.
The NCN root user keys are stored in the HashiCorp Vault
instance, and applied with the csm.ssh_keys
Ansible role via a CFS session. If
no keys are added to Vault as in the procedure below, this Ansible role will
skip any updates.
Generate a new SSH key pair for the root user.
Use ssh-keygen
to generate a new pair or stage an existing pair, as per site security policies and procedures.
Get the HashiCorp Vault root token.
ncn-mw# kubectl get secrets -n vault cray-vault-unseal-keys -o jsonpath='{.data.vault-root}' | base64 -d; echo
Write the private and public halves of the key pair to the HashiCorp Vault.
WARNING: The CSM instance of Vault does not support the
patch
operation. Ensure that if thessh_private_key
andssh_public_key
fields in thesecret/csm/users/root
secret are being updated, then any other desired fields are also included in thewrite
command. For example the user’s password hash. See Update NCN Passwords. Any fields omitted from thewrite
command will be cleared from Vault.
The path to the secret and the SSH key fields are configurable locations in
the CSM csm.ssh_keys
Ansible role located in the CSM configuration
management Git repository that is in use. If not using the defaults as shown
in the command examples, ensure that the paths are consistent between Vault and
the values in the Ansible role. See roles/csm.ssh_keys
in the
repository for more information.
Open an interactive shell in the Vault Kubernetes pod.
ncn-mw# kubectl exec -itn vault cray-vault-0 -c vault -- sh
Write the SSH keys to Vault.
vault login
command will request the token value from the output of the previous step.ssh_private_key
and ssh_public_key
fields should contain the exact content from the
id_rsa
and id_rsa.pub
files (if using RSA key types).NOTE
: It is important to enclose the key content in single quotes to preserve any special characters.vault read
command allows the administrator to verify that the contents of the secret were stored correctly.cray-vault# export VAULT_ADDR=http://cray-vault:8200
cray-vault# vault login
cray-vault# vault write secret/csm/users/root ssh_private_key='...' \
ssh_public_key='...' \
[... other fields (see warning below) ...]
cray-vault# vault read secret/csm/users/root
cray-vault# exit
Use the following procedure with the rotate-ssh-keys-mgmt-nodes.yml
playbook to only change the root SSH keys on NCNs.
This is a quick alternative to running a full management NCN personalization, as documented in the
Configure Non-Compute Nodes with CFS procedure.
Create a CFS configuration layer to run the SSH key change Ansible playbook.
NOTE
This step only needs to be done once, as long as the commit in the CSM
configuration management Git repository has not changed. If the commit has not changed since the
last time this step was run, this step may be skipped, because the previously created CFS configuration
will still work.
Create a file containing only this CFS configuration layer.
The file contents should be as follows, except replace the <INSERT GIT COMMIT ID>
text with the commit in the
CSM configuration management Git repository that is in use.
{
"layers": [
{
"name": "ncn-root-keys-update",
"cloneUrl": "https://api-gw-service-nmn.local/vcs/cray/csm-config-management.git",
"playbook": "rotate-ssh-keys-mgmt-nodes.yml",
"commit": "<INSERT GIT COMMIT ID>"
}
]
}
Create the ncn-root-keys-update
configuration in CFS.
Replace the <INSERT FILE PATH HERE>
text with the path to the file created in the previous step.
If a CFS configuration already exists with this name, the following command will overwrite it.
ncn-mw# cray cfs configurations update ncn-root-keys-update --file <INSERT FILE PATH HERE>
Create a CFS configuration session to apply the SSH keys update.
ncn-mw# cray cfs sessions create --name ncn-root-keys-update-`date +%Y%m%d%H%M%S` --configuration-name ncn-root-keys-update
Monitor the CFS session.
The csm.ssh_key
Ansible role supports setting SSH keys for non-root users.
Make a copy of the rotate-ssh-keys-mgmt-nodes.yml
Ansible playbook and modify the role variables to specify
a different ssh_keys_username
.
Using that username, add the SSH keys to Vault.
Create a configuration layer using the new Ansible playbook and create a CFS session using that layer.