The sat
command-line utility can optionally be installed and configured on an
external system to interact with CSM over the CAN.
Most sat
commands work by accessing APIs which are reachable via the CAN.
However, certain sat
commands depend on host-based functionality on the
management NCNs and will not work from an external system. This includes the
following:
platform-services
and ncn-power
stages of sat bootsys
--local
option of sat showrev
Installing the sat
CLI on an external system is not an officially supported
configuration. These instructions are provided “as-is” with the hope that they
can be useful for users who desire additional flexibility.
Certain additional steps may need to be taken to install and configure SAT depending on the configuration of the external system in use. These additional steps may include provisioning virtual machines, installing packages, or configuring TLS certificates, and these steps are outside the scope of this documentation. This section covers only the steps needed to configure SAT to use externally-accessible API endpoints exposed by CSM.
kubectl
, openssh
, git
, and curl
are installed on the external system.(user@hostname>
) Create a Python virtual environment.
SAT_VENV_PATH="$(pwd)/venv"
python3 -m venv ${SAT_VENV_PATH}
. ${SAT_VENV_PATH}/bin/activate
((venv) user@hostname>
) Clone the SAT source code.
To use SAT version 3.26, this example clones the release/3.26
branch of
Cray-HPE/sat
.
git clone --branch=release/3.26 https://github.com/Cray-HPE/sat.git
Set up the SAT CSM Python dependencies to be installed from their source code.
SAT CSM Python dependency packages are not currently distributed publicly as
source packages or binary distributions. They must be installed from
their source code hosted on GitHub. Also, to install the cray-product-catalog
Python package, first clone it locally. Use the following steps to
modify the SAT CSM Python dependencies so they can be installed from their source
code.
((venv) user@hostname>
) Clone the source code for cray-product-catalog
.
git clone --branch v1.6.0 https://github.com/Cray-HPE/cray-product-catalog
((venv) user@hostname>
) In the cray-product-catalog
directory, create a file named .version
that contains the version of cray-product-catalog
.
echo 1.6.0 > cray-product-catalog/.version
((venv) user@hostname>
) Open the “locked” requirements file in a text editor.
vim sat/requirements.lock.txt
Update the line containing cray-product-catalog
so that it reflects the
local path to cray-product-catalog
.
It should read as follows:
./cray-product-catalog
For versions of SAT newer than 3.19, change the line containing csm-api-client
to read as follows.
csm-api-client@git+https://github.com/Cray-HPE/python-csm-api-client@release/1.1
(Optional) ((venv) user@hostname>
) Confirm that requirements.lock.txt
is modified as expected.
grep -E 'cray-product-catalog|csm-api-client' sat/requirements.lock.txt
Example output:
./cray-product-catalog
csm-api-client@git+https://github.com/Cray-HPE/python-csm-api-client@release/1.1
NOTE: For versions newer than 3.19, the output will show both
cray-product-catalog
and csm-api-client
. For version 3.19 and older,
the output will only show cray-product-catalog
.
((venv) user@hostname>
) Install the modified SAT dependencies.
pip install -r sat/requirements.lock.txt
((venv) user@hostname>
) Install the SAT Python package.
pip install ./sat
(Optional) ((venv) user@hostname>
) Add the sat
virtual environment to the user’s PATH
environment
variable.
If a shell other than bash
is in use, replace ~/.bash_profile
with the
appropriate profile path.
If the virtual environment is not added to the user’s PATH
environment
variable, then source ${SAT_VENV_PATH}/bin/activate
will need to be run before
running any SAT commands.
deactivate
echo export PATH=\"${SAT_VENV_PATH}/bin:${PATH}\" >> ~/.bash_profile
source ~/.bash_profile
(user@hostname>
) Copy the file /etc/kubernetes/admin.conf
from ncn-m001
to ~/.kube/config
on the external system.
NOTE: This file contains credentials to authenticate against the Kubernetes API as the administrative user, so treat it as sensitive information.
mkdir -p ~/.kube
scp ncn-m001:/etc/kubernetes/admin.conf ~/.kube/config\
Example output:
admin.conf 100% 5566 3.0MB/s 00:00
(user@hostname>
) Find the CAN IP address on ncn-m001
to determine the
corresponding kubernetes
hostname.
On CSM 1.2 and newer, query the IP address of the bond0.cmn0
interface.
ssh ncn-m001 ip addr show bond0.cmn0
Example output:
13: bond0.cmn0@bond0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
link/ether b8:59:9f:1d:d9:0e brd ff:ff:ff:ff:ff:ff
inet 10.102.1.11/24 brd 10.102.1.255 scope global vlan007
valid_lft forever preferred_lft forever
inet6 fe80::ba59:9fff:fe1d:d90e/64 scope link
valid_lft forever preferred_lft forever
On CSM versions prior to 1.2, query the IP address of the vlan007
interface.
ssh ncn-m001 ip addr show vlan007
Example output:
13: vlan007@bond0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
link/ether b8:59:9f:1d:d9:0e brd ff:ff:ff:ff:ff:ff
inet 10.102.1.10/24 brd 10.102.1.255 scope global vlan007
valid_lft forever preferred_lft forever
inet6 fe80::ba59:9fff:fe1d:d90e/64 scope link
valid_lft forever preferred_lft forever
(user@hostname>
) Set the IP_ADDRESS
variable to the value found in the
previous step.
IP_ADDRESS=10.102.1.11
(user@hostname>
) Add an entry to /etc/hosts
mapping the IP address to
the hostname kubernetes
.
echo "${IP_ADDRESS} kubernetes" | sudo tee -a /etc/hosts
10.102.1.11 kubernetes
(user@hostname>
) Modify ~/.kube/config
to set the cluster server address.
The value of the server
key for the kubernetes
cluster under the clusters
section should be set to https://kubernetes:6443
.
---
clusters:
- cluster:
certificate-authority-data: REDACTED
server: https://kubernetes:6443
name: kubernetes
...
(user@hostname>
) Confirm that kubectl
can access the CSM Kubernetes cluster.
kubectl get nodes
Example output:
NAME STATUS ROLES AGE VERSION
ncn-m001 Ready master 135d v1.19.9
ncn-m002 Ready master 136d v1.19.9
ncn-m003 Ready master 136d v1.19.9
ncn-w001 Ready <none> 136d v1.19.9
ncn-w002 Ready <none> 136d v1.19.9
ncn-w003 Ready <none> 136d v1.19.9
(user@hostname>
) Use sat init
to create a configuration file for SAT.
sat init
Example output:
INFO: Configuration file "/home/user/.config/sat/sat.toml" generated.
(user@hostname>
) Copy the platform CA certificates from the management NCN
and configure the certificates for use with SAT.
If a shell other than bash
is in use, replace ~/.bash_profile
with the
appropriate profile path.
scp ncn-m001:/etc/pki/trust/anchors/platform-ca-certs.crt .
echo export REQUESTS_CA_BUNDLE=\"$(realpath platform-ca-certs.crt)\" >> ~/.bash_profile
source ~/.bash_profile
Edit the SAT configuration file to set the API and S3 hostnames.
Externally available API endpoints are given domain names in PowerDNS, so the
endpoints in the configuration file should each be set to the format
subdomain.system-name.site-domain
. Here system-name
and site-domain
are
replaced with the values specified during csi config init
, and subdomain
is the DNS name for the externally available service. For more information,
see Externally Exposed Services.
The API gateway has the subdomain api
, and S3 has the subdomain s3
. The
S3 endpoint runs on port 8080. The following options should be set in the
SAT configuration file.
[api_gateway]
host = "api.system-name.site-domain"
[s3]
endpoint = "http://s3.system-name.site-domain:8080"
Edit the SAT configuration file to specify the Keycloak user who will be accessing the REST API.
[api_gateway]
username = "user"
(user@hostname>
) Use sat auth
and enter the password when prompted.
sat auth
Example output:
Password for user:
Succeeded!
For more information on authenticating SAT to the API gateway, see Authenticate SAT Commands.
(user@hostname>
) Ensure the files are readable only by the current user.
touch ~/.config/sat/s3_access_key \
~/.config/sat/s3_secret_key
chmod 600 ~/.config/sat/s3_access_key \
~/.config/sat/s3_secret_key
(user@hostname>
) Write the credentials to local files using kubectl
.
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 user must generate
the S3 access key and secret keys and write them to a local file. SAT uses
S3 storage for several purposes, most importantly to store the site-specific
information set with sat setrev
.
kubectl get secret sat-s3-credentials -o json -o \
jsonpath='{.data.access_key}' | base64 -d > \
~/.config/sat/s3_access_key
kubectl get secret sat-s3-credentials -o json -o \
jsonpath='{.data.secret_key}' | base64 -d > \
~/.config/sat/s3_secret_key