Merge "mirror-update: stats for vos release of mirrors"

This commit is contained in:
Zuul 2020-04-14 20:33:25 +00:00 committed by Gerrit Code Review
commit e3901ef8fe
7 changed files with 56 additions and 7 deletions

View File

@ -93,7 +93,7 @@ done
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
echo "rsync completed successfully, running vos release."
$VOS_RELEASE $MIRROR_VOLUME
vos_release $MIRROR_VOLUME
date --iso-8601=ns
echo "Done."

View File

@ -90,7 +90,7 @@ echo "$SHA1SUM $BASE/$REPO/$REPOMD" | sha1sum -c -
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
echo "rsync completed successfully, running vos release."
$VOS_RELEASE $MIRROR_VOLUME
vos_release $MIRROR_VOLUME
date --iso-8601=ns
echo "Done."

View File

@ -153,7 +153,7 @@ sleep $(( 20 * 60 ))
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
echo_ts "Running vos release."
$VOS_RELEASE $MIRROR_VOLUME | \
vos_release $MIRROR_VOLUME | \
while IFS= read -r line; do echo_ts "$line"; done
echo_ts "... done"

View File

@ -2,4 +2,47 @@
# Common definitions and functions for mirror-update scripts
#
VOS_RELEASE="ssh -i /root/.ssh/id_vos_release vos_release@afs01.dfw.openstack.org vos release "
AFS_SERVER=afs01.dfw.openstack.org
VOS_RELEASE="ssh -i /root/.ssh/id_vos_release vos_release@${AFS_SERVER} vos release "
# Send a timer stat to statsd
# send_timer metric [start_time]
# * uses timer metric afs.release.<$1> normalised for stats
# * time will be taken from last call of start_timer, or $2 if set
function send_timer {
# Only send stats under cron conditions
if [[ ${UNDER_CRON} != 1 ]]; then
return
fi
local current
current=$(date '+%s')
local name
# "." is a separator, replace with _
name=${1//./_}
local start
start=${2-$_START_TIME}
local elapsed_ms
elapsed_ms=$(( (current - start) * 1000 ))
# See also the release-volumes.py script which sends stats to the
# same place for doc, etc. volumes.
echo "afs.release.${name}:${elapsed_ms}|ms" | nc -w 1 -u graphite.opendev.org 8125
echo "End timer for $name"
}
# See send_timer
function start_timer {
_START_TIME=$(date '+%s')
}
# Run vos release via ssh on the AFS server, and report the timing
# back to graphite
function vos_release {
local name
name=$1
start_timer
$VOS_RELEASE ${name}
send_timer ${name}
}

View File

@ -133,7 +133,7 @@ $K5START rsync -rlptDvz \
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
echo "rsync completed successfully, running vos release."
$VOS_RELEASE $MIRROR_VOLUME
vos_release $MIRROR_VOLUME
date --iso-8601=ns
echo "Done."

View File

@ -60,7 +60,7 @@ $K5START rsync -rlptDvz \
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
echo "rsync completed successfully, running vos release."
$VOS_RELEASE $MIRROR_VOLUME
vos_release $MIRROR_VOLUME
date --iso-8601=ns
echo "Done."

View File

@ -55,6 +55,12 @@
mode: '0755'
loop: '{{ rsync_update_scripts }}'
- name: Set cron flag to enable reporting stats
cron:
name: UNDER_CRON
env: yes
job: '1'
- name: Install update cron jobs
cron:
name: '{{ item }} mirror sync'
@ -70,4 +76,4 @@
vars:
logrotate_file_name: '/var/log/rsync-mirrors/{{ item }}.log'
logrotate_frequency: 'weekly'
loop: '{{ rsync_update_scripts }}'
loop: '{{ rsync_update_scripts }}'