X-Git-Url: https://git.madduck.net/code/vinst.git/blobdiff_plain/371c3a846758cc0ef0aa0c7ecd9fc5071b7725ad..2fd1f59b2c1e11939a8e4312b0392bc8a803c7da:/vinst diff --git a/vinst b/vinst index c6abe72..f323d56 100755 --- a/vinst +++ b/vinst @@ -9,6 +9,7 @@ STORAGE_POOL=default QEMU_URI=qemu:///system SUITE=wheezy CONSOLE='console=tty0 console=ttyS0,115200n8' +DEBUG=0 while [ -n "$1" ]; do case "$1" in @@ -67,6 +68,17 @@ while [ -n "$1" ]; do fi DISK="$1" ;; + (-a|--arch) + shift + if [ -z "$1" ]; then + echo >&2 'E: --arch/-a needs size argument' + exit 1 + fi + ARCH="$1" + ;; + (--debug) + DEBUG=1 + ;; esac shift done @@ -100,15 +112,24 @@ if [ -n "$IPADDRESS" ]; then netcfg/get_gateway=$GATEWAY \ netcfg/get_nameservers=$NAMESERVER" + BRIDGE=wan + else extra_args="$extra_args netcfg/disable_dhcp=false" + BRIDGE=virt-br +fi + +if [ -z "$ARCH" ]; then + ARCH=$(dpkg --print-architecture) fi cat >&2 <<_eof hostname: $HOSTNAME + arch: $ARCH ram: $RAM MiB disk: $DISK GiB console: $CONSOLE +net bridge: $BRIDGE _eof if [ -n "$IPADDRESS" ]; then cat >&2 <<_eof @@ -123,13 +144,19 @@ else _eof fi -exit 0 +echo >&2 -exec virt-install --connect=$QEMU_URI \ +set -v +virsh --connect=$QEMU_URI vol-create-as $STORAGE_POOL virt-$HOSTNAME ${DISK}G + +[ $DEBUG = 1 ] && DEBUGFLAG=--debug + +virt-install --connect=$QEMU_URI \ + ${DEBUGFLAG:-} \ -n $HOSTNAME \ -r $RAM \ - --disk pool=default,size=$SIZE \ - -w bridge=virt-br \ + --disk vol=$STORAGE_POOL/virt-$HOSTNAME \ + -w bridge=$BRIDGE \ --graphics=vnc \ --serial=pty \ --watchdog i6300esb,action=reset \ @@ -137,6 +164,9 @@ exec virt-install --connect=$QEMU_URI \ -l $BASEDIR/installer-amd64 \ --initrd-inject=$BASEDIR/preseed/$SUITE/preseed.cfg \ --initrd-inject=$tmpdir/commands.tar \ + --noautoconsole --autostart \ --extra-args="$extra_args" \ - --autostart \ "$@" + +virsh --connect=$QEMU_URI console $HOSTNAME +virsh --connect=$QEMU_URI "start $HOSTNAME; console $HOSTNAME"