]>
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:
QEMU_URI=qemu:///system
SUITE=wheezy
CONSOLE='console=tty0 console=ttyS0,115200n8'
QEMU_URI=qemu:///system
SUITE=wheezy
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
+ (-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"
+ ;;
+ (--debug)
+ DEBUG=1
+ set -vx
+ ;;
+ (--wipe)
+ WIPE=1
+ ;;
+ (--restart)
+ RESTART=1
+ ;;
netcfg/get_gateway=$GATEWAY \
netcfg/get_nameservers=$NAMESERVER"
netcfg/get_gateway=$GATEWAY \
netcfg/get_nameservers=$NAMESERVER"
else
extra_args="$extra_args netcfg/disable_dhcp=false"
else
extra_args="$extra_args netcfg/disable_dhcp=false"
+ BRIDGE=virt-br
+fi
+
+if [ -z "$ARCH" ]; then
+ ARCH=$(dpkg --print-architecture)
+fi
+
+if [ -z "$MAC" ]; then
+ bytes=$(dd status=none 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
ram: $RAM MiB
disk: $DISK GiB
ram: $RAM MiB
disk: $DISK GiB
+ 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 \
-l $BASEDIR/installer-amd64 \
--initrd-inject=$BASEDIR/preseed/$SUITE/preseed.cfg \
--initrd-inject=$tmpdir/commands.tar \
-l $BASEDIR/installer-amd64 \
--initrd-inject=$BASEDIR/preseed/$SUITE/preseed.cfg \
--initrd-inject=$tmpdir/commands.tar \
+ --noautoconsole --autostart \
--extra-args="$extra_args" \
--extra-args="$extra_args" \
+
+virsh --connect=$QEMU_URI console $HOSTNAME
+
+if [ $RESTART = 1]; then
+ virsh --connect=$QEMU_URI "start $HOSTNAME; console $HOSTNAME"
+fi