

GitHub - ktbyers/netmiko: Multi-vendor library to simplify Paramiko SSH connecti...
source link: https://github.com/ktbyers/netmiko
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

README.md
Netmiko
Multi-vendor library to simplify Paramiko SSH connections to network devices
Quick Links
- Supported Platforms
- Installation
- Tutorials/Examples/Getting Started
- Common Issues/FAQ
- API-Documentation
- TextFSM Integration
- Contributing
- Questions/Discussion
Supported Platforms
Netmiko supports a wide range of devices. These devices fall into three categories:
- Regularly Tested
- Limited Testing
- Experimental
Regularly tested means we try to run our full test suite against that set of devices prior to each Netmiko release.
Limited testing means the config and show operation system tests passed against a test on that platform at one point in time so we are reasonably comfortable the driver should generally work.
Experimental means that we reviewed the PR and the driver seems reasonable, but we don't have good data on whether the driver fully passes the unit tests or how reliably it works.
Click PLATFORMS for a list of all supported platforms.
Installation
To install netmiko, simply us pip:
$ pip install netmiko
Netmiko has the following requirements (which pip will install for you)
- Paramiko >= 2.4.3
- scp >= 0.13.2
- pyserial
- textfsm
Tutorials/Examples/Getting Started
Tutorials:
- Getting Started
- Secure Copy
- Netmiko through SSH Proxy
- Netmiko and TextFSM
- Netmiko and what constitutes done
Example Scripts:
See the following directory for example scripts, including examples of:
- Simple Connection
- Sending Show Commands
- Sending Configuration Commands
- Handling Additional Prompting
- Connecting with SSH Keys
- Cisco Genie Integration
Getting Started:
Create a dictionary representing the device.
Supported device_types can be found in ssh_dispatcher.py, see CLASS_MAPPER keys.
from netmiko import ConnectHandler cisco_881 = { 'device_type': 'cisco_ios', 'host': '10.10.10.10', 'username': 'test', 'password': 'password', 'port' : 8022, # optional, defaults to 22 'secret': 'secret', # optional, defaults to '' }
Establish an SSH connection to the device by passing in the device dictionary.
net_connect = ConnectHandler(**cisco_881)
Execute show commands.
output = net_connect.send_command('show ip int brief') print(output)
Interface IP-Address OK? Method Status Protocol
FastEthernet0 unassigned YES unset down down
FastEthernet1 unassigned YES unset down down
FastEthernet2 unassigned YES unset down down
FastEthernet3 unassigned YES unset down down
FastEthernet4 10.10.10.10 YES manual up up
Vlan1 unassigned YES unset down down
Execute configuration change commands (will automatically enter into config mode)
config_commands = [ 'logging buffered 20000', 'logging buffered 20010', 'no logging console' ] output = net_connect.send_config_set(config_commands) print(output)
pynet-rtr1#config term
Enter configuration commands, one per line. End with CNTL/Z.
pynet-rtr1(config)#logging buffered 20000
pynet-rtr1(config)#logging buffered 20010
pynet-rtr1(config)#no logging console
pynet-rtr1(config)#end
pynet-rtr1#
Common Issues/FAQ
Answers to some common questions
Topics covered in above document:
- Handling commands that prompt for additional input
- Enabling logging of all reads/writes of the communication channel
- Redispatch -- or connecting through a terminal server
API-Documentation
Below are some of the particularly handy Classes/functions for easy reference:
TextFSM Integration
Netmiko has been configured to automatically look in ~/ntc-template/templates/index
for the ntc-templates index file. Alternatively, you can explicitly tell Netmiko where to look for the TextFSM template directory by setting the NET_TEXTFSM
environment variable (note, there must be an index file in this directory):
export NET_TEXTFSM=/path/to/ntc-templates/templates/
More info on TextFSM and Netmiko.
Contributing
Contributors are always welcome! You can contribute to Netmiko in a variety of ways: spreading the word about Netmiko, answering questions on Slack (see below in Quests/Discussions), responding to issues, adding to the common issues, reporting/fixing bugs, or even adding your own device type.
Before contributing a new vendor/platform device type, remember that any code added needs to be supported in some fashion (much more so for the "regularly tested" devices and the core of Netmiko)! To add a vendor/platform you can follow the outline here. Once you've worked on your first pass of your driver and have it functional, you'll need to include test data in order for it to be merged into develop, you can see the general flow of how to do that here.
For all code contributions, please ensure that you have ran black
against the code or your code will fail the Travis CI build.
Questions/Discussion
If you find an issue with Netmiko, then you can open an issue on this projects issue page here: https://github.com/ktbyers/netmiko/issues. Please make sure you've read through the common issues and examples prior to opening an issue. Please only open issues for bugs, feature requests, or other topics related to development of Netmiko. If you simply have a question, join us on Slack...
If you have questions or would like to discuss Netmiko, a #netmiko channel exists in this Slack workspace. To join, use this invitation. Once you have entered the workspace, then you can join the #netmiko channel.
Kirk Byers
Python for Network Engineers
https://pynet.twb-tech.com
Recommend
-
49
README.rst Paramiko
-
34
概述 ssh是一个协议,OpenSSH是其中一个开源实现,paramiko是Python的一个库,实现了SSHv2协议(底层使用cryptography)。 有了Paramiko以后,我们就可以在Python代码中直接使用SSH协议对远程服务器执行操作,而不是通...
-
50
paramiko模块 paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。 因此,如果需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是最佳工具之一...
-
11
Installing PyCrypto/Paramiko for Python3 x64 Windows Submitted by NanoDano on Sat, 11/28...
-
12
Jager · 6月16日 · 2017年python · shell · shell脚本 663次已读最近一直在开发自动化运维...
-
11
Daniel Pepuho Posted on Nov 22...
-
2
How to stop running out of ephemeral ports and start to love long-lived connections 02/02/2022 Often programmers have assumptions that turn out, to their surp...
-
10
Python解决paramiko使用invoke_shell交互式命令超时问题 20...
-
8
Elon Musk: 'We've Had Promising Conversations With Apple About Starlink Connectivity'Elon Musk: 'We've Had Promising Conversations With Apple About Starlink Connectivity'Thursday September 8, 2022 10:55 a...
-
7
SQLGateway Access your SQL database over HTTP like it’s a SQL database but with superpowers. An edge function's best friend. Superpowers include: HTTP access for SQL databases enable WASM-based runtim...
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK