You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

105 lines
3.5 KiB

9 years ago
9 years ago
  1. #!/bin/bash
  2. # create-arista-veos-image.sh V1.0
  3. # HS-Fulda - sebastian.rieger@informatik.hs-fulda.de
  4. # usage
  5. if [ ! $# -eq 3 ] ; then
  6. echo -e "usage: $0 <Aboot-veos-serial-version.iso> <vEOS-version.vmdk> <new glance image name>, e.g.:\n"
  7. echo "$0 Aboot-veos-serial-2.0.8.iso vEOS-4.13.4F.vmdk vEOS"
  8. exit -1
  9. fi
  10. # sudo check
  11. if [ ! $UID -eq 0 ] ; then
  12. echo "Insufficient privileges. Please consider using sudo."
  13. exit -1
  14. fi
  15. ABOOT_SERIAL_ISO=$1
  16. ABOOT_SERIAL_ISO_BASENAME=$(basename -s .iso $1)
  17. VEOS_VMDK=$2
  18. VEOS_VMDK_BASENAME=$(basename -s .vmdk $2)
  19. GLANCE_IMAGE_NAME=$3
  20. GLANCE_IMAGE_RELEASE=$VEOS_VMDK_BASENAME-$ABOOT_SERIAL_ISO_BASENAME
  21. TMP_NAME="vEOS-$GLANCE_IMAGE_RELEASE"
  22. echo "Creating vEOS image..."
  23. echo "==========================================================="
  24. # create a copy of Aboot bootloader and extend it to 3G
  25. cp $1 $TMP_NAME.raw
  26. truncate -s +3G $TMP_NAME.raw
  27. echo "Extracting partitions from vEOS vmdk..."
  28. echo "==========================================================="
  29. # convert vmdk to raw and extract two partitions in it
  30. qemu-img convert -O raw $2 $VEOS_VMDK_BASENAME.raw
  31. kpartx -av $VEOS_VMDK_BASENAME.raw
  32. dd if=/dev/loop0p1 of=$VEOS_VMDK_BASENAME-p1.raw
  33. dd if=/dev/loop0p2 of=$VEOS_VMDK_BASENAME-p2.raw
  34. kpartx -d $VEOS_VMDK_BASENAME.raw
  35. echo "Injecting new partitions from vEOS vmdk in Aboot image..."
  36. echo "==========================================================="
  37. # calulate size of the two partitions
  38. PART1_START=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw1" | tr -s " " | cut -d ' ' -f 3)
  39. PART1_END=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw1" | tr -s " " | cut -d ' ' -f 4)
  40. PART1_LENGTH=$(expr $PART1_END - $PART1_START)
  41. PART2_START=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw2" | tr -s " " | cut -d ' ' -f 2)
  42. PART2_END=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw2" | tr -s " " | cut -d ' ' -f 3)
  43. PART2_LENGTH=$(expr $PART2_END - $PART2_START)
  44. # append the two partitions from vmdk in the bootloader iso
  45. echo -e "n
  46. p
  47. +$PART1_LENGTH
  48. t
  49. 2
  50. c
  51. a
  52. 2
  53. n
  54. p
  55. +$PART2_LENGTH
  56. t
  57. 3
  58. 12
  59. w" | fdisk $TMP_NAME.raw >/dev/null
  60. # copy the partitions from vEOS vmdk to new image
  61. kpartx -av $TMP_NAME.raw
  62. dd if=$VEOS_VMDK_BASENAME-p1.raw of=/dev/loop0p2
  63. dd if=$VEOS_VMDK_BASENAME-p2.raw of=/dev/loop0p3
  64. kpartx -d $TMP_NAME.raw
  65. echo "Convert new image to qcow2..."
  66. echo "==========================================================="
  67. # convert raw to qcow2
  68. qemu-img convert -O qcow2 $TMP_NAME.raw $TMP_NAME.qcow2
  69. echo "Cleaning up..."
  70. echo "==========================================================="
  71. #cleanup
  72. rm $TMP_NAME.raw
  73. rm $VEOS_VMDK_BASENAME-p1.raw
  74. rm $VEOS_VMDK_BASENAME-p2.raw
  75. rm $VEOS_VMDK_BASENAME.raw
  76. echo "Importing image into glance..."
  77. echo "==========================================================="
  78. glance image-create --container-format bare --disk-format qcow2 --is-public true --name $GLANCE_IMAGE_NAME --file $TMP_NAME.qcow2 --property hw_disk_bus=ide --property serial=1 --property hw_vif_model=e1000 --property hw_cdrom_type=ide --property release="$GLANCE_IMAGE_RELEASE" --property subtype=IOSv --property config_disk_type=cdrom
  79. #testing:
  80. #
  81. # nova boot --image "Arista vEOS Disk" --flavor m1.small veos --nic net-id=abc7ad47-55fd-4396-8d31-91dd4d41a18a --nic net-id=abc7ad47-55fd-4396-8d31-91dd4d41a18a --nic net-id=abc7ad47-55fd-4396-8d31-91dd4d41a18a --nic net-id=abc7ad47-55fd-4396-8d31-91dd4d41a18a --nic net-id=abc7ad47-55fd-4396-8d31-91dd4d41a18a
  82. #
  83. # using VM Maestro, the image can be chosen as "VM image", e.g., for an IOSv or IOSvL2 node