如何解决无法通过Python ncclient访问Yang功能
我有一个带有Cisco XE版本16.8.1a的Cisco CSRv1000。
我启用了netconf-yang,当我运行命令ssh -2 -s admin@172.30.43.115 netconf
时,它将在CLI上显示YANG。
但是,如果我在python上运行以下代码,则会出现错误ncclient.transport.errors.SSHError: Could not open socket to 172.30.43.115:830
我的代码:
from ncclient import manager
import xml.etree.ElementTree as ET
router = {
"host": "172.30.43.115","port": "830","username": "admin","password": "******",}
with manager.connect(
host=router["host"],port=router["port"],username=router["username"],password=router["password"],hostkey_verify=False,allow_agent=False,look_for_keys=False,) as m:
ip_schema = m.get_schema("ietf-ip")
root = ET.fromstring(ip_schema.xml)
yang_tree = list(root)[0].text
f = open("ietf-ip.yang","w")
f.write(yang_tree)
f.close()
另外,请在路由器上运行我的节目:
MyRouter#show run
Building configuration...
Current configuration : 1725 bytes
!
! Last configuration change at 17:37:24 UTC Sat Oct 3 2020
!
version 16.8
service timestamps debug datetime msec
service timestamps log datetime msec
platform qfp utilization monitor load 80
no platform punt-keepalive disable-kernel-core
platform console serial
!
hostname MyRouter
!
boot-start-marker
boot-end-marker
!
!
enable secret 5 $1$tK3F$2WEFfM8JZcyP7YPgzRZbH1
!
aaa new-model
!
!
aaa authentication login default local
aaa authorization exec default local
!
!
!
!
!
aaa session-id common
!
!
!
!
!
!
!
ip domain name myrouter.com
!
!
!
!
!
!
!
!
!
!
subscriber templating
!
!
!
!
!
!
!
multilink bundle-name authenticated
!
!
!
!
!
!
!
!
!
!
!
!
!
!
license udi pid CSR1000V sn 96YNK5Y0HUS
no license smart enable
diagnostic bootup level minimal
!
spanning-tree extend system-id
!
netconf-yang
!
!
username admin privilege 15 secret 5 $1$h/2L$vvzIggHKLFlS1KJlYOqkA1
!
redundancy
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
interface GigabitEthernet1
ip address 172.30.43.115 255.255.255.0
ip nat outside
negotiation auto
no mop enabled
no mop sysid
!
interface GigabitEthernet2
no ip address
shutdown
negotiation auto
no mop enabled
no mop sysid
!
interface GigabitEthernet3
no ip address
shutdown
negotiation auto
no mop enabled
no mop sysid
!
interface GigabitEthernet4
no ip address
shutdown
negotiation auto
no mop enabled
no mop sysid
!
ip forward-protocol nd
ip http server
ip http authentication local
ip http secure-server
ip route 0.0.0.0 0.0.0.0 172.30.43.3
!
ip ssh version 2
!
!
!
!
!
!
!
control-plane
!
!
!
!
!
!
line con 0
stopbits 1
line vty 0 4
transport input ssh
!
netconf ssh
wsma agent exec
!
wsma agent config
!
wsma agent filesys
!
wsma agent notify
!
!
end
我在做错什么吗?如果是这样,有人可以帮我吗?
解决方法
使用 'pip install paramiko' 安装 Paramiko 为我完成了这项工作。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。