]>
git.madduck.net Git - code/vinst.git/blobdiff - vinst
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
# defaults
RAM=512
DISK=20
# defaults
RAM=512
DISK=20
STORAGE_POOL=default
QEMU_URI=qemu:///system
STORAGE_POOL=default
QEMU_URI=qemu:///system
CONSOLE='console=tty0 console=ttyS0,115200n8'
CONSOLE='console=tty0 console=ttyS0,115200n8'
+DEBUG=0
+WIPE=0
+RESTART=0
while [ -n "$1" ]; do
case "$1" in
while [ -n "$1" ]; do
case "$1" in
+ (--debug)
+ DEBUG=1
+ ;;
+ (-S|--suite)
+ shift
+ if [ -z "$1" ]; then
+ echo >&2 'E: --suite/-S needs suite argument'
+ exit 1
+ fi
+ SUITE="$1"
+ ;;
(-n|--name)
shift
if [ -z "$1" ]; then
(-n|--name)
shift
if [ -z "$1" ]; then
+ (-d|--dns)
+ shift
+ if [ -z "$1" ]; then
+ echo >&2 'E: --dns/-d needs IP address'
+ exit 1
+ fi
+ NAMESERVER="$1"
+ ;;
+ (-g|--gateway)
+ shift
+ if [ -z "$1" ]; then
+ echo >&2 'E: --gateway/-g needs IP address'
+ exit 1
+ fi
+ GATEWAY="$1"
+ ;;
(-r|--ram)
shift
if [ -z "$1" ]; then
(-r|--ram)
shift
if [ -z "$1" ]; then
+ (-a|--arch)
+ shift
+ if [ -z "$1" ]; then
+ echo >&2 'E: --arch/-a needs arch argument'
+ exit 1
+ fi
+ ARCH="$1"
+ ;;
+ (-m|--mac)
+ shift
+ if [ -z "$1" ]; then
+ echo >&2 'E: --mac/-m needs mac address argument'
+ exit 1
+ fi
+ MAC="$1"
+ ;;
+ (-c|--cpus)
+ shift
+ if [ -z "$1" ]; then
+ echo >&2 'E: --cpus/-c needs integer argument'
+ exit 1
+ fi
+ CPUS="$1"
+ ;;
+ (--debug)
+ DEBUG=1
+ set -vx
+ ;;
+ (--wipe)
+ WIPE=1
+ ;;
+ (--restart)
+ RESTART=1
+ ;;
tmpdir=$(mktemp -d)
tar -C $BASEDIR/preseed/$SUITE -cf $tmpdir/commands.tar commands
tmpdir=$(mktemp -d)
tar -C $BASEDIR/preseed/$SUITE -cf $tmpdir/commands.tar commands
-extra_args="auto $CONSOLE \
-hostname=${HOSTNAME%%.*} \
-domain=${HOSTNAME#*.}"
+extra_kargs="auto $CONSOLE \
+netcfg/hostname=${HOSTNAME%%.*} \
+netcfg/domain=${HOSTNAME#*.}"
+
+extra_opts=
+if [ -n "$DEBUG" ]; then
+ extra_opts='--debug'
+fi
if [ -n "$IPADDRESS" ]; then
if [ -n "$IPADDRESS" ]; then
- if [ -z "$GATEWAY" ]; then
+ if [ -z "$GATEWAY" ] && [ -x $(command -v ipcalc) ] ; then
# default to the first IP in the network
GATEWAY=$(ipcalc $IPADDRESS | grep HostMin | awk '{print $2}')
fi
# default to the first IP in the network
GATEWAY=$(ipcalc $IPADDRESS | grep HostMin | awk '{print $2}')
fi
IPADDRESS="${IPADDRESS%/*}"
: ${NAMESERVER:=$GATEWAY}
IPADDRESS="${IPADDRESS%/*}"
: ${NAMESERVER:=$GATEWAY}
- extra_args="$extra_ args netcfg/disable_dhcp=true \
+ extra_kargs="$extra_k args netcfg/disable_dhcp=true \
netcfg/get_ipaddress=$IPADDRESS \
netcfg/get_netmask=$NETMASK \
netcfg/get_gateway=$GATEWAY \
netcfg/get_nameservers=$NAMESERVER"
netcfg/get_ipaddress=$IPADDRESS \
netcfg/get_netmask=$NETMASK \
netcfg/get_gateway=$GATEWAY \
netcfg/get_nameservers=$NAMESERVER"
- extra_args="$extra_args netcfg/disable_dhcp=false"
+ extra_kargs="$extra_kargs netcfg/disable_dhcp=false"
+ BRIDGE=virt-br
+fi
+
+if [ -z "$ARCH" ]; then
+ ARCH=$(dpkg --print-architecture)
+fi
+
+if [ -z "$MAC" ]; then
+ bytes=$(dd status=noxfer if=/dev/urandom bs=3 count=1 | hexdump -v -e '/1 ":%02X"')
+ MAC=52:54:00$bytes
fi
cat >&2 <<_eof
hostname: $HOSTNAME
fi
cat >&2 <<_eof
hostname: $HOSTNAME
+ arch: $ARCH
+ suite: $SUITE
ram: $RAM MiB
disk: $DISK GiB
ram: $RAM MiB
disk: $DISK GiB
+ cpus: $CPUS
+ wipe: $WIPE
+ restart: $RESTART
+net bridge: $BRIDGE
+macaddress: $MAC
_eof
if [ -n "$IPADDRESS" ]; then
cat >&2 <<_eof
_eof
if [ -n "$IPADDRESS" ]; then
cat >&2 <<_eof
+echo >&2
+
+virsh --connect=$QEMU_URI vol-create-as $STORAGE_POOL virt-$HOSTNAME ${DISK}G
+if [ $WIPE = 1 ]; then
+ echo >&2 "Wiping disk…"
+ virsh --connect=$QEMU_URI vol-wipe --pool $STORAGE_POOL --algorithm zero virt-$HOSTNAME
+fi
+
+if [ $DEBUG = 1 ]; then
+ DEBUGFLAG=--debug
+ extra_args="$extra_args DEBCONF_DEBUG=5"
+fi
-exec virt-install --connect=$QEMU_URI \
+virt-install --connect=$QEMU_URI \
+ ${DEBUGFLAG:-} \
- --disk pool=default,size=$SIZ E \
- -w bridge=virt-br \
+ --disk vol=$STORAGE_POOL/virt-$HOSTNAM E \
+ --network bridge=$BRIDGE,mac=$MAC \
--graphics=vnc \
--serial=pty \
--watchdog i6300esb,action=reset \
--graphics=vnc \
--serial=pty \
--watchdog i6300esb,action=reset \
- --os-variant=debian$SUITE \
- -l $BASEDIR/installer-amd64 \
+ --os-variant=debianwheezy \
--initrd-inject=$BASEDIR/preseed/$SUITE/preseed.cfg \
--initrd-inject=$tmpdir/commands.tar \
--initrd-inject=$BASEDIR/preseed/$SUITE/preseed.cfg \
--initrd-inject=$tmpdir/commands.tar \
- --extra-args="$extra_args" \
- --autostart \
+ --extra-args="$extra_kargs" \
+ --prompt --noautoconsole --autostart $extra_opts \
+ -l $BASEDIR/installer-amd64/$SUITE \
+
+virsh --connect=$QEMU_URI console $HOSTNAME
+
+if [ $RESTART = 1 ]; then
+ sleep 5
+ virsh --connect=$QEMU_URI "start $HOSTNAME; console $HOSTNAME"
+fi