Skip to content
This repository has been archived by the owner on Dec 29, 2024. It is now read-only.

Commit

Permalink
refresh & squash
Browse files Browse the repository at this point in the history
  • Loading branch information
kiorky committed Sep 20, 2024
1 parent c821c93 commit 9b0ea51
Show file tree
Hide file tree
Showing 31 changed files with 603 additions and 230 deletions.
7 changes: 5 additions & 2 deletions .github/workflows/cicd.yml
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,11 @@ jobs:
fail-fast: false
matrix:
IMAGES:
- "library/amazonlinux/2 library/amazonlinux/latest library/amazonlinux/1"
- "library/amazonlinux/with-sources library/amazonlinux/1-with-sources library/amazonlinux/2-with-sources"
- "library/amazonlinux/latest library/amazonlinux/with-sources"
- "library/amazonlinux/2023"
- "library/amazonlinux/2022-with-sources library/amazonlinux/2022"
- "library/amazonlinux/2 library/amazonlinux/1"
- "library/amazonlinux/2-with-sources library/amazonlinux/1-with-sources"
#- "corpusops/test/a corpusops/test/b corpusops/test/c"
# all images that werent explicitly told to be built would be built in the next batches
# we span them onto N jobs
Expand Down
3 changes: 2 additions & 1 deletion Dockerfile.args
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
ARG DO_UPDATE=y
ARG NONINTERACTIVE=y
ARG DEBIAN_FRONTEND=noninteractive
ARG INSTALL_DEFAULT_LOCALE="fr_FR.UTF-8"
ARG EXTRA_FILES_LIST=""
ARG COPS_SYSTEM=${_cops_SYSTEM}
ARG COPS_SYSTEM=${_cops_SYSTEM-}
ARG FOREGO_RELEASE=latest
ARG REMCO_RELEASE=latest
ARG GOSU_RELEASE=latest
Expand Down
2 changes: 1 addition & 1 deletion Dockerfile.from
Original file line number Diff line number Diff line change
@@ -1 +1 @@
FROM ${_cops_BASE}:${_cops_VERSION}
FROM ${_cops_BASE}:${_cops_VERSION} AS final
1 change: 1 addition & 0 deletions Dockerfile.labels
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
ARG DOCKER_IMAGES_COMMIT="$DOCKER_IMAGES_COMMIT"
LABEL com.github.corpusops.docker-images-commit="$DOCKER_IMAGES_COMMIT"
4 changes: 4 additions & 0 deletions Dockerfile.squash
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
FROM $RSYNC AS squashed-rsync
FROM $ANCESTOR AS squashed-ancestor
ARG ROOTFS="/BASE_ROOTFS_TO_COPY_THAT_WONT_COLLIDE_1234567890"
ARG PATH="${ROOTFS}_rsync/bin:$PATH"
4 changes: 4 additions & 0 deletions Dockerfile.squashexec
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
SHELL ["busybox", "sh", "-c"]
RUN --mount=type=bind,from=final,target=$ROOTFS --mount=type=bind,from=squashed-rsync,target=${ROOTFS}_rsync \
rsync -Aaz --delete ${ROOTFS}/ / --exclude=/proc --exclude=/sys --exclude=/etc/resolv.conf --exclude=/etc/hosts --exclude=$ROOTFS* --exclude=dev/shm --exclude=dev/pts --exclude=dev/mqueue
SHELL ["/bin/sh", "-c"]
2 changes: 2 additions & 0 deletions Dockerfile.squashpre
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
ARG ANCESTOR=${_cops_BASE}:${_cops_VERSION}
ARG RSYNC=corpusops/rsync
26 changes: 20 additions & 6 deletions helpers/cops_pkgmgr_install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ SYSTEM_COPS_ROOT=${SYSTEM_COPS_ROOT-$DEFAULT_COPS_ROOT}
DOCKER_COPS_ROOT=${DOCKER_COPS_ROOT-$SYSTEM_COPS_ROOT}
COPS_URL=${COPS_URL-$DEFAULT_COPS_URL}
BASE_PREPROVISION_IMAGES="ubuntu:latest_preprovision"
BASE_PREPROVISION_IMAGES="$BASE_PREPROVISION_IMAGES corpusops/ubuntu:24.04_preprovision"
BASE_PREPROVISION_IMAGES="$BASE_PREPROVISION_IMAGES corpusops/ubuntu:22.04_preprovision"
BASE_PREPROVISION_IMAGES="$BASE_PREPROVISION_IMAGES corpusops/ubuntu:20.04_preprovision"
BASE_PREPROVISION_IMAGES="$BASE_PREPROVISION_IMAGES corpusops/ubuntu:18.04_preprovision"
Expand All @@ -44,6 +45,7 @@ BASE_PREPROVISION_IMAGES="$BASE_PREPROVISION_IMAGES corpusops/ubuntu:14.04_prepr
BASE_PREPROVISION_IMAGES="$BASE_PREPROVISION_IMAGES corpusops/centos:7_preprovision"

