system-config/playbooks/roles/mirror-update/files/yum-puppetlabs-mirror-update
Ian Wienand 339cbf4c3d mirror-update: stats for vos release of mirrors
It's difficult to know if a release process is running too long when
we don't have a history of how long it should run for.

This is mostly the stats function from run_all.sh that has been
sending stats about runtimes there.  Wrap it in a vos_release function
with some minor refactoring, and update the scripts.

As noted inline, there's already release timer stats going to
afs.release.<volume> for the periodic release of docs/tarballs etc.

Change-Id: I3d79d1a0997af8977050b7f6e7cf3b7578cc8491
2020-04-09 14:34:35 +10:00

67 lines
1.8 KiB
Bash
Executable File

#!/bin/bash -xe
# Copyright 2018 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
source /usr/share/mirror-update/functions.sh
MIRROR_VOLUME=$1
if [[ ${NO_TIMEOUT:-0} -eq 1 ]]; then
echo "Running interactively"
TIMEOUT=""
else
TIMEOUT="timeout -k 2m 30m"
fi
BASE="/afs/.openstack.org/mirror/yum-puppetlabs"
MIRROR="rsync://rsync.puppet.com/packages"
K5START="k5start -t -f /etc/yum-puppetlabs.keytab service/yum-puppetlabs-mirror -- $TIMEOUT"
if ! [ -f $BASE ]; then
$K5START mkdir -p $BASE
fi
date --iso-8601=ns
echo "Running rsync..."
# We don't need cisco-wrlinux arch in OpenStack Infra.
$K5START rsync -rlptDvz \
--delete \
--delete-excluded \
--exclude="cisco-wrlinux" \
--exclude="el/5" \
--exclude="el/6" \
--exclude="fedora/24" \
--exclude="fedora/25" \
--exclude="fedora/26" \
--exclude="fedora/27" \
--exclude="fedora/f20" \
--exclude="fedora/f21" \
--exclude="fedora/f22" \
--exclude="fedora/f23" \
--exclude="fedora/f24" \
--exclude="fedora/f25" \
--exclude="fedora/f26" \
--exclude="fedora/f27" \
$MIRROR/yum/ $BASE
# TODO(pabelanger): Validate rsync process
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
echo "rsync completed successfully, running vos release."
vos_release $MIRROR_VOLUME
date --iso-8601=ns
echo "Done."