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.

161 lines
5.3 KiB

9 years ago
  1. #!/bin/bash
  2. # create-arista-veos-image.sh V1.12
  3. # HS-Fulda - sebastian.rieger@informatik.hs-fulda.de
  4. #
  5. # changelog:
  6. # V1.1 added injection of config defined in VM Maestro using config-drivex
  7. # V1.11 fixed device mapping of extracted partitions, fixed problems with stale swi directory
  8. # V1.12 rc.eos now supports e1000 and virtio as vnic types (virtio is supported in vEOS >=4.14.5F)
  9. # usage
  10. if [ ! $# -eq 3 ] ; then
  11. echo -e "usage: $0 <Aboot-veos-serial-version.iso> <vEOS-version.vmdk> <new glance image name>, e.g.:\n"
  12. echo "$0 Aboot-veos-serial-2.0.8.iso vEOS-4.13.4F.vmdk vEOS"
  13. exit -1
  14. fi
  15. # sudo check
  16. if [ ! $UID -eq 0 ] ; then
  17. echo "Insufficient privileges. Please consider using sudo -s."
  18. exit -1
  19. fi
  20. ABOOT_SERIAL_ISO=$1
  21. ABOOT_SERIAL_ISO_BASENAME=$(basename -s .iso $1)
  22. VEOS_VMDK=$2
  23. VEOS_VMDK_BASENAME=$(basename -s .vmdk $2)
  24. GLANCE_IMAGE_NAME=$3
  25. GLANCE_IMAGE_RELEASE=$VEOS_VMDK_BASENAME-$ABOOT_SERIAL_ISO_BASENAME
  26. TMP_NAME="vEOS-$GLANCE_IMAGE_RELEASE"
  27. TIMESTAMP=$(date +%Y%m%d%H%M%S)
  28. echo
  29. echo "Creating vEOS image..."
  30. echo "==========================================================="
  31. # create a copy of Aboot bootloader and extend it to 3G
  32. cp $1 $TMP_NAME.raw
  33. truncate -s +3G $TMP_NAME.raw
  34. echo
  35. echo "Extracting partitions from vEOS vmdk..."
  36. echo "==========================================================="
  37. # convert vmdk to raw and extract two partitions in it
  38. qemu-img convert -O raw $2 $VEOS_VMDK_BASENAME.raw
  39. kpartx -av $VEOS_VMDK_BASENAME.raw
  40. dd if=/dev/mapper/loop0p1 of=$VEOS_VMDK_BASENAME-p1.raw
  41. dd if=/dev/mapper/loop0p2 of=$VEOS_VMDK_BASENAME-p2.raw
  42. kpartx -d $VEOS_VMDK_BASENAME.raw
  43. echo
  44. echo "Injecting rc.eos startup script to get switch config..."
  45. echo "==========================================================="
  46. # inject rc.eos script in first partition of the image, to get switch config defined in VM Maestro (config-drive)
  47. mkdir swi-$TIMESTAMP
  48. mount -o loop $VEOS_VMDK_BASENAME-p1.raw swi-$TIMESTAMP
  49. cd swi-$TIMESTAMP
  50. cat << EOF > rc.eos
  51. #!/bin/sh
  52. #
  53. # startup script to get node configs from VM Maestro
  54. #
  55. echo "Getting switch config from config drive..."
  56. echo "=========================================="
  57. mkdir /config-drive
  58. mount /dev/sdb1 /config-drive
  59. echo "Getting ip address for ma1 via dhcp..."
  60. echo "=========================================="
  61. MANAGEMENT_INTERFACE="ma1"
  62. ip link show \$MANAGEMENT_INTERFACE
  63. if [ \$? -ne 0 ]; then
  64. # if using virtio ma1 will not be up during Eos Init 1, hence we use eth0
  65. MANAGEMENT_INTERFACE="eth0"
  66. fi
  67. dhclient -r \$MANAGEMENT_INTERFACE
  68. dhclient -1 -v \$MANAGEMENT_INTERFACE >/mnt/flash/dhclient.log
  69. IP=\$(ip addr show \$MANAGEMENT_INTERFACE | grep inet | tr -s ' ' | cut -d ' ' -f 3 | sed s/"\/"/"\\\\\\\\\/"/g)
  70. echo \$IP
  71. sed s/"! ip of ma1 configured on launch"/"ip address \$IP"/g /config-drive/veos_config.txt >/mnt/flash/startup-config.tmp
  72. cat /mnt/flash/startup-config.tmp
  73. echo
  74. echo "Copying switch config from config drive..."
  75. echo "=========================================="
  76. cp /mnt/flash/startup-config.tmp /mnt/flash/startup-config
  77. EOF
  78. chmod 755 rc.eos
  79. cd ..
  80. umount swi-$TIMESTAMP
  81. rm -rf swi-$TIMESTAMP
  82. echo
  83. echo "Injecting new partitions from vEOS vmdk in Aboot image..."
  84. echo "==========================================================="
  85. # calulate size of the two partitions
  86. PART1_START=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw1" | tr -s " " | cut -d ' ' -f 3)
  87. PART1_END=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw1" | tr -s " " | cut -d ' ' -f 4)
  88. PART1_LENGTH=$(expr $PART1_END - $PART1_START)
  89. PART2_START=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw2" | tr -s " " | cut -d ' ' -f 2)
  90. PART2_END=$(fdisk -l $VEOS_VMDK_BASENAME.raw | grep "\.raw2" | tr -s " " | cut -d ' ' -f 3)
  91. PART2_LENGTH=$(expr $PART2_END - $PART2_START)
  92. # append the two partitions from vmdk in the bootloader iso
  93. echo -e "n
  94. p
  95. +$PART1_LENGTH
  96. t
  97. 2
  98. c
  99. a
  100. 2
  101. n
  102. p
  103. +$PART2_LENGTH
  104. t
  105. 3
  106. 12
  107. w" | fdisk $TMP_NAME.raw >/dev/null
  108. # copy the partitions from vEOS vmdk to new image
  109. kpartx -av $TMP_NAME.raw
  110. dd if=$VEOS_VMDK_BASENAME-p1.raw of=/dev/mapper/loop0p2
  111. dd if=$VEOS_VMDK_BASENAME-p2.raw of=/dev/mapper/loop0p3
  112. kpartx -d $TMP_NAME.raw
  113. echo
  114. echo "Convert new image to qcow2..."
  115. echo "==========================================================="
  116. # convert raw to qcow2
  117. qemu-img convert -O qcow2 $TMP_NAME.raw $TMP_NAME.qcow2
  118. echo
  119. echo "Cleaning up..."
  120. echo "==========================================================="
  121. #cleanup
  122. rm $TMP_NAME.raw
  123. rm $VEOS_VMDK_BASENAME-p1.raw
  124. rm $VEOS_VMDK_BASENAME-p2.raw
  125. rm $VEOS_VMDK_BASENAME.raw
  126. echo
  127. echo "Importing image into glance..."
  128. echo "==========================================================="
  129. 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=disk
  130. #testing:
  131. #
  132. # 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
  133. #
  134. # using VM Maestro, the image can be chosen as "VM image", e.g., for an IOSv or IOSvL2 node