-#!/bin/bash -l
+#!/bin/bash
# Copyright (C) 2016 Ian Kelling
# This program is free software; you can redistribute it and/or
-x="$(readlink -f "$BASH_SOURCE")"
-script_dir="${x%/*}"
+readonly this_file="$(readlink -f -- "${BASH_SOURCE[0]}")"
+script_dir="${this_file%/*}"
+# shellcheck source=./bash-trace
source "${script_dir}/bash-trace"
+cd $script_dir
+PATH="$PATH:$PWD"
e() { echo "$*"; "$@"; }
-n Create new qcow2(s) for vm. Good for testing partitioning
script, to ensure a blank disk.
-p Use pxe instead of autodiscover iso with fai.
+-c Use normal fai-cd iso is instead of autodiscover iso.
-r Do not boot after install is complete
-h|--help Print help and exit.
orig_args=("$@")
new_disk=false
pxe=false
-temp=$(getopt -l help dnprh "$@") || usage 1
+iso=autodiscover.iso
+temp=$(getopt -l help dnpcrh "$@") || usage 1
eval set -- "$temp"
while true; do
case $1 in
-d) dhcp_arg=-d; shift ;;
-n) new_disk=true; shift ;;
-p) pxe=true; shift ;;
+ -c) iso=netinst.iso; shift ;;
-r) reboot_arg=--noreboot; shift ;;
-h|--help) usage ;;
--) shift; break ;;
disk_count=1
+if ! ip l show br0 &>/dev/null; then
+ cat <<'EOF'
+fai-rvm error: no bridge detected. add one to interfaces like this:
+iface eth0 inet manual
+iface br0 inet dhcp
+ bridge_ports eth0
+ bridge_stp off
+ bridge_maxwait 0
+EOF
+ exit 1
+fi
+
if [[ $script_dir == /a/bin/* ]]; then
# Copy our script elsewhere so we can develop it
# and save it at the same time it's running
exec /tmp/faifreeze/${BASH_SOURCE##*/} "${orig_args[@]}"
fi
-cd $script_dir
is_arch_revm() {
[[ ${0##*/} == arch-revm ]]
}
-cleanup() {
+err-cleanup() {
echo "doing cleanup"
e ./pxe-server $dhcp_arg
./faiserver-disable
}
-_errcatch_cleanup=cleanup
boot_arg=--pxe
if is_arch_revm; then
e ./pxe-server $dhcp_arg demohost fai
sleep 2
else
- fai-monitor&
+ killall fai-monitor &>/dev/null ||:
+ fai-monitor &
if [[ ! $BASEFILE_DIR ]]; then
BASEFILE_DIR=/tmp
fi
- if [[ ! -e $BASEFILE_DIR/autodiscover.iso ]]; then
- fai-cd -g grub.cfg.autodiscover -f -A $BASEFILE_DIR/autodiscover.iso
+ isopath=$BASEFILE_DIR/$iso
+ isosrc=$BASEFILE_DIR/BUSTER64.tar.gz
+ if [[ ! -e $isopath || $(stat -c %Y $isopath) -lt $(stat -c %Y $isosrc) ]]; then
+ e sudo fai-cd -g $(readlink -f grub.cfg.${iso%%.*}) -f -A $isopath
fi
- boot_arg="--cdrom $BASEFILE_DIR/autodiscover.iso"
+ boot_arg="--cdrom $isopath"
e fai-redep
e myfai-chboot default
fi
name=demohost
-e s virshrm $name ||:
+e sudo virsh destroy $name ||:
+e sudo virsh undefine $name ||:
disk_arg=()
f=/var/lib/libvirt/images/${name}$i
disk_arg+=("--disk path=$f")
if $new_disk || [[ ! -e $f ]]; then
- s rm -f $f
- e s qemu-img create -o preallocation=metadata -f qcow2 $f 50G
+ sudo rm -f $f
+ # https://btrfs.wiki.kernel.org/index.php/FAQ
+ sudo touch $f
+ chattr +C $f
+ e sudo qemu-img create -o preallocation=metadata -f qcow2 $f 50G
fi
done
fi
# docker makes forward default to drop, which blocks the vm pxe on flidas. easiest solution:
-s iptables -P FORWARD ACCEPT
+e sudo iptables -P FORWARD ACCEPT
# --cpu host: this causes mkfs.btrfs to fail with a stack trace which began
# something like:
# init_module+0x108/0x1000 [raid6_pq]
#
# uniq is to stop gtk-warning spam
-# e s virt-install --os-variant $variant -n $name --pxe -r 2048 --vcpus 1 \
+# e sudo virt-install --os-variant $variant -n $name --pxe -r 2048 --vcpus 1 \
# ${disk_arg[*]} -w bridge=br0,mac=52:54:00:9c:ef:ad $reboot_arg \
# --graphics spice,listen=0.0.0.0 $console_arg |& grep -v '^ *$' | uniq &
+cpus=1
+if (( $(nproc) > 2 )); then
+ cpus=2
+fi
-e s virt-install --os-variant $variant -n $name $boot_arg -r 2048 --vcpus 1 \
+e sudo systemctl start libvirtd
+e sudo virt-install --rng /dev/urandom --os-variant $variant -n $name $boot_arg -r 2048 --vcpus $cpus \
${disk_arg[*]} -w bridge=br0,mac=52:54:00:9c:ef:ad $reboot_arg \
--graphics spice,listen=0.0.0.0 $console_arg |& grep -v '^ *$' | uniq &
fg
fi
-sleep 30
+sleep 90
while ! timeout -s 9 10 ssh -oBatchMode=yes root@$name /bin/true; do
e sleep 5
done
-unset _errcatch_cleanup
+unset -f err-cleanup
e ./pxe-server $dhcp_arg
if is_arch_revm; then
./arch-init-remote $name