Python 3
MIT license

Cisco SDWAN auto-upgrade

Introduction

This tool demonstrates the approach to automatically upgrade Cisco edge devices in a Cisco SD-WAN environment to simplify and streamline the software rollout and upgrade process.

It uses Public Cloud infrastructure to store software images and manage access to them using API.

This approach focuses on Cisco SDWAN infrastructure, but it can be used to upgrade any devices as long as they have Internet access.

This approach has the following benefits:

  • The organization doesn't have to host files on-prem, manage any infrastructure or complex firewall rules which greatly reduces security risks and management overhead
  • Software images can be shared using dynamic restricted access URLs
  • Endpoints can access the images using their Internet links which reduces a single link utilization if images were stored on a central on-prem server or vManage
  • Images can be hosted in different regions, closer to endpoints, which would benefit customers who have global presence
  • Images can automatically uploaded on the devices out of business hours reducing engineers' after hours work

Installation

It is recommended to build a Python 3 virtual environment.
Details on how to set one up can be found here.

If you use a Windows PC, follow these steps:

  1. Download and install python 3
  2. Setup virtual environment for NetSQL
  3. Activate it
  4. Download source code
  5. Install requirements
git clone https://github.com/supro200/sdwan-auto-upgrade.git
python -m venv netsql
cd sdwan-auto-upgrade
Scripts\activate.bat
pip install -r requirements.txt
  1. Change constants.py and test_software.py

Make sure you have environmental variables: AZURE_PRIMARY_KEY and if you connect to vManage using intermediate jump host (bastion host) set env.vars SSH_USERNAME and SSH_PASSWORD

Note the tool uses test_devices.py to get the software name and target devices.
It it supposed this kind of data is provided by your automation tools.

Azure Shared Access Signature

The images are stored in private storage accounts, not publicly available and only exposed during the upgrade using secure access links.

Most of public cloud providers have this feature, for example, in AWS and GCP it's called signed URL:

https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-signed-urls.html
https://cloud.google.com/storage/docs/access-control/signed-urls

This particular script uses Azure blob storage and its feature called shared access signature (SAS):

https://docs.microsoft.com/en-us/azure/storage/common/storage-sas-overview

A shared access signature (SAS) provides secure delegated access to resources in your storage account without compromising the security of your data. With a SAS, you have granular control over how a client can access your data. You can control what resources the client may access, what permissions they have on those resources, and how long the SAS is valid, among other parameters.

The SAS can specify start and expiry time, allowed source IP addresses, as well as a key to generate unique signatures:
Azure SAS

These signed URL can be generated using API calls and easily integrated with existing automation pipelines.
The software images are stored as Azure Blob objects and uploaded there manually (this process can also be automated if necessary)

Meanwhile, Cisco vManage has API endpoints which allow to upgrade controlled devices:

https://sdwan-docs.cisco.com/Product_Documentation/Command_Reference/Command_Reference/vManage_REST_APIs/Software_Maintenance_APIs/Upgrade_Software

Solution components and steps

The diagram shows the components of this solution and the required steps described below in more details:

diagram

  1. The script makes API call to Azure, specifying target file and the time limit when this file should be available.
  2. The API endpoint returns SAS URL which includes unique signature, for example: http://account-name.blob.core.windows.net/images/isr4300-universalk9.17.02.02.SPA.bin?se=2020-10-28T03%3A48%3A01Z&sp=rt&sv=2019-12-12&sr=b&sig=BIkMvzGhUwKo0J7ASabsfdgsdfDTRSWEljnFkpjeowE%3D
  3. The script makes API call to vManage to add software with type=remote and URL=SAS which is generated in previos step
  4. The script makes another API call to vManage to initiate the upgrade process with the parameters of Software Version and target device (Device ID/Serial and System IP)
  5. vManage returns Job ID which is used to poll vManage for the upgrade process status
  6. vManage makes netconf RPC call to the router instructing it to download image via HTTP using the SAS URL, install it, and optionally, activate the new image.
  7. The router downloads the image from Azure using it's transport Internet connection
    vManage Screenshot
  8. The router validates the image and installs it. If requested, the new software is activated and the router is rebooted.
  9. The script polls vManage using Job ID

Costs

Public cloud infrastructure is not free, so it's important to consider possible costs.

There are two components: Cost of storage the files and transfer costs.

Storage costs:

https://azure.microsoft.com/en-au/pricing/details/storage/blobs/

$0.0275 per GB per month for LRS Standard storage tier in Australia regions

If the average image size is 700 MB and we store 100 images, the cost would be 0.71000.0275 = $1.9 per month
Transfer costs:

https://azure.microsoft.com/en-au/pricing/details/bandwidth/

$0.165 per GB in Australia regions

If the image size is 700MB and the number of sites is 50, the cost of upgrade would be: 0.7GB * 50 * 0.165 = $5.8

There are other costs like read access, but they are counted per 10,000 and cost about 0.07, so it can be safely excluded from the calculations.

Caveats and limitations

This approach was tested on vManage version 20.1 and Cisco IOS-XE devices version 17.2

A significant limitation is that vManage does not accept image URLs if they don't ends with .bin. Meanwhile, Azure generates SAS URLs in a specific format and it's not possible to influence it.

As a workaround an additional key-value pair is added which seems to be ignored by Azure. This satisfied vManage requirements to the file to end with .bin and Azure returns the correct file.

 azure_blob_sas_token_bin = (generate_sas_token(AZURE_STORAGE_ACCOUNT, azure_blob_container, file_name=file_name) + "&ext=.bin")

Correct Azure SAS URL:

http://account-name.blob.core.windows.net/images/c1100-universalk9.17.03.01a.SPA.bin?se=2020-10-28T03%3A42%3A32Z&sp=rt&sv=2019-12-12&sr=b&sig=TCpnfN1AKghI9H9tpt6EkUBfMDPgBX3wzobG9jY%3D

Modified:

http://account-name.blob.core.windows.net/images/c1100-universalk9.17.03.01a.SPA.bin?se=2020-10-28T03%3A42%3A32Z&sp=rt&sv=2019-12-12&sr=b&sig=TCpnfN1AKgz9H9tpt6EkUBfMDPgBX3wzobG9jY%3D&ext=.bin

This tool is not a complete upgrade solution, but rather a module which can be used in conjunction with your automated pipelines, for example:

diagram

If you have any questions, please contact me at supro200@gmail.com

View code on GitHub

Code Exchange Community

Get help, share code, and collaborate with other developers in the Code Exchange community.View Community
Disclaimer:
Cisco provides Code Exchange for convenience and informational purposes only, with no support of any kind. This page contains information and links from third-party websites that are governed by their own separate terms. Reference to a project or contributor on this page does not imply any affiliation with or endorsement by Cisco.