iankelling.org
/
git
/
automated-distro-installer
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
update to 31b795ca71189b326b80666076398f31aea4f2be
[automated-distro-installer]
/
fai
/
config
/
basefiles
/
mk-basefile
diff --git
a/fai/config/basefiles/mk-basefile
b/fai/config/basefiles/mk-basefile
index ebbe3d9ae43f850a5ec154c7953f4a137cdde95c..be00fe2d6aa997f2dd9766c9f11dec0cc0cdf269 100755
(executable)
--- a/
fai/config/basefiles/mk-basefile
+++ b/
fai/config/basefiles/mk-basefile
@@
-2,13
+2,16
@@
# mk-basefile, create basefiles for some distributions
#
# mk-basefile, create basefiles for some distributions
#
-# Thomas Lange, Uni Koeln, 2011-20
17
+# Thomas Lange, Uni Koeln, 2011-20
20
# based on the Makefile implementation of Michael Goetze
# based on the Makefile implementation of Michael Goetze
+#
+# Usage example: mk-basefile -J STRETCH64
+# This will create a STRETCH64.tar.xz basefile.
# Supported distributions (each i386/amd64):
# Debian GNU/Linux
# Ubuntu 14.04/16.04
# Supported distributions (each i386/amd64):
# Debian GNU/Linux
# Ubuntu 14.04/16.04
-# CentOS 5/6/7
+# CentOS 5/6/7
/8
# Scientific Linux Cern 5/6
#
# Packages you might want to install to use this command:
# Scientific Linux Cern 5/6
#
# Packages you might want to install to use this command:
@@
-17,19
+20,25
@@
# Define your local mirros here
# For the first stage, set the CentOS/SLC mirror in /etc/rinse/rinse.conf
# Define your local mirros here
# For the first stage, set the CentOS/SLC mirror in /etc/rinse/rinse.conf
-MIRROR_DEBIAN=http://
httpredir
.debian.org/debian/
+MIRROR_DEBIAN=http://
deb
.debian.org/debian/
MIRROR_UBUNTU=http://mirror.netcologne.de/ubuntu/
MIRROR_CENTOS=http://mirror.netcologne.de/
MIRROR_UBUNTU=http://mirror.netcologne.de/ubuntu/
MIRROR_CENTOS=http://mirror.netcologne.de/
-EXCLUDE_SQUEEZE=isc-dhcp-client,isc-dhcp-common,info,tasksel,tasksel-data
-EXCLUDE_WHEEZY=info,tasksel,tasksel-data
-EXCLUDE_JESSIE=tasksel,tasksel-data
-EXCLUDE_STRETCH=tasksel,tasksel-data
+EXCLUDE_SQUEEZE=isc-dhcp-client,isc-dhcp-common,info
+EXCLUDE_WHEEZY=info
+EXCLUDE_JESSIE=info
+EXCLUDE_STRETCH=info
+EXCLUDE_BUSTER=
+EXCLUDE_BULLSEYE=
+EXCLUDE_SID=
EXCLUDE_TRUSTY=dhcp3-client,dhcp3-common,info
EXCLUDE_TRUSTY=dhcp3-client,dhcp3-common,info
-EXCLUDE_XENIAL=tasksel,tasksel-data
+EXCLUDE_XENIAL=udhcpc,dibbler-client,info
+EXCLUDE_BIONIC=udhcpc,dibbler-client,info
+EXCLUDE_FOCAL=udhcpc,dibbler-client,info
-INCLUDE_DEBIAN=aptitude
+# here you can add packages, that are needed very early
+INCLUDE_DEBIAN=
setarch() {
setarch() {
@@
-42,7
+51,7
@@
setarch() {
check() {
check() {
- if [
`id -u`
!= 0 ]; then
+ if [
$(id -u)
!= 0 ]; then
echo "You must be root to create chroots."
exit 1
fi
echo "You must be root to create chroots."
exit 1
fi
@@
-66,6
+75,7
@@
check() {
mkpost-centos() {
mkpost-centos() {
+ # set local mirror for rinse post script
[ -z "$MIRROR_CENTOS" ] && return
cat <<EOM > $xtmp/post
#! /bin/sh
[ -z "$MIRROR_CENTOS" ] && return
cat <<EOM > $xtmp/post
#! /bin/sh
@@
-79,6
+89,7
@@
EOM
mkpost-slc() {
mkpost-slc() {
+ # set local mirror for rinse post script
ver=$1
[ -z "$MIRROR_SLC" ] && return
cat <<EOM > $xtmp/post
ver=$1
[ -z "$MIRROR_SLC" ] && return
cat <<EOM > $xtmp/post
@@
-95,10
+106,11
@@
EOM
cleanup-deb() {
cleanup-deb() {
- chroot $xtmp aptitude clean
- rm -f $xtmp/etc/hostname $xtmp/etc/resolv.conf $xtmp/etc/machine-id
- rm $xtmp/var/lib/apt/lists/*_*
- rm -f $xtmp/etc/udev/rules.d/70-persistent-net.rules
+ chroot $xtmp apt-get clean
+ rm -f $xtmp/etc/hostname $xtmp/etc/resolv.conf \
+ $xtmp/var/lib/apt/lists/*_* $xtmp/usr/bin/qemu-*-static \
+ $xtmp/etc/udev/rules.d/70-persistent-net.rules
+ > $xtmp/etc/machine-id
}
}
@@
-120,7
+132,7
@@
cleanup-rinse() {
tarit() {
tarit() {
- tar $attributes --one-file-system -C $xtmp -cf - . | $zip > $target.$ext
+ tar $attributes --
numeric-owner --
one-file-system -C $xtmp -cf - . | $zip > $target.$ext
}
}
@@
-159,19
+171,30
@@
debgeneric() {
local DIST=$1
shift
local mirror=$1
local DIST=$1
shift
local mirror=$1
+ shift
+ local arch=$1
- if [[ $DIST =~ 64 ]]; then
- arch=amd64
- else
- arch=i386
- fi
-
- DIST=${DIST%%??}
- dist=${DIST,,}
+ dist=${DIST%%[0-9][0-9]}
+ local exc="EXCLUDE_$dist"
+ [ -n "${!exc}" ] && exc="--exclude=${!exc}" || unset exc
+ dist=${dist,,}
- local exc="EXCLUDE_$DIST"
check
check
- debootstrap --arch $arch --exclude=${!exc} --include=${INCLUDE_DEBIAN} $dist $xtmp $mirror
+ if [ -n "$INCLUDE_DEBIAN" ]; then
+ local inc="--include=$INCLUDE_DEBIAN"
+ fi
+
+ if [ -n "$arch" ]; then
+ qemu-debootstrap --arch $arch ${exc} $inc $dist $xtmp $mirror
+ target="${target}_${arch^^}"
+ else
+ if [[ $DIST =~ 64 ]]; then
+ arch=amd64
+ else
+ arch=i386
+ fi
+ debootstrap --arch $arch ${exc} $inc $dist $xtmp $mirror
+ fi
cleanup-deb
tarit
}
cleanup-deb
tarit
}
@@
-183,15
+206,21
@@
prtdists() {
CENTOS5_32 CENTOS5_64
CENTOS6_32 CENTOS6_64
CENTOS7_32 CENTOS7_64
CENTOS5_32 CENTOS5_64
CENTOS6_32 CENTOS6_64
CENTOS7_32 CENTOS7_64
+ CENTOS8_64
SLC5_32 SLC5_64
SLC6_32 SLC6_64
SLC7_64
TRUSTY32 TRUSTY64
XENIAL32 XENIAL64
SLC5_32 SLC5_64
SLC6_32 SLC6_64
SLC7_64
TRUSTY32 TRUSTY64
XENIAL32 XENIAL64
+ BIONIC64
+ FOCAL64
SQUEEZE32 SQUEEZE64
WHEEZY32 WHEEZY64
JESSIE32 JESSIE64
STRETCH32 STRETCH64
SQUEEZE32 SQUEEZE64
WHEEZY32 WHEEZY64
JESSIE32 JESSIE64
STRETCH32 STRETCH64
+ BUSTER32 BUSTER64
+ BULLSEYE32 BULLSEYE64
+ SID32 SID64
"
}
"
}
@@
-200,12
+229,12
@@
usage() {
cat <<EOF
mk-basefile, create minimal base files for a Linux distritubtion
cat <<EOF
mk-basefile, create minimal base files for a Linux distritubtion
- Copyright (C) 2011-20
16
by Thomas Lange
+ Copyright (C) 2011-20
20
by Thomas Lange
Usage: mk-basefile [OPTION] ... DISTRIBUTION
-s Show list of supported linux distributions
Usage: mk-basefile [OPTION] ... DISTRIBUTION
-s Show list of supported linux distributions
- -
a Add xtattrs, acl and selinux properties to the tar file
.
+ -
f ARCH Build for foreign architecture ARCH
.
-d DIR Use DIR for creating the temporary subtree structure.
-z Use gzip for compressing the tar file.
-J Use xz for compressing the tar file.
-d DIR Use DIR for creating the temporary subtree structure.
-z Use gzip for compressing the tar file.
-J Use xz for compressing the tar file.
@@
-225,11
+254,13
@@
ext=tar
zip=cat
attributes=
cleanup=1
zip=cat
attributes=
cleanup=1
+attributes="--xattrs --selinux --acls"
-while getopts ashzJd:k opt ; do
+while getopts ashzJd:k
f:
opt ; do
case "$opt" in
case "$opt" in
- a)
attributes="--xattrs --selinux --acl
" ;;
+ a)
echo "$0: Warning. -a is ignored, because xtattrs, acls and selinux are always added.
" ;;
d) export TMPDIR=$OPTARG ;;
d) export TMPDIR=$OPTARG ;;
+ f) export ARCH=$OPTARG ;;
z) zip="gzip -9"; ext=tar.gz ;;
J) zip="xz -8" ext=tar.xz ;;
k) cleanup=0 ;;
z) zip="gzip -9"; ext=tar.gz ;;
J) zip="xz -8" ext=tar.xz ;;
k) cleanup=0 ;;
@@
-238,7
+269,7
@@
while getopts ashzJd:k opt ; do
?) exit 3 ;; # error in option parsing
esac
done
?) exit 3 ;; # error in option parsing
esac
done
-shift $((
$
OPTIND - 1))
+shift $((OPTIND - 1))
xtmp=$(mktemp --tmpdir -d basefiles.XXXXXXXX)
if [ $? -eq 1 ]; then
xtmp=$(mktemp --tmpdir -d basefiles.XXXXXXXX)
if [ $? -eq 1 ]; then
@@
-249,6
+280,7
@@
chmod 755 $xtmp
target=$1 # also the name of the output file
target=$1 # also the name of the output file
+[ -z "$target" ] && usage
case "$target" in
CENTOS5_32) centos i386 5 ;;
CENTOS5_64) centos amd64 5 ;;
case "$target" in
CENTOS5_32) centos i386 5 ;;
CENTOS5_64) centos amd64 5 ;;
@@
-256,15
+288,16
@@
case "$target" in
CENTOS6_64) centos amd64 6 ;;
CENTOS7_32) centos i386 7 ;;
CENTOS7_64) centos amd64 7 ;;
CENTOS6_64) centos amd64 6 ;;
CENTOS7_32) centos i386 7 ;;
CENTOS7_64) centos amd64 7 ;;
+ CENTOS8_64) centos amd64 8 ;;
SLC5_32) slc i386 5 ;;
SLC5_64) slc amd64 5 ;;
SLC6_32) slc i386 6 ;;
SLC6_64) slc amd64 6 ;;
SLC7_64) slc amd64 7 ;;
SLC5_32) slc i386 5 ;;
SLC5_64) slc amd64 5 ;;
SLC6_32) slc i386 6 ;;
SLC6_64) slc amd64 6 ;;
SLC7_64) slc amd64 7 ;;
- TRUSTY*|XENIAL*)
+ TRUSTY*|XENIAL*
|BIONIC*|FOCAL*
)
debgeneric $target $MIRROR_UBUNTU ;;
debgeneric $target $MIRROR_UBUNTU ;;
- SQUEEZE*|WHEEZY*|JESSIE*|STRETCH*)
- debgeneric $target $MIRROR_DEBIAN ;;
+ SQUEEZE*|WHEEZY*|JESSIE*|STRETCH*
|BUSTER*|BULLSEYE*|SID*
)
+ debgeneric $target $MIRROR_DEBIAN
$ARCH
;;
*) echo "Unknown distribution. Aborting."
prtdists
exit 99 ;;
*) echo "Unknown distribution. Aborting."
prtdists
exit 99 ;;