Describes how to view the logs of BOS operations with Kubernetes.
When a Boot Orchestration Service (BOS) session is created, it will return a job ID. This ID can be used to locate the Boot Orchestration Agent (BOA) Kubernetes job that executes the session. For example:
ncn-mw# cray bos session create --template-uuid SESSIONTEMPLATE_NAME --operation boot --format toml
Example output:
operation = "boot"
templateName = "SESSIONTEMPLATE_NAME"
[[links]]
href = "foo-c7faa704-3f98-4c91-bdfb-e377a184ab4f"
jobId = "boa-a939bd32-9d27-433f-afc2-735e77ec8e58"
rel = "session"
type = "GET"
All BOS Kubernetes pods operate in the services namespace.
Use the following command to locate the Kubernetes BOA pod.
ncn-mw# kubectl get pods -n services | grep -E "NAME | BOS_SESSION_JOB_ID"
For example:
ncn-mw# kubectl get pods -n services | grep -E "NAME | boa-a939bd32-9d27-433f-afc2-735e77ec8e58"
Example output:
NAME READY STATUS RESTARTS AGE
boa-a939bd32-9d27-433f-afc2-735e77ec8e58-ztscd 0/2 Completed 0 16m
Use the following command to locate the Kubernetes BOA job.
ncn-mw# kubectl get jobs -n services BOS_SESSION_JOB_ID
For example:
ncn-mw# kubectl get jobs -n services boa-a939bd32-9d27-433f-afc2-735e77ec8e58
Example output:
NAME COMPLETIONS DURATION AGE
boa-a939bd32-9d27-433f-afc2-735e77ec8e58 1/1 13m 15m
The Kubernetes BOA pod name is not a one-to-one match with the BOA job name. The pod name has -XXXX appended to it, where ‘X’ is a hexadecimal digit.
Use the following command to look at the BOA pod’s logs.
ncn-mw# kubectl logs -n services KUBERNETES_BOA_POD_ID -c boa
For example:
ncn-mw# kubectl logs -n services boa-a939bd32-9d27-433f-afc2-735e77ec8e58 -c boa
If a session template has CFS enabled, then BOA will attempt to configure the nodes during a boot, reboot, or configure operation. Use the BOA job ID to find the CFS job that BOA launched to configure the nodes.
ncn-mw# cray cfs sessions describe BOA_JOB_ID
For example:
ncn-mw# cray cfs sessions describe boa-86b78489-1d76-4957-9c0e-a7b1d6665c35 --format json
Example output:
{
"ansible": {
"limit": "x3000c0s19b4n0,x3000c0s19b3n0,x3000c0s19b2n0,x3000c0s19b1n0",
"playbook": "site.yml"
},
"id": "ffdda2c6-2277-11ea-8db8-b42e993b706a",
"links": [
{
"href": "/apis/cfs/sessions/boa-86b78489-1d76-4957-9c0e-a7b1d6665c35",
"rel": "self"
},
{
"href": "/apis/cms.cray.com/v1/namespaces/services/cfsessions/boa-86b78489-1d76-4957-9c0e-a7b1d6665c35",
"rel": "k8s"
}
],
"name": "boa-86b78489-1d76-4957-9c0e-a7b1d6665c35",
"repo": {
"branch": "master",
"cloneUrl": "https://api-gw-service-nmn.local/vcs/cray/csm-config-management.git"
},
"status": {
"artifacts": [],
"session": {
"completionTime": "2019-12-19T16:05:11+00:00",
"job": "cfs-85e3e48f-6795-4570-b379-347b05b39dbe", <<-- Kubernetes CFS job ID
"startTime": "2019-12-19T15:55:37+00:00",
"status": "complete",
"succeeded": "true"
},
"targets": {
"failed": 0,
"running": 0,
"success": 0
}
},
"target": {
"definition": "dynamic",
"groups": []
}
}
Use the Kubernetes CFS job ID in the returned output above to find the CFS pod ID. It is the pod with three containers listed, not two.
ncn-mw# kubectl -n services get pods|grep KUBERNETES_CFS_JOB_ID
Example output:
cfs-85e3e48f-6795-4570-b379-347b05b39dbe-59645667b-ffznt 2/2 Running 0 3h57m
cfs-85e3e48f-6795-4570-b379-347b05b39dbe-cvr54 0/3 Completed 0 3h57m
View the pod’s logs for the Ansible container:
ncn-mw# kubectl -n services logs -f -c ansible KUBERNETES_CFS_POD_ID
The BOS log shows when a session was launched. It also logs any errors encountered while attempting to launch a session.
The BOS Kubernetes pod ID can be found with the following command:
ncn-mw# kubectl get pods -n services | grep bos | grep -v etcd
Example output:
cray-bos-d97cf465c-klcrw 2/2 Running 0 90s
Examine the logs:
ncn-mw# kubectl logs BOS_POD_ID
BOS uses an etcd database. Looking at the etcd logs is typically not necessary.