summaryrefslogtreecommitdiffstats
path: root/mcp/scripts/log.sh
blob: 8bfd0d5539631dd4d5c7d3e115edf3e918dcb138 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#!/bin/bash -e
##############################################################################
# Copyright (c) 2017 Mirantis Inc., Enea AB and others.
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
#
# Collect /var/log from all cluster nodes via Salt Master
#

# shellcheck disable=SC1090
[ -n "${SSH_OPTS}" ] || source "$(dirname "${BASH_SOURCE[0]}")/globals.sh"

CI_DEBUG=${CI_DEBUG:-0}; [[ "${CI_DEBUG}" =~ (false|0) ]] || set -x
DEPLOY_LOG=$1
OPNFV_TMP_LOG="opnfv_fuel_logs"

[ -n "${DEPLOY_LOG}" ] || exit 0

# ssh to cfg01
# shellcheck disable=SC2086,2087
ssh ${SSH_OPTS} "${SSH_SALT}" bash -s << LOG_COLLECT_END
  sudo -i

  echo salt -C '*' cp.push_dir /var/log upload_path='${OPNFV_TMP_LOG}'
  salt -C '*' cp.push_dir /var/log upload_path='${OPNFV_TMP_LOG}'

  cd /var/cache/salt/master/minions && \
    find */files/${OPNFV_TMP_LOG}/ | \
      xargs tar czf \$(eval echo \~\${SUDO_USER}/${OPNFV_TMP_LOG}.tar.gz) \
        --transform 's|/files/${OPNFV_TMP_LOG}||'
LOG_COLLECT_END

# shellcheck disable=SC2086
scp ${SSH_OPTS} "${SSH_SALT}:${OPNFV_TMP_LOG}.tar.gz" "${DEPLOY_LOG}"
# shellcheck disable=SC2086,2029
ssh ${SSH_OPTS} "${SSH_SALT}" rm -f "${OPNFV_TMP_LOG}.tar.gz"
n class="k">do arr.append(pack([pack(c.apt['keys']), pack(c.apt.repos), pack(c.pkg.install), pack(c.pkg.remove)], '^')) -%} {%- endfor -%} '{{ pack(arr, '^') }}' {%- endmacro -%} {%- set bridges = conf.idf.fuel.jumphost.bridges %} # Determine bridge names based on IDF, where all bridges are now mandatory OPNFV_BRIDGES=( '{{ bridges.admin or "pxebr" }}' '{{ bridges.mgmt or "mgmt" }}' '{{ bridges.private or "internal" }}' '{{ bridges.public or "public" }}' ) export CLUSTER_DOMAIN={{ conf.cluster.domain }} cluster_states={{ bash_arr(conf.cluster.states) }} virtual_nodes={{ bash_arr(conf.virtual.nodes) }} base_image={{ arch.base_image }} # Serialize vnode data as '<name0>,<ram0>,<vcpu0>|<name1>,<ram1>,<vcpu1>[...]' virtual_nodes_data={{ serialize_vnodes() }} # Serialize repos, packages to (pre-)install/remove for: # - foundation node VM base image (virtual: all VMs, baremetal: cfg01|mas01) # - virtualized control plane VM base image (only when VCP is used) virtual_repos_pkgs={{ serialize_apt_pkg() }}