master-logs 1.1 KB

1234567891011121314151617181920212223242526272829
  1. #!/bin/bash
  2. set -euo pipefail
  3. # Return the logs for a given static pod by component name and container name. Remaining arguments are passed to the
  4. # current container runtime.
  5. if [[ -z "${1-}" || -z "${2-}" ]]; then
  6. echo "A component name like 'api', 'etcd', or 'controllers' must be specified along with the container name within that component." 1>&2
  7. exit 1
  8. fi
  9. # container name is ignored for services
  10. types=( "atomic-openshift" "origin" )
  11. for type in "${types[@]}"; do
  12. if systemctl cat "${type}-master-${1}.service" &>/dev/null; then
  13. journalctl -u "${type}-master-${1}.service" "${@:3}"
  14. exit 0
  15. fi
  16. done
  17. # TODO: move to cri-ctl
  18. # TODO: short term hack for cri-o
  19. uid=$(docker ps -l -a --filter "label=openshift.io/component=${1}" --filter "label=io.kubernetes.container.name=POD" --format '{{ .Label "io.kubernetes.pod.uid" }}')
  20. if [[ -z "${uid}" ]]; then
  21. echo "Component ${1} is stopped or not running" 1>&2
  22. exit 0
  23. fi
  24. container=$(docker ps -l -a -q --filter "label=io.kubernetes.pod.uid=${uid}" --filter "label=io.kubernetes.container.name=${2}")
  25. exec docker logs "${@:3}" "${container}"