A procedure for creating a Cisco CSR 1000V (Cisco IOS XE Denali 16.3.1 or later) Vagrant box for the libvirt provider.
- Git
- Python
- Ansible >= 2.7
- libvirt with client tools
- QEMU
- Expect
- Telnet
- Vagrant >= 2.2.10
- vagrant-libvirt
Vagrant version 2.2.16 introduced a bug that breaks SSH connectivity - #12344
0. Verify the prerequisite tools are installed.
$ which git python ansible libvirtd virsh qemu-system-x86_64 expect telnet vagrant $ vagrant plugin list vagrant-libvirt (0.5.1, global)
1. Log in and download the Cisco Cloud Services Router 1000V software from your Cisco account. Save the file to your Downloads directory.
2. Copy (and rename) the disk image file to the /var/lib/libvirt/images directory.
$ sudo cp $HOME/Downloads/csr1000v-universalk9.17.03.02-serial.qcow2 /var/lib/libvirt/images/cisco-csr1kv.qcow2
3. Modify the file ownership and permissions. Note the owner may differ between Linux distributions.
Ubuntu 18.04
$ sudo chown libvirt-qemu:kvm /var/lib/libvirt/images/cisco-csr1kv.qcow2 $ sudo chmod u+x /var/lib/libvirt/images/cisco-csr1kv.qcow2
Arch Linux
$ sudo chown nobody:kvm /var/lib/libvirt/images/cisco-csr1kv.qcow2 $ sudo chmod u+x /var/lib/libvirt/images/cisco-csr1kv.qcow2
4. Create the boxes directory.
$ mkdir -p $HOME/boxes
5. Start the vagrant-libvirt network (if not already started).
$ virsh -c qemu:///system net-list $ virsh -c qemu:///system net-start vagrant-libvirt
6. Clone this GitHub repo and cd into the directory.
$ git clone https://github.com/mweisel/cisco-csr1kv-vagrant-libvirt $ cd cisco-csr1kv-vagrant-libvirt
7. Run the Ansible playbook.
$ ansible-playbook main.yml
8. Copy (and rename) the Vagrant box artifact to the boxes directory.
$ cp cisco-csr1kv.box $HOME/boxes/cisco-csr1000v-17.03.02.box
9. Copy the box metadata file to the boxes directory.
$ cp ./files/cisco-csr1000v.json $HOME/boxes/
10. Change the current working directory to boxes.
$ cd $HOME/boxes
11. Substitute the HOME placeholder string in the box metadata file.
$ awk '/url/{gsub(/^ */,"");print}' cisco-csr1000v.json
"url": "file://HOME/boxes/cisco-csr1000v-VER.box"
$ sed -i "s|HOME|${HOME}|" cisco-csr1000v.json
$ awk '/url/{gsub(/^ */,"");print}' cisco-csr1000v.json
"url": "file:///home/marc/boxes/cisco-csr1000v-VER.box"
12. Also, substitute the VER placeholder string with the Cisco IOS XE version you're using.
$ awk '/VER/{gsub(/^ */,"");print}' cisco-csr1000v.json
"version": "VER",
"url": "file:///home/marc/boxes/cisco-csr1000v-VER.box"
$ sed -i 's/VER/17.03.02/g' cisco-csr1000v.json
$ awk '/\<version\>|url/{gsub(/^ */,"");print}' cisco-csr1000v.json
"version": "17.03.02",
"url": "file:///home/marc/boxes/cisco-csr1000v-17.03.02.box"
13. Add the Vagrant box to the local inventory.
$ vagrant box add cisco-csr1000v.json
To view the telnet session output for the expect task:
$ tail -f ~/csr1kv-console.explog
This project is licensed under the MIT License - see the LICENSE file for details