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
fixes and remove some jessie stuff
[automated-distro-installer]
/
pxe-server
diff --git
a/pxe-server
b/pxe-server
index 6137386a1188d9ab9c50e4bee783e7ee57dfc053..5a157636b943f8eed2e65d2177eb5f14aef7086b 100755
(executable)
--- a/
pxe-server
+++ b/
pxe-server
@@
-61,6
+61,11
@@
EOF
exit $1
}
exit $1
}
+pre="${0##*/}:"
+m() { printf "$pre %s\n" "$*"; "$@"; }
+e() { printf "$pre %s\n" "$*"; }
+err() { echo "[$(date +'%Y-%m-%d %H:%M:%S%z')]: $pre: $*" >&2; }
+
##### begin command line parsing ########
dhcp=true
##### begin command line parsing ########
dhcp=true
@@
-70,7
+75,7
@@
wait=false
fsf=false
case $HOSTNAME in
fsf=false
case $HOSTNAME in
- x
2|x
3|kw) fsf=true ;;
+ x3|kw) fsf=true ;;
esac
chboot_args=()
esac
chboot_args=()
@@
-125,16
+130,11
@@
fi
##### end command line parsing ########
##### end command line parsing ########
-e() {
- echo "$@"
- "$@"
-}
-
archlike() {
cat <<EOF
archlike() {
cat <<EOF
-
dhcp-option-force=
209,boot/syslinux/${type}iso.cfg
-
dhcp-option-force=
210,/${type}/
-
dhcp-boot=${host_tag}
/${type}/boot/syslinux/lpxelinux.0
+
${host_tag}
209,boot/syslinux/${type}iso.cfg
+
${host_tag}
210,/${type}/
+
${host_tag}option:bootfile-name,
/${type}/boot/syslinux/lpxelinux.0
EOF
}
EOF
}
@@
-142,28
+142,35
@@
plain() {
# if arch based was used before, this additionally needs
# the tftp link in /mnt/usb to be changed.
cat <<EOF
# if arch based was used before, this additionally needs
# the tftp link in /mnt/usb to be changed.
cat <<EOF
-
dhcp-boot=${host_tag}
pxelinux.0
+
${host_tag}option:bootfile-name,
pxelinux.0
EOF
}
fai() {
cat <<EOF
EOF
}
fai() {
cat <<EOF
-dhcp-boot=${host_tag}pxelinux.0,faiserver.b8.nz,faiserver.b8.nz
+${host_tag}option:bootfile-name,pxelinux.0
+${host_tag}option:server-ip-address,$faiserverip
+${host_tag}option:tftp-server,$faiserverip
EOF
EOF
+ # Note, previously used normal dnsmasq option, but it requires dnsmasq
+ # restart, which causes momentary dns failures, which can bork an
+ # install.
+ #
+ # dhcp-boot=${host_tag}pxelinux.0,faiserver.b8.nz,faiserver.b8.nz
}
ack-wait() {
if $fsf; then
}
ack-wait() {
if $fsf; then
- wait_cmd="ssh tarantula tail -n0 -f /var/log/syslog"
+ wait_cmd="ssh tarantula
.office.fsf.org
tail -n0 -f /var/log/syslog"
else
else
- wait_cmd="ssh
wrt
logread -f"
+ wait_cmd="ssh
cmc
logread -f"
fi
wait_count=$1
if [[ $host ]]; then
if $fsf; then
host_regex=" $(getent hosts kw | awk '{print $1}' | sed 's/\./\\./g')"
fi
wait_count=$1
if [[ $host ]]; then
if $fsf; then
host_regex=" $(getent hosts kw | awk '{print $1}' | sed 's/\./\\./g')"
-
else
- host_regex=" $host"
+ else
+
host_regex=" $host"
fi
fi
regex=".*DHCPACK.*$host_regex\b"
fi
fi
regex=".*DHCPACK.*$host_regex\b"
@@
-174,41
+181,48
@@
ack-wait() {
echo $line
fi
done < <($wait_cmd ||:) # tail returns 2 it seems
echo $line
fi
done < <($wait_cmd ||:) # tail returns 2 it seems
-
e
sleep 20
+
m
sleep 20
}
set-pxe() {
$dhcp || return 0
if $fsf; then
if [[ ! $cmd ]]; then
}
set-pxe() {
$dhcp || return 0
if $fsf; then
if [[ ! $cmd ]]; then
- e
cho "$0:
removing pxe for $host on tarantula"
- ssh tarantula bash -e <<EOF
+ e
"
removing pxe for $host on tarantula"
+ ssh tarantula
.office.fsf.org
bash -e <<EOF
sed -ri 's/^( *host +$host *\{).*/\1/' /etc/dhcp3/dhcpd.conf
/etc/init.d/dhcp3-server restart
EOF
elif [[ $cmd == fai ]]; then
sed -ri 's/^( *host +$host *\{).*/\1/' /etc/dhcp3/dhcpd.conf
/etc/init.d/dhcp3-server restart
EOF
elif [[ $cmd == fai ]]; then
- e
cho "$0:
adding pxe for $host on tarantula"
- ssh tarantula bash -e <<EOF
+ e
"
adding pxe for $host on tarantula"
+ ssh tarantula
.office.fsf.org
bash -e <<EOF
sed -ri 's/^( *host +$host *\{).*/\1 next-server faiserver.office.fsf.org; filename "pxelinux.0";/' /etc/dhcp3/dhcpd.conf
/etc/init.d/dhcp3-server restart
EOF
fi
else
sed -ri 's/^( *host +$host *\{).*/\1 next-server faiserver.office.fsf.org; filename "pxelinux.0";/' /etc/dhcp3/dhcpd.conf
/etc/init.d/dhcp3-server restart
EOF
fi
else
- e
cho "$0:
updating dnsmasq.conf:"
- $cmd
- ${cmd:-:}|ssh
wrt "cedit pxe /etc/dnsmasq.conf || /etc/init.d/dnsmasq restart
+ e
"
updating dnsmasq.conf:"
+
m
$cmd
+ ${cmd:-:}|ssh
cmc "dd of=/etc/dnsmasq-dhcpopts.conf; /etc/init.d/dnsmasq reload
$([[ $type == arch || $type == parabola ]] && echo archlike-pxe-mount)"
fi
}
$([[ $type == arch || $type == parabola ]] && echo archlike-pxe-mount)"
fi
}
+type -t host &>/dev/null || sudo apt-get -y install dnsutils
+faiserverip=$(host faiserver | sed -rn 's/^\S+ has address //p;T;q' ||:)
+if [[ ! $faiserverip || $faiserverip =~ [[:space:]] ]]; then
+ echo "$0: error: failed to get \$faiserverip, got: $faiserverip"
+ exit 1
+fi
+
if $set; then
set-pxe
if [[ $type == fai ]]; then
if $set; then
set-pxe
if [[ $type == fai ]]; then
- e myfai-chboot ${chboot_args[@]} $host
if $redep; then
if $redep; then
-
e
fai-redep
+
m
fai-redep
fi
fi
+ m myfai-chboot ${chboot_args[@]} $host
else
# This will fail if faiserver is not setup, so ignore any
# failure and don't bother us about it.
else
# This will fail if faiserver is not setup, so ignore any
# failure and don't bother us about it.