Nornir Service File Copy Task¤
The Nornir Service File Copy Task is a component of NorFab's Nornir service, designed to facilitate the transfer of files to and from network devices. This task provides network engineers with a reliable and efficient method for managing device configurations, firmware updates, and other critical files. By leveraging the capabilities of the Nornir service, users can automate file transfers.
Nornir File Copy Sample Usage¤
NORFAB Nornir File Copy Shell Reference¤
NorFab shell supports these command options for Nornir file-copy
task:
nf#man tree nornir.file-copy
root
└── nornir: Nornir service
└── file-copy: Copy files to/from devices
├── timeout: Job timeout
├── workers: Filter worker to target, default 'all'
├── add_details: Add task details to results
├── run_num_workers: RetryRunner number of threads for tasks execution
├── run_num_connectors: RetryRunner number of threads for device connections
├── run_connect_retry: RetryRunner number of connection attempts
├── run_task_retry: RetryRunner number of attempts to run task
├── run_reconnect_on_fail: RetryRunner perform reconnect to host on task failure
├── run_connect_check: RetryRunner test TCP connection before opening actual connection
├── run_connect_timeout: RetryRunner timeout in seconds to wait for test TCP connection to establish
├── run_creds_retry: RetryRunner list of connection credentials and parameters to retry
├── tf: File group name to save task results to on worker file system
├── tf_skip_failed: Save results to file for failed tasks
├── diff: File group name to run the diff for
├── diff_last: File version number to diff, default is 1 (last)
├── progress: Emit execution progress
├── table: Table format (brief, terse, extend) or parameters or True
├── headers: Table headers
├── headers_exclude: Table headers to exclude
├── sortby: Table header column to sort by
├── reverse: Table reverse the sort by order
├── FO: Filter hosts using Filter Object
├── FH: Filter hosts by hostname
├── FC: Filter hosts containment of pattern in name
├── FR: Filter hosts by name using Regular Expressions
├── FG: Filter hosts by group
├── FP: Filter hosts by hostname using IP Prefix
├── FL: Filter hosts by names list
├── FM: Filter hosts by platform
├── FX: Filter hosts excluding them by name
├── FN: Negate the match
├── hosts: Filter hosts to target
├── *source_file: Source file to copy
├── plugin: Connection plugin parameters
│ └── netmiko: Use Netmiko plugin to copy files
│ ├── dest-file: Destination file to copy
│ ├── file-system: Destination file system
│ ├── direction: Direction of file copy, default 'put'
│ ├── inline-transfer: Use inline transfer, supported by Cisco IOS
│ ├── overwrite-file: Overwrite destination file if it exists, default 'False'
│ ├── socket-timeout: Socket timeout in seconds, default '10.0'
│ └── verify-file: Verify destination file hash after copy, default 'True'
└── dry-run: Do not copy files, just show what would be done
nf#
*
- mandatory/required command argument
Python API Reference¤
Task to transfer files to and from hosts using SCP
Parameters:
Name | Type | Description | Default |
---|---|---|---|
source_file
|
str
|
path to file to copy, support |
required |
plugin
|
str
|
plugin name to use - |
'netmiko'
|
to_dict
|
bool
|
default is True - produces dictionary results, if False produces list |
True
|
add_details
|
bool
|
if True will add task execution details to the results |
False
|
dry_run
|
bool
|
if True will not copy files just return what would be copied |
False
|
kwargs
|
additional arguments to pass to the plugin function |
{}
|
Returns:
Type | Description |
---|---|
dict
|
dictionary with the results of the file copy task |
Source code in norfab\workers\nornir_worker.py
1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 |
|