Generate SAT S3 Credentials

Generate S3 credentials and write them to a local file so the SAT user can access S3 storage. In order to use the SAT S3 bucket, the system administrator must generate the S3 access key and secret keys and write them to a local file. This must be done on every Kubernetes control plane node where SAT commands are run.

SAT uses S3 storage for several purposes, most importantly to store the site-specific information set with sat setrev (see Set System Revision Information).

Prerequisites

Procedure

  1. (ncn-m001#) Ensure the files are readable only by root.

    touch /root/.config/sat/s3_access_key \
        /root/.config/sat/s3_secret_key
    
    chmod 600 /root/.config/sat/s3_access_key \
        /root/.config/sat/s3_secret_key
    
  2. (ncn-m001#) Write the credentials to local files using kubectl.

    kubectl get secret sat-s3-credentials -o json -o \
        jsonpath='{.data.access_key}' | base64 -d > \
        /root/.config/sat/s3_access_key
    
    kubectl get secret sat-s3-credentials -o json -o \
        jsonpath='{.data.secret_key}' | base64 -d > \
        /root/.config/sat/s3_secret_key
    
  3. Verify the S3 endpoint specified in the SAT configuration file is correct.

    1. (ncn-m001#) Get the SAT configuration file’s endpoint value.

      NOTE: If the command’s output is commented out, indicated by an initial # character, the SAT configuration will take the default value – "https://rgw-vip.nmn".

      grep endpoint ~/.config/sat/sat.toml
      

      Example output:

      # endpoint = "https://rgw-vip.nmn"
      
    2. (ncn-m001#) Get the sat-s3-credentials secret’s endpoint value.

      kubectl get secret sat-s3-credentials -o json -o \
          jsonpath='{.data.s3_endpoint}' | base64 -d | xargs
      

      Example output:

      https://rgw-vip.nmn
      
    3. Compare the two endpoint values.

      If the values differ, change the SAT configuration file’s endpoint value to match the secret’s.

  4. (ncn-m001#) Copy SAT configurations to each Kubernetes control plane (ncn-m) node on the system.

    for i in ncn-m002 ncn-m003; do echo $i; ssh ${i} \
        mkdir -p /root/.config/sat; \
        scp -pr /root/.config/sat ${i}:/root/.config; done
    

    NOTE: Depending on how many Kubernetes control plane (ncn-m) nodes are on the system, the list of nodes may be different. This example assumes three ncn-m nodes, where the configuration files must be copied from ncn-m001 to ncn-m002 and ncn-m003. Therefore, the list of hosts above is ncn-m002 and ncn-m003.