2e4858e596
Change-Id: I157484236c3dd8783066d9b1b6d7906ed3649c3e
167 lines
5.6 KiB
Bash
Executable File
167 lines
5.6 KiB
Bash
Executable File
#!/bin/bash -e
|
|
# Copyright 2016 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_ts "Running interactively"
|
|
set -x
|
|
TIMEOUT=""
|
|
else
|
|
TIMEOUT="timeout -k 2m 30m"
|
|
fi
|
|
|
|
BASE="/afs/.openstack.org/mirror/fedora"
|
|
# NOTE(pabelanger): #fedora-admin:
|
|
# tibbs | I run pubmirror[12].math.uh.edu.
|
|
# tibbs | It polls the masters every ten minutes.
|
|
# NOTE(ianw): 2018-11 we dropped "-p" from the rsync commands
|
|
# because upstream starting putting setgid bits on directories,
|
|
# which you have to have admin permissions in AFS to set.
|
|
# https://pagure.io/releng/issue/7921
|
|
# NOTE(fungi): 2020-08-17 temporarily(?) switched to mirrors.mit.edu
|
|
# because pubmirror[12].math.uh.edu were stuck on a corrupt f31
|
|
# update for days; not changing Atomic or EPEL mirroring for now.
|
|
MIRROR="rsync://mirrors.mit.edu/fedora/linux"
|
|
K5START="k5start -t -f /etc/fedora.keytab service/fedora-mirror -- ${TIMEOUT}"
|
|
|
|
echo_ts "----- START FEDORA MIRROR RSYNC RUN -----"
|
|
|
|
# Purge old releases
|
|
echo_ts "Purging old mirrors"
|
|
$K5START rm -rf $BASE/releases/31 $BASE/updates/31
|
|
|
|
for REPO in releases/32 releases/33 releases/34 development/rawhide; do
|
|
if ! [ -f $BASE/$REPO ]; then
|
|
$K5START mkdir -p $BASE/$REPO
|
|
fi
|
|
|
|
echo_ts "Running rsync for $REPO..."
|
|
$K5START rsync -rltvz \
|
|
--delete \
|
|
--delete-excluded \
|
|
--exclude="Cloud/x86_64/images/*.box" \
|
|
--exclude="CloudImages/x86_64/images/*.box" \
|
|
--exclude="Container" \
|
|
--exclude="Docker" \
|
|
--exclude="aarch64/" \
|
|
--exclude="armhfp/" \
|
|
--exclude="source/" \
|
|
--exclude="Server" \
|
|
--exclude="Spins" \
|
|
--exclude="Workstation" \
|
|
--exclude="x86_64/debug/" \
|
|
--exclude="x86_64/drpms/" \
|
|
--exclude="snapshot/" \
|
|
--exclude=".~tmp~/" \
|
|
--exclude=".private/" \
|
|
--exclude=".nfs*" \
|
|
$MIRROR/$REPO/ $BASE/$REPO/
|
|
echo_ts "... done"
|
|
done
|
|
|
|
for REPO in updates/32 updates/33 updates/34; do
|
|
if ! [ -f $BASE/$REPO ]; then
|
|
$K5START mkdir -p $BASE/$REPO
|
|
fi
|
|
|
|
echo_ts "Running rsync for $REPO..."
|
|
$K5START rsync -rltvz \
|
|
--delete \
|
|
--delete-excluded \
|
|
--exclude="aarch64/" \
|
|
--exclude="armhfp/" \
|
|
--exclude="i386/" \
|
|
--exclude="source/" \
|
|
--exclude="SRPMS/" \
|
|
--exclude="x86_64/debug" \
|
|
--exclude="x86_64/drpms" \
|
|
--exclude="snapshot/" \
|
|
--exclude=".~tmp~/" \
|
|
--exclude=".private/" \
|
|
--exclude=".nfs*" \
|
|
$MIRROR/$REPO/ $BASE/$REPO/
|
|
echo_ts "... done"
|
|
done
|
|
|
|
# Atomic is EOL but this particular image is used by magnum. We mirror
|
|
# only this specific version.
|
|
MIRROR="rsync://pubmirror2.math.uh.edu/fedora-buffet/alt/atomic/stable/Fedora-29-updates-20190820.0"
|
|
|
|
if ! [ -f $BASE/atomic/stable/Fedora-29-updates-20190820.0 ]; then
|
|
$K5START mkdir -p $BASE/atomic/stable/Fedora-29-updates-20190820.0
|
|
fi
|
|
|
|
echo_ts "Running rsync atomic..."
|
|
$K5START rsync -rltvz \
|
|
--delete \
|
|
--delete-excluded \
|
|
--exclude="testing/" \
|
|
--exclude="Atomic/" \
|
|
--exclude="ppc64le/" \
|
|
--exclude="images/*.raw.xz" \
|
|
--exclude="images/*.box" \
|
|
--exclude="images/*.iso" \
|
|
--exclude="images/efiboot.img" \
|
|
--exclude="images/install.img" \
|
|
--exclude="iso/*.iso" \
|
|
--exclude="os/EFI/BOOT/" \
|
|
--exclude="pxeboot/" \
|
|
--exclude="isolinux/" \
|
|
$MIRROR/ $BASE/atomic/stable/Fedora-29-updates-20190820.0/
|
|
echo_ts "... done"
|
|
# TODO(pabelanger): Validate rsync process
|
|
|
|
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
|
|
|
|
# Now sleep for 20 minutes. openafs "pads" its incremental
|
|
# replication on "vos release" by -15 minutes to account for clock
|
|
# skew between hosts.
|
|
#
|
|
# We can get into a negative feedback loop with this, particularly if
|
|
# we have a series of big updates, or run things by hand to avoid
|
|
# timeouts.
|
|
#
|
|
# Consider the case of a large mirror pulse (perhaps a new distro
|
|
# release is included, etc.). The "Last Update" time on the volume
|
|
# will indicate when this run finished.
|
|
#
|
|
# The last 15 minutes of that run could have brought in a significant
|
|
# amount of data. Now we move onto the next mirror pulse, and the
|
|
# "vos release" below will try to sync the remote R/O volume from
|
|
# "Last Update - 15 minutes" to now(). If you include the data from
|
|
# this pulse, we are now dragging across potentially *a lot* of data;
|
|
# enough to make the whole thing timeout. Then the volume is locked,
|
|
# and we keep putting more data ontop with each cron run making it
|
|
# even worse.
|
|
#
|
|
# By sleeping here for 15+ minutes and doing a trivial write, we can
|
|
# ensure that when the *next* release says "sync from Last Update - 15
|
|
# minutes" it will *only* include this trivial write, and not
|
|
# potentially this entire mirror pulse data too.
|
|
|
|
sleep $(( 20 * 60 ))
|
|
date --iso-8601=ns | $K5START tee $BASE/timestamp.txt
|
|
|
|
echo_ts "Running vos release."
|
|
vos_release $MIRROR_VOLUME | \
|
|
while IFS= read -r line; do echo_ts "$line"; done
|
|
echo_ts "... done"
|
|
|
|
echo_ts "----- END FEDORA MIRROR RSYNC RUN -----"
|
|
printf "\n\n"
|