Add log timings for perf debugging.
This commit is contained in:
parent
eb177a2a2b
commit
f6ea1022c2
4 changed files with 46 additions and 36 deletions
|
@ -17,22 +17,22 @@ input_packages="${@:2}"
|
||||||
normalized_packages="$(normalize_package_list "${input_packages}")"
|
normalized_packages="$(normalize_package_list "${input_packages}")"
|
||||||
|
|
||||||
package_count=$(wc -w <<< "${normalized_packages}")
|
package_count=$(wc -w <<< "${normalized_packages}")
|
||||||
echo "Clean installing and caching ${package_count} package(s)."
|
log "Clean installing and caching ${package_count} package(s)."
|
||||||
echo "Package list:"
|
log "Package list:"
|
||||||
for package in ${normalized_packages}; do
|
for package in ${normalized_packages}; do
|
||||||
echo "- ${package}"
|
log "- ${package}"
|
||||||
done
|
done
|
||||||
|
|
||||||
echo -n "Updating APT package list..."
|
log -n "Updating APT package list..."
|
||||||
sudo apt-get update > /dev/null
|
sudo apt-get update > /dev/null
|
||||||
echo "done."
|
"done."
|
||||||
|
|
||||||
# Strictly contains the requested packages.
|
# Strictly contains the requested packages.
|
||||||
manifest_main=""
|
manifest_main=""
|
||||||
# Contains all packages including dependencies.
|
# Contains all packages including dependencies.
|
||||||
manifest_all=""
|
manifest_all=""
|
||||||
|
|
||||||
echo "Clean installing and caching ${package_count} packages..."
|
log "Clean installing and caching ${package_count} packages..."
|
||||||
for package in ${normalized_packages}; do
|
for package in ${normalized_packages}; do
|
||||||
read package_name package_ver < <(get_package_name_ver "${package}")
|
read package_name package_ver < <(get_package_name_ver "${package}")
|
||||||
|
|
||||||
|
@ -42,10 +42,10 @@ for package in ${normalized_packages}; do
|
||||||
all_packages="$(apt-get install --dry-run --yes "${package_name}" | grep "^Inst" | awk '{print $2}')"
|
all_packages="$(apt-get install --dry-run --yes "${package_name}" | grep "^Inst" | awk '{print $2}')"
|
||||||
dep_packages="$(echo ${dep_packages} | grep -v "${package_name}" | tr '\n' ,)"
|
dep_packages="$(echo ${dep_packages} | grep -v "${package_name}" | tr '\n' ,)"
|
||||||
|
|
||||||
echo "- ${package_name}"
|
log "- ${package_name}"
|
||||||
echo " * Version: ${package_ver}"
|
log " * Version: ${package_ver}"
|
||||||
echo " * Dependencies: ${dep_packages:0:-1}"
|
log " * Dependencies: ${dep_packages:0:-1}"
|
||||||
echo -n " * Installing..."
|
log -n " * Installing..."
|
||||||
# Zero interaction while installing or upgrading the system via apt.
|
# Zero interaction while installing or upgrading the system via apt.
|
||||||
sudo DEBIAN_FRONTEND=noninteractive apt-get --yes install "${package}" > /dev/null
|
sudo DEBIAN_FRONTEND=noninteractive apt-get --yes install "${package}" > /dev/null
|
||||||
echo "done."
|
echo "done."
|
||||||
|
@ -55,7 +55,7 @@ for package in ${normalized_packages}; do
|
||||||
|
|
||||||
if test ! -f "${cache_filepath}"; then
|
if test ! -f "${cache_filepath}"; then
|
||||||
read cache_package_name cache_package_ver < <(get_package_name_ver "${cache_package}")
|
read cache_package_name cache_package_ver < <(get_package_name_ver "${cache_package}")
|
||||||
echo -n " * Caching ${cache_package_name} to ${cache_filepath}..."
|
log -n " * Caching ${cache_package_name} to ${cache_filepath}..."
|
||||||
# Pipe all package files (no folders) to Tar.
|
# Pipe all package files (no folders) to Tar.
|
||||||
dpkg -L "${cache_package_name}" |
|
dpkg -L "${cache_package_name}" |
|
||||||
while IFS= read -r f; do
|
while IFS= read -r f; do
|
||||||
|
@ -69,16 +69,16 @@ for package in ${normalized_packages}; do
|
||||||
manifest_all="${manifest_all}${cache_package_name}:${cache_package_ver},"
|
manifest_all="${manifest_all}${cache_package_name}:${cache_package_ver},"
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
echo "done."
|
log "done."
|
||||||
|
|
||||||
manifest_all_filepath="${cache_dir}/manifest_all.log"
|
manifest_all_filepath="${cache_dir}/manifest_all.log"
|
||||||
echo -n "Writing all packages manifest to ${manifest_all_filepath}..."
|
log -n "Writing all packages manifest to ${manifest_all_filepath}..."
|
||||||
# Remove trailing comma and write to manifest_all file.
|
# Remove trailing comma and write to manifest_all file.
|
||||||
echo "${manifest_all:0:-1}" > "${manifest_all_filepath}"
|
echo "${manifest_all:0:-1}" > "${manifest_all_filepath}"
|
||||||
echo "done."
|
echo "done."
|
||||||
|
|
||||||
manifest_main_filepath="${cache_dir}/manifest_main.log"
|
manifest_main_filepath="${cache_dir}/manifest_main.log"
|
||||||
echo -n "Writing main requested packages manifest to ${manifest_main_filepath}..."
|
log -n "Writing main requested packages manifest to ${manifest_main_filepath}..."
|
||||||
# Remove trailing comma and write to manifest_main file.
|
# Remove trailing comma and write to manifest_main file.
|
||||||
echo "${manifest_main:0:-1}" > "${manifest_main_filepath}"
|
echo "${manifest_main:0:-1}" > "${manifest_main_filepath}"
|
||||||
echo "done."
|
echo "done."
|
10
lib.sh
10
lib.sh
|
@ -17,3 +17,13 @@ function get_package_name_ver {
|
||||||
fi
|
fi
|
||||||
echo "${name}" "${ver}"
|
echo "${name}" "${ver}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function log {
|
||||||
|
timestamp="$(echo -n "$(date +%H:%M:%S)")"
|
||||||
|
line=""${timestamp}" "$(echo ${@})""
|
||||||
|
if [[ "${1}" == "-n" ]]; then
|
||||||
|
echo -n "${line}"
|
||||||
|
else
|
||||||
|
echo "${line}"
|
||||||
|
fi
|
||||||
|
}
|
|
@ -19,27 +19,27 @@ packages="$(normalize_package_list "${input_packages}")"
|
||||||
# Create cache directory so artifacts can be saved.
|
# Create cache directory so artifacts can be saved.
|
||||||
mkdir -p ${cache_dir}
|
mkdir -p ${cache_dir}
|
||||||
|
|
||||||
echo -n "Validating action arguments (version='${version}', packages='${packages}')...";
|
log -n "Validating action arguments (version='${version}', packages='${packages}')...";
|
||||||
if grep -q " " <<< "${version}"; then
|
if grep -q " " <<< "${version}"; then
|
||||||
echo "aborted."
|
log "aborted."
|
||||||
echo "Version value '${version}' cannot contain spaces." >&2
|
log "Version value '${version}' cannot contain spaces." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Is length of string zero?
|
# Is length of string zero?
|
||||||
if test -z "${packages}"; then
|
if test -z "${packages}"; then
|
||||||
echo "aborted."
|
log "aborted."
|
||||||
echo "Packages argument cannot be empty." >&2
|
log "Packages argument cannot be empty." >&2
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
echo "done."
|
log "done."
|
||||||
|
|
||||||
versioned_packages=""
|
versioned_packages=""
|
||||||
echo -n "Verifying packages..."
|
log -n "Verifying packages..."
|
||||||
for package in ${packages}; do
|
for package in ${packages}; do
|
||||||
if test ! "$(apt show "${package}")"; then
|
if test ! "$(apt show "${package}")"; then
|
||||||
echo "aborted."
|
echo "aborted."
|
||||||
echo "Package '${package}' not found." >&2
|
log "Package '${package}' not found." >&2
|
||||||
exit 3
|
exit 3
|
||||||
fi
|
fi
|
||||||
read package_name package_ver < <(get_package_name_ver "${package}")
|
read package_name package_ver < <(get_package_name_ver "${package}")
|
||||||
|
@ -50,20 +50,20 @@ echo "done."
|
||||||
# Abort on any failure at this point.
|
# Abort on any failure at this point.
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
echo "Creating cache key..."
|
log "Creating cache key..."
|
||||||
|
|
||||||
# TODO Can we prove this will happen again?
|
# TODO Can we prove this will happen again?
|
||||||
normalized_versioned_packages="$(normalize_package_list "${versioned_packages}")"
|
normalized_versioned_packages="$(normalize_package_list "${versioned_packages}")"
|
||||||
echo "- Normalized package list is '${normalized_versioned_packages}'."
|
log "- Normalized package list is '${normalized_versioned_packages}'."
|
||||||
|
|
||||||
value="$(echo "${normalized_versioned_packages} @ ${version}")"
|
value="$(echo "${normalized_versioned_packages} @ ${version}")"
|
||||||
echo "- Value to hash is '${value}'."
|
log "- Value to hash is '${value}'."
|
||||||
|
|
||||||
key="$(echo "${value}" | md5sum | /bin/cut -f1 -d' ')"
|
key="$(echo "${value}" | md5sum | /bin/cut -f1 -d' ')"
|
||||||
echo "- Value hashed as '${key}'."
|
log "- Value hashed as '${key}'."
|
||||||
|
|
||||||
echo "done."
|
log "done."
|
||||||
|
|
||||||
key_filepath="${cache_dir}/cache_key.md5"
|
key_filepath="${cache_dir}/cache_key.md5"
|
||||||
echo ${key} > ${key_filepath}
|
echo ${key} > ${key_filepath}
|
||||||
echo "Hash value written to ${key_filepath}"
|
log "Hash value written to ${key_filepath}"
|
||||||
|
|
|
@ -11,24 +11,24 @@ cache_dir="${1}"
|
||||||
cache_restore_root="${2}"
|
cache_restore_root="${2}"
|
||||||
|
|
||||||
cache_filepaths="$(ls -1 "${cache_dir}" | sort)"
|
cache_filepaths="$(ls -1 "${cache_dir}" | sort)"
|
||||||
echo "Found $(echo ${cache_filepaths} | wc -w) files in the cache."
|
log "Found $(echo ${cache_filepaths} | wc -w) files in the cache."
|
||||||
for cache_filepath in ${cache_filepaths}; do
|
for cache_filepath in ${cache_filepaths}; do
|
||||||
echo "- "$(basename ${cache_filepath})""
|
log "- "$(basename ${cache_filepath})""
|
||||||
done
|
done
|
||||||
|
|
||||||
echo "Reading from main requested packages manifest..."
|
log "Reading from main requested packages manifest..."
|
||||||
for logline in $(cat "${cache_dir}/manifest_main.log" | tr ',' '\n' ); do
|
for logline in $(cat "${cache_dir}/manifest_main.log" | tr ',' '\n' ); do
|
||||||
echo "- $(echo "${logline}" | tr ':' ' ')"
|
log "- $(echo "${logline}" | tr ':' ' ')"
|
||||||
done
|
done
|
||||||
echo "done."
|
log "done."
|
||||||
|
|
||||||
# Only search for archived results. Manifest and cache key also live here.
|
# Only search for archived results. Manifest and cache key also live here.
|
||||||
cache_pkg_filepaths=$(ls -1 "${cache_dir}"/*.tar.gz | sort)
|
cache_pkg_filepaths=$(ls -1 "${cache_dir}"/*.tar.gz | sort)
|
||||||
cache_pkg_filecount=$(echo ${cache_pkg_filepaths} | wc -w)
|
cache_pkg_filecount=$(echo ${cache_pkg_filepaths} | wc -w)
|
||||||
echo "Restoring ${cache_pkg_filecount} packages from cache..."
|
log "Restoring ${cache_pkg_filecount} packages from cache..."
|
||||||
for cache_pkg_filepath in ${cache_pkg_filepaths}; do
|
for cache_pkg_filepath in ${cache_pkg_filepaths}; do
|
||||||
echo -n "- $(basename "${cache_pkg_filepath}") restoring..."
|
log -n "- $(basename "${cache_pkg_filepath}") restoring..."
|
||||||
sudo tar -xf "${cache_pkg_filepath}" -C "${cache_restore_root}" > /dev/null
|
sudo tar -xf "${cache_pkg_filepath}" -C "${cache_restore_root}" > /dev/null
|
||||||
echo "done."
|
echo "done."
|
||||||
done
|
done
|
||||||
echo "done."
|
log "done."
|
||||||
|
|
Loading…
Reference in a new issue