Skip to main content

No project description provided

Project description

Nornir Conditional Runner

The ConditionalRunner is a custom Nornir runner that enforces concurrency limits based on host groups or custom condition groups. It allows you to control task execution by defining limits on the number of simultaneous tasks for specific groups of hosts, ensuring your nornir tasks are not updating vital network devices at the same time.

Installation

pip install nornir-conditional-runner

Usage

Replace the default Nornir runner with ConditionalRunner in your configuration:

from nornir import InitNornir

nr = InitNornir(
    runner={
        "plugin": "ConditionalRunner", # Use the ConditionalRunner instead of the default
        "options": {
            "num_workers": 10, # Maximum number of concurrent tasks
            "group_limits": {
                "core": 1, # Limit the "core" group to 1 concurrent task
                "distribution": 2,
                "edge": 3,
            },
            "conditional_group_key": "conditional_groups", # Custom key for conditional groups config in host data
        },
    },
    inventory={
        "plugin": "SimpleInventory",
        "options": {
            "host_file": "inventory/hosts.yaml",
            "group_file": "inventory/groups.yaml",
        },
    },
)

def my_task(task):
    return f"Running on {task.host.name}"

result = nr.run(task=my_task)
print(result)

Host Example

Hosts can define custom groups in their data dictionary using the conditional_group_key provided to the runner. The runner will use these groups to enforce the group_limits.

host1:
  data:
    conditional_groups:
      - core
host2:
  data:
    conditional_groups:
      - distribution

If no conditional groups are defined and conditional_group_key is not provided to the runner, the runner will use the host groups.

host1:
  groups: 
    - core
host2:
  groups: 
    - edge

Logging

The ConditionalRunner leverages Python's built-in logging system to provide insights into its operation. It logs key events, such as:

  • Warnings when a group limit is missing in group_limits, defaulting to the global limit.
  • Warnings when an invalid or missing conditional_group_key causes a fallback to host groups.

Demo

A demo can be found in the demo/demo.py file.

Demo topology with conditional groups: Demo topology

Error Handling

  • If conditional_group_key is provided but no conditional groups are defined in the host data, the runner will warn you and default to using the host groups as conditional groups.
  • If no group_limits are specified for a group, the runner will default to using the global num_workers value as the limit.
  • If neither group_limits nor a conditional_group_key are provided, the runner will fall back to using the host groups as conditional groups, with the default limits set to the global num_workers. This behavior thean basically mirrors that of the default threaded Nornir runner.
  • Invalid group limits (i.e., non-positive integers) will result in a ValueError.

Contributing

Contributions are welcome! Feel free to submit issues or feature requests on GitHub.


Enjoy using the Nornir Conditional Runner! 🎉

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

nornir_conditional_runner-0.1.3.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file nornir_conditional_runner-0.1.3.tar.gz.

File metadata

File hashes

Hashes for nornir_conditional_runner-0.1.3.tar.gz
Algorithm Hash digest
SHA256 0567f6f6e8468f186b3ba382b6c0cafeda2379c8cdbd7940b5fd8776cc87865b
MD5 d6b86ca8d890784a992102ce046e6425
BLAKE2b-256 af5724ce2c8076e76ec7d43707e6c916d1c32373f4709a924091b83b4d3d7a5e

See more details on using hashes here.

File details

Details for the file nornir_conditional_runner-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for nornir_conditional_runner-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 cb8fdce40cd22da324036c701a9a63fb9b0ffb5c43362224d92c02fa6cbf65e9
MD5 b21625418f0140205a0fba266f57031e
BLAKE2b-256 0114fc2d445ecb925155f3dd8b92d2105d023eaa5bdf4467d004c473de86f698

See more details on using hashes here.

Supported by

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