Skip to main content

Backup Network Device Configurations

Project description

Stockpiler

Stockpiler gathers network device configurations and stores them in a local Git repository.

Stockpiler utilizes Nornir, Netmiko, and GitPython for a fully self-contained backup solution, and has been tested to function on Linux, MacOS, and Windows.

Using Stockpiler

Once installed in an environment Stockpiler can be called directly/ad-hoc, or more commonly, by a Cron Job or other system scheduling tool such as creating a Systemd service.

The most basic execution of Stockpiler would be simply executing the following:

stockpiler

This will read the credentials from the Inventory or the environment, then attempt a backup of devices in the Nornir Inventory at /etc/stockpiler/inventory and put the resultant backups into a Git repository in /opt/stockpiler.

However, there are many configuration options available as well to specify Inventory location, provide custom credentials, utilize a SOCKS proxy, and so forth.

Another, more complex execution example could be:

 stockpiler \
 --inventory /home/brett/mah_inventory \
 --output /home/brett/stockpiler_backups \
 --proxy localhost:8000 \
 --log_level DEBUG \
 --logging_dir /home/brett/stockpiler_logs \
 --prompt_for_credentials

See stockpiler --help for full command information.

Credentials

By default, Stockpiler will look in the follwoing three Environment Variables for the username/password/enable_password to use:

  • STOCKPILER_USER
  • STOCKPILER_PW
  • STOCKPILER_ENABLE

Note that if STOCKPILER_ENABLE is not set, Stockpiler will utilize the STOCKPILER_PW for both values.

In addition, if these values are not set, you must tell Stockpiler to prompt you for credentials with the argument --prompt_for_credentials. By default it will not do so, as it is intended to be run in a non-interactive scenario, i.e. by a Cron job, and will simply raise an IOError and exit.

Configuration

As Stockpiler utilizes Nornir for the underlying inventory and task handling, see the Nornir documentation for more information on creating an inventory file or your configuration options

While we have provided a simple nornir_conf.yaml file, you are welcome to provide your own or customize the one provided by the package. See the Nornir documentation on Configuration for more information on the options available to you.

If you are using Windows (or wish to host your inventory in a different location than /etc/stockpiler/inventory), you will need to create a custom Nornir config file with your inventory paths.

Installation

Notes:

  1. Stockpiler utilizes a very recent release of Netmiko. This requires some specific handling (as outlined below), until other libraries update their dependencies.
  2. Stockpiler requires Python 3.7 or higher.
  3. Stockpiler utilizes Python Virtual Environments for isolation of the code/environment.

Installation Steps

  1. Create a directory for the Stockpiler virtual environment: mkdir stockpiler
  2. Create a virtual environment in that directory: python3 -m venv stockpiler
  3. Navigate to the new directory and activate it: cd stockpiler;source bin/activate
  4. Install Stockpiler: pip install stockpiler
  5. Edit the dependencies, this will require you to find the Napalm and Nornir METADATA files in your virtual environment:
    • Paths should be similar to:
      • lib/python3.7/site-packages/napalm-2.5.0.dist-info/METADATA
    • In each file, find the lines similar to below that reference Netmiko:
      • Requires-Dist: netmiko (==2.4.2)
    • Edit it to include 3.0.0, similar to the below:
      • Requires-Dist: netmiko (>=2.4.2)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stockpiler-0.5.3.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

stockpiler-0.5.3-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

File details

Details for the file stockpiler-0.5.3.tar.gz.

File metadata

  • Download URL: stockpiler-0.5.3.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.8.1

File hashes

Hashes for stockpiler-0.5.3.tar.gz
Algorithm Hash digest
SHA256 b26e83349ced105cb8cc1faf32ee73c4b2924f190f50abce9e37c4c989ef6189
MD5 c36534d0a080f8eb1bc1814d9bc44f1f
BLAKE2b-256 82ccf6c6a7980de3ad4d372b412c170cccc0c1aee8e2bff25271ce833da4dfcb

See more details on using hashes here.

File details

Details for the file stockpiler-0.5.3-py3-none-any.whl.

File metadata

  • Download URL: stockpiler-0.5.3-py3-none-any.whl
  • Upload date:
  • Size: 17.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.8.1

File hashes

Hashes for stockpiler-0.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6032812c37d8745f3471caca1e33527e786c4abeadd7b63eaf30e2931fd1e556
MD5 9b335e101b31c635641c694c3d0ef5e3
BLAKE2b-256 bb2f8ead9f4fc38746900cbcfb471d4551e150947118d1910469fcb3d013bb35

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page