BASE_CORE_IMAGES="$BASE_CORE_IMAGES corpusops/ubuntu:latest"
BASE_CORE_IMAGES="$BASE_CORE_IMAGES corpusops/ubuntu:24.04"
BASE_CORE_IMAGES="$BASE_CORE_IMAGES corpusops/ubuntu:22.04"
BASE_CORE_IMAGES="$BASE_CORE_IMAGES corpusops/ubuntu:20.04"
BASE_CORE_IMAGES="$BASE_CORE_IMAGES corpusops/ubuntu:18.04"
Expand All @@ -55,6 +57,7 @@ EXP_PREPROVISION_IMAGES=""
EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES archlinux:latest_preprovision"
EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES debian:latest_preprovision"
#EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES debian:stretch_preprovision"
EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES debian:bookworm_preprovision"
EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES debian:bullseye_preprovision"
EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES debian:buster_preprovision"
EXP_PREPROVISION_IMAGES="$EXP_PREPROVISION_IMAGES debian:sid_preprovision"
Expand All @@ -64,6 +67,7 @@ EXP_CORE_IMAGES="$EXP_CORE_IMAGES corpusops/debian:latest"
#EXP_CORE_IMAGES="$EXP_CORE_IMAGES corpusops/debian:stretch"
EXP_CORE_IMAGES="$EXP_CORE_IMAGES corpusops/debian:bullseye"
EXP_CORE_IMAGES="$EXP_CORE_IMAGES corpusops/debian:buster"
EXP_CORE_IMAGES="$EXP_CORE_IMAGES corpusops/debian:bookworm"
EXP_CORE_IMAGES="$EXP_CORE_IMAGES corpusops/debian:sid"
EXP_IMAGES="$EXP_PREPROVISION_IMAGES $EXP_CORE_IMAGES"
# ansible related
Expand Down Expand Up @@ -518,8 +522,8 @@ get_python2() {
get_python3() {
local py_ver=3
get_python_ $py_ver \
python3.10 python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 \
python-3.10 python-3.9 python-3.8 python-3.7 python-3.6 python-3.5 python-3.4 \
python3.12 python3.11 python3.10 python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 \
python-3.12 python-3.11 python-3.10 python-3.9 python-3.8 python-3.7 python-3.6 python-3.5 python-3.4 \
python-${py_ver} python${py_ver} python
}
has_python_module() {
Expand All @@ -538,9 +542,19 @@ pymod_ver() {
get_setuptools() {
local py=${1:-python}
local setuptoolsreq="setuptools"
if ( is_python2 $py );then setuptoolsreq="setuptools<=45"; else setuptoolsreq="setuptools<50"; fi
local cpyver=$($py -c "import sys;print(sys.version.split()[0])")
if ( is_python2 $py );then
setuptoolsreq="setuptools<=45"
elif ( version_lt $cpyver 3.12.0 );then
setuptoolsreq="setuptools<66"
else
setuptoolsreq="setuptools>=75"
fi
echo "$setuptoolsreq"
}
setup_setuptools_requirement() {
sed -i -re "s/^setuptools\s*(>|<|=|$)/$(get_setuptools $py)/g" requirements/python_requirements.txt
}
install_pip() {
local py="${1:-python}"
local DEFAULT_PIP_URL="https://bootstrap.pypa.io/get-pip.py"
Expand Down Expand Up @@ -760,8 +774,8 @@ ensure_command() {
### archlinux (pacman)
is_pacman_available() {
for i in $@;do
if ! ( pacman -Si $(i_y) "$i" >/devnull 2>&1 ||\
pacman -Sg $(i_y) "$i" >/devnull 2>&1; );then
if ! ( pacman -Si $(i_y) "$i" >/dev/null 2>&1 ||\
pacman -Sg $(i_y) "$i" >/dev/null 2>&1; );then
return 1
fi
done
Expand All @@ -770,7 +784,7 @@ is_pacman_available() {

is_pacman_installed() {
for i in $@;do
if ! ( pacman -Qi $(i_y) "$i" >/devnull 2>&1; ); then
if ! ( pacman -Qi $(i_y) "$i" >/dev/null 2>&1; ); then
return 1
fi
done
Expand Down
137 changes: 102 additions & 35 deletions helpers/up.sh
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#!/usr/bin/env sh
set -e
set -ex
log() { echo "${@}" >&2; }
vv() { log "${@}";"${@}"; }
DO_UPDATE=1
Expand All @@ -18,10 +18,22 @@ _cops_SYSTEM=$(system_detect.sh||./system_detect.sh||"$W/system_detect.sh")
DISTRIB_ID=
DISTRIB_CODENAME=
DISTRIB_RELEASE=
oldubuntu="^(10\.|12\.|13\.|14\.|15\.|16\.|17\.|18\.10|19\.|20\.10|21\.)"
oldubuntu="^(10\.|12\.|13\.|14\.|15\.|16\.|17\.|18\.10|19\.|20\.10|21\.|22\.10)"
# oldubuntu="^(10\.|12\.|13\.|14.10|15\.|16.10|17\.04)"
NOSOCAT=""
CENTOS_OLDSTABLE=8
CENTOS_OLDSTABLES="6|7|8"
OAPTMIRROR="${OAPTMIRROR:-}"
OYUMMIRROR="${OYUMMIRROR:-}"
NYUMMIRROR="${NYUMMIRROR:-}"
OUBUNTUMIRROR="${OUBUNTUMIRROR:-old-releases.ubuntu.com}"
ODEBIANMIRROR="${ODEBIANMIRROR:-archive.debian.org}"
NDEBIANMIRROR="${NDEBIANMIRROR:-http.debian.net|httpredir.debian.org|deb.debian.org}"
NUBUNTUMIRROR="${NUBUNTUMIRROR:-archive.ubuntu.com|security.ubuntu.com}"
IS_OLD_CENTOS_STABLE=""
SNCENTOSMIRROR="$(echo "${NCENTOSMIRROR}"|sed -re "s/\|.*//g")"
SNDEBIANMIRROR="$(echo "${NDEBIANMIRROR}"|sed -re "s/\|.*//g")"
SNUBUNTUMIRROR="$(echo "${NUBUNTUMIRROR}"|sed -re "s/\|.*//g")"
yuminstall () {
if (yum --version >/dev/null 2>&1 );then
( vv yum -y install $@ || vv yum --disablerepo=epel -y install $@ ) || /bin/true
Expand All @@ -48,32 +60,53 @@ elif [ -e /etc/redhat-release ];then
DISTRIB_RELEASE=$(echo $(head /etc/issue)|awk '{print tolower($3)}')
fi
DISTRIB_MAJOR="$(echo ${DISTRIB_RELEASE}|sed -re "s/\..*//g")"
if [ "x${DISTRIB_ID}" = "xcentos" ] && ( echo "${DISTRIB_MAJOR}" | grep -Eq "^(6|7|8)");then
sed -i 's/mirrorlist/#mirrorlist/g;s|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g' /etc/yum.repos.d/CentOS-*
EPEL_RPM_URL="https://dl.fedoraproject.org/pub/epel/epel-release-latest-${DISTRIB_MAJOR}.noarch.rpm"
if [ "x${DISTRIB_ID}" = "xcentos" ] && ( echo "${DISTRIB_MAJOR}" | grep -Eq "$CENTOS_OLDSTABLES");then
IS_OLD_CENTOS_STABLE="1"
EPEL_RPM_URL="https://archives.fedoraproject.org/pub/archive/epel/7/x86_64/Packages/e/epel-release-7-14.noarch.rpm"
if (echo "$DISTRIB_RELEASE"|egrep -q "8|7");then
OCENTOSMIRROR="${OCENTOSMIRROR:-mirror.centos.org}"
NCENTOSMIRROR="${NCENTOSMIRROR:-vault.centos.org}"
elif [ $DISTRIB_RELEASE -le $CENTOS_OLDSTABLE ];then
OCENTOSMIRROR="${OCENTOSMIRROR:-vault.centos.org}"
NCENTOSMIRROR="${NCENTOSMIRROR:-mirror.centos.org}"
else
OCENTOSMIRROR="${OCENTOSMIRROR:-mirror.centos.org}"
NCENTOSMIRROR="${NCENTOSMIRROR:-vault.centos.org}"
fi
OYUMMIRROR="${OCENTOSMIRROR}"
NYUMMIRROR="${NCENTOSMIRROR}"
if [ "$OYUMMIRROR" != "x" ];then
sed -i -r -e 's!'$OCENTOSMIRROR'!'$NCENTOSMIRROR'!g' $( find /etc/yum.repos.d -type f; )
fi
sed -i "s/^#.*baseurl=http/baseurl=http/g" $( find /etc/yum.repos.d -type f; )
sed -i "s/^mirrorlist=http/#mirrorlist=http/g" $( find /etc/yum.repos.d -type f; )
fi
if ( grep -q amzn /etc/os-release );then
yuminstall findutils
if ( amazon-linux-extras help >/dev/null 2>&1 );then
amazon-linux-extras install -y epel
else
yum install -y epel-release
yum-config-manager --enable epel
if ( yum list | grep -q epel );then
yum install -y epel-release
yum-config-manager --enable epel
fi
fi
fi
if [ -e /etc/redhat-release ];then
if [ -e /etc/fedora-release ];then
vv yum upgrade -y --nogpg fedora-gpg-keys fedora-repos
fi
if [ ! -e /etc/yum.repos.d/epel.repo ];then
rpm="epel-release-latest-${DISTRIB_MAJOR}.noarch.rpm"
curl -sSLO "https://dl.fedoraproject.org/pub/epel/$rpm"
rpm -ivh $(pwd)/$rpm
curl -sSLO "$EPEL_RPM_URL"
rpm -ivh $(pwd)/$(basename $EPEL_RPM_URL)
fi
if ! ( find --version >/dev/null 2>&1);then
yuminstall findutils
fi
fi
DEBIAN_OLDSTABLE=8
DEBIAN_OLDSTABLE=9
PG_DEBIAN_OLDSTABLE=9
find /etc -name "*.reactivate" | while read f;do
mv -fv "$f" "$(basename $f .reactivate)"
done
Expand All @@ -91,11 +124,14 @@ if (echo $DISTRIB_ID | grep -E -iq "debian");then
if (echo $DISTRIB_RELEASE | grep -E -iq stretch );then DISTRIB_CODENAME="$DISTRIB_RELEASE";DISTRIB_RELEASE="9" ;fi
if (echo $DISTRIB_RELEASE | grep -E -iq buster );then DISTRIB_CODENAME="$DISTRIB_RELEASE";DISTRIB_RELEASE="10";fi
if (echo $DISTRIB_RELEASE | grep -E -iq bullseye );then DISTRIB_CODENAME="$DISTRIB_RELEASE";DISTRIB_RELEASE="11";fi
if (echo $DISTRIB_RELEASE | grep -E -iq bookworm );then DISTRIB_CODENAME="$DISTRIB_RELEASE";DISTRIB_RELEASE="12";fi
fi
sed -i -re "s/(old)?oldstable/$DISTRIB_CODENAME/g" $(find /etc/apt/sources.list* -type f)
NAPTMIRROR="http.debian.net|httpredir.debian.org|deb.debian.org"
NAPTMIRROR="${NDEBIANMIRROR}"
SNAPTMIRROR="${SNDEBIANMIRROR}"
elif ( echo $DISTRIB_ID | grep -E -iq "mint|ubuntu" );then
NAPTMIRROR="archive.ubuntu.com|security.ubuntu.com"
NAPTMIRROR="${NUBUNTUMIRROR}"
SNAPTMIRROR="${SNUBUNTUMIRROR}"
fi
DEBIAN_LTS_SOURCELIST="
deb http://security.debian.org/ $DISTRIB_CODENAME/updates main contrib non-free
Expand Down Expand Up @@ -123,37 +159,62 @@ if ( echo $DISTRIB_ID | grep -E -iq "centos|red|fedora" ) && ! ( echo $DISTRIB_I
fi
if ( echo $DISTRIB_ID | grep -E -iq "debian|mint|ubuntu" );then
if (echo $DISTRIB_ID|grep -E -iq debian);then
sed -i -r -e '/(((squeeze)-(lts))|testing-backports)/d' \
$( find /etc/apt/sources.list* -type f; )
sed -i -r -e '/(((squeeze)-(lts))|testing-backports)/d' $( find /etc/apt/sources.list* -type f; )
fi
if (echo $DISTRIB_ID|grep -E -iq debian) && [ $DISTRIB_RELEASE -le $DEBIAN_OLDSTABLE ];then
# fix old debian unstable images
sed -i -re "s!sid(/)?!$DISTRIB_CODENAME\1!" $(find /etc/apt/sources.list* -type f)
OAPTMIRROR="archive.debian.org"
sed -i -r -e '/-updates|security.debian.org/d' \
$( find /etc/apt/sources.list* -type f; )
if (echo $DISTRIB_ID|grep -E -iq debian) && [ $DISTRIB_RELEASE -eq $DEBIAN_OLDSTABLE ];then
OAPTMIRROR="${OAPTMIRROR:-$ODEBIANMIRROR}"
sed -i -r -e '/-updates|security.debian.org/d' $( find /etc/apt/sources.list* -type f; )
if (echo $DISTRIB_ID|grep -E -iq debian) && [ $DISTRIB_RELEASE -eq $DEBIAN_OLDSTABLE ] && [ $DEBIAN_OLDSTABLE -lt 9 ];then
log "Using debian LTS packages"
echo "$DEBIAN_LTS_SOURCELIST" >> /etc/apt/sources.list
rm -rvf /var/lib/apt/*
fi
fi
if ( echo $DISTRIB_ID | grep -E -iq "mint|ubuntu" ) && \
( echo $DISTRIB_RELEASE |grep -E -iq $oldubuntu);then
OAPTMIRROR="old-releases.ubuntu.com"
sed -i -r \
-e 's/^(deb.*ubuntu)\/?(.*-(security|backport|updates).*)/#\1\/\2/g' \
-e 's!'$NAPTMIRROR'!'$OAPTMIRROR'!g' \
$( find /etc/apt/sources.list* -type f; )
if ( echo $DISTRIB_ID | grep -E -iq "mint|ubuntu" ) && ( echo $DISTRIB_RELEASE |grep -E -iq $oldubuntu);then
OAPTMIRROR="${OAPTMIRROR:-$OUBUNTUMIRROR}"
fi
if (echo $DISTRIB_ID|grep -E -iq debian) && [ -e $pglist ] && [ $DISTRIB_RELEASE -le $PG_DEBIAN_OLDSTABLE ] && [ -e /etc/apt/sources.list.d/pgdg.list ];then
sed -i -re "s/apt.postgresql/apt-archive.postgresql/g" -e "s/http:/https:/g" /etc/apt/sources.list.d/pgdg.list
fi
if [ "x$OAPTMIRROR" != "x" ];then
printf 'Acquire::Check-Valid-Until no;\nAPT{ Get { AllowUnauthenticated "1"; }; };\n\n'>/etc/apt/apt.conf.d/nogpgverif
# 16.04/14.04 is not yet on old mirrors and were switched back to regular mirrors
if (echo $DISTRIB_RELEASE |grep -E -iq "14.04|16.04|18.04");then
echo "Patching APT to use $SNAPTMIRROR" >&2
sed -i -r \
-e 's/^(deb.*ubuntu)\/?(.*-(security|backport|updates).*)/#\1\/\2/g' \
-e 's!'$OAPTMIRROR'!'$SNAPTMIRROR'!g' \
$( find /etc/apt/sources.list* -type f; )
echo "deb http://$SNAPTMIRROR/ubuntu/ $DISTRIB_CODENAME-security main restricted universe multiverse" >> /etc/apt/sources.list
else
echo "Patching APT to use $OAPTMIRROR" >&2
sed -i -r \
-e 's/^(deb.*ubuntu)\/?(.*-(security|backport|updates).*)/#\1\/\2/g' \
-e 's!'$NAPTMIRROR'!'$OAPTMIRROR'!g' \
$( find /etc/apt/sources.list* -type f; )
fi
fi
if (echo $DISTRIB_RELEASE |grep -E -iq "18.04") && (grep -q cuda $(find /etc/apt/sources.list* -type f));then
wget https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64/cuda-keyring_1.0-1_all.deb || curl -O https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64/cuda-keyring_1.0-1_all.deb
dpkg -i cuda-keyring_1.0-1_all.deb
sed -i -re "/cuda/d" /etc/apt/sources.list
rm -f /etc/apt/sources.list.d/cuda-ubuntu1804-x86_64.list || true
apt-key adv --keyserver keyserver.ubuntu.com --recv A4B469963BF863CC F60F4B3D7FA2AF80
fi
if ( (echo $DISTRIB_ID|grep -E -iq "mint|ubuntu" ) && ( echo $DISTRIB_RELEASE |grep -E -iq $oldubuntu); ) ||\
( (echo $DISTRIB_ID|grep -E -iq debian) && [ $DISTRIB_RELEASE -le $DEBIAN_OLDSTABLE ]; ) ||\
( (echo $DISTRIB_ID|grep -E -iq debian) && [ -e $pglist ] && [ $DISTRIB_RELEASE -le $PG_DEBIAN_OLDSTABLE ]; );then
if (dpkg -l|grep -vq apt-transport-https);then sed -i -re "s/^(deb.*https:.*)/#\1 #httpsfix/g" $(find /etc/apt/sources.list* -type f);fi
apt-get update || true
if ! (apt-get install -y ca-certificates apt-transport-https apt bzip2);then
apt-get full-upgrade -y
apt-get install -y ca-certificates apt-transport-https apt bzip2
fi
sed -i -re "s/^#(.*)#httpsfix/\1/g" $(find /etc/apt/sources.list* -type f)
apt-get update
fi
fi

if [ "x$OAPTMIRROR" != "x" ];then
echo "Patching APT to use $OAPTMIRROR" >&2
printf 'Acquire::Check-Valid-Until "0";\n' \
> /etc/apt/apt.conf.d/noreleaseexpired.conf
sed -i -r -e 's!'$NAPTMIRROR'!'$OAPTMIRROR'!g' \
$( find /etc/apt/sources.list* -type f; )
fi
# fix broken curl if needed
curl_updated=
Expand Down Expand Up @@ -205,9 +266,15 @@ fi
if ( echo "$DISTRIB_ID $DISTRIB_RELEASE $DISTRIB_CODENAME" | grep -E -iq alpine );then
log "Upgrading alpine"
apk update && apk add bash
apk upgrade --update-cache --available
if !(apk upgrade --update-cache --available);then
apk upgrade --update-cache && apk upgrade --update-cache --available
fi
fi
./bin/fix_letsencrypt.sh
if ( echo $DISTRIB_ID | grep -E -iq "centos|red|fedora|amzn" );then
# ensure no conflict between curl & curl-minimal
yum install -y --allowerasing curl || yum install -y curl
fi
export FORCE_INSTALL=y
DO_UPDATE="$DO_UPDATE" WANTED_PACKAGES="$pkgs" ./cops_pkgmgr_install.sh
install_gpg
Expand All @@ -219,4 +286,4 @@ if ! ( echo foo|envsubst >/dev/null 2>&1);then
fi
fi
find /etc/rsyslog.d -name "*.conf" -not -type d |while read f;do mv -vf "$f" "$f.sample";done
# vim:set et sts=4 ts=4 tw=0:
# Vim:set et sts=4 ts=4 tw=0:
16 changes: 14 additions & 2 deletions library/amazonlinux/1-with-sources/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,9 +1,12 @@
FROM library/amazonlinux:1-with-sources
ARG ANCESTOR=library/amazonlinux:1-with-sources
ARG RSYNC=corpusops/rsync
FROM library/amazonlinux:1-with-sources AS final
ARG DO_UPDATE=y
ARG NONINTERACTIVE=y
ARG DEBIAN_FRONTEND=noninteractive
ARG INSTALL_DEFAULT_LOCALE="fr_FR.UTF-8"
ARG EXTRA_FILES_LIST=""
ARG COPS_SYSTEM=${_cops_SYSTEM}
ARG COPS_SYSTEM=${_cops_SYSTEM-}
ARG FOREGO_RELEASE=latest
ARG REMCO_RELEASE=latest
ARG GOSU_RELEASE=latest
Expand Down Expand Up @@ -82,4 +85,13 @@ RUN sh -c 'set -ex \
&& ./${_cops_SYSTEM}_clean.sh \
&& ./common_clean.sh \
&& cd / && rm -rf /tmp/corpusopssteroids /var/cache/apk/* /var/lib/apt/lists/*'
FROM $RSYNC AS squashed-rsync
FROM $ANCESTOR AS squashed-ancestor
ARG ROOTFS="/BASE_ROOTFS_TO_COPY_THAT_WONT_COLLIDE_1234567890"
ARG PATH="${ROOTFS}_rsync/bin:$PATH"
SHELL ["busybox", "sh", "-c"]
RUN --mount=type=bind,from=final,target=$ROOTFS --mount=type=bind,from=squashed-rsync,target=${ROOTFS}_rsync \
rsync -Aaz --delete ${ROOTFS}/ / --exclude=/proc --exclude=/sys --exclude=/etc/resolv.conf --exclude=/etc/hosts --exclude=$ROOTFS* --exclude=dev/shm --exclude=dev/pts --exclude=dev/mqueue
SHELL ["/bin/sh", "-c"]
ARG DOCKER_IMAGES_COMMIT="$DOCKER_IMAGES_COMMIT"
LABEL com.github.corpusops.docker-images-commit="$DOCKER_IMAGES_COMMIT"
Loading

0 comments on commit 9b0ea51

Please sign in to comment.