本文整理匯總了Python中ncclient.manager.connect方法的典型用法代碼示例。如果您正苦於以下問題:Python manager.connect方法的具體用法?Python manager.connect怎麽用?Python manager.connect使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類ncclient.manager
的用法示例。
在下文中一共展示了manager.connect方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: connect
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def connect(self):
""" Establish netconf session """
if self.handle is not None:
return True
try:
# timeout is configurable as environment variable
timeout = int(os.getenv("NCCLIENT_TIMEOUT", 90))
self.handle = manager.connect(host=self.host,
port=self.port,
username=self.username,
password=self.password,
device_params=self.params,
unknown_host_cb=self._unknown_host_cb,
look_for_keys=False,
timeout=timeout)
except:
logging.exception("Failed to create netconf session:")
self.handle = None
return False
logging.debug("Connected: %s" % self.__str__())
return True
示例2: get_capability
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def get_capability(self):
""" Returns device capabilities """
logging.debug('get_capability ..')
reply = ET.Element('reply')
if not self.connect():
reply.text = 'NetConf Session could not be established {%s}' % str(self)
return reply
self.disconnect()
if self.handle.server_capabilities:
caps = sorted(self.handle.server_capabilities)
reply.text = '\n'.join((c for c in caps if c.startswith('urn:ietf:params:netconf:')))
reply.text += '\n\n'
reply.text += '\n'.join((c for c in caps if not c.startswith('urn:ietf:params:netconf:')))
logging.info('Received device capabilities ..')
return reply
示例3: demo
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def demo(host=nc_host, port=nc_port, user=nc_user, password=nc_password):
with manager.connect(host=host, port=port, username=user, password=password, hostkey_verify=False, look_for_keys=False, allow_agent=False) as m:
# Persist-id for the confirmed commit
pid = "IQ,d4668"
assert(":candidate" in m.server_capabilities)
assert(":validate" in m.server_capabilities)
with m.locked(target='candidate'):
m.discard_changes()
m.edit_config(config=config_snippet, target="candidate")
m.validate()
m.commit(confirmed=True, timeout="10", persist=pid)
print "Running the tests"
time.sleep(5)
# Could cancel the commit during the timeout
# res = m.cancel_commit(persist_id=pid)
print "Committing"
res = m.commit(confirmed=True)
print res
示例4: demo
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def demo(host=nc_host, port=nc_port, user=nc_user, password=nc_password):
with manager.connect(host=host, port=port, username=user, password=password,
hostkey_verify=False, look_for_keys=False, allow_agent=False) as mgr:
# Persist-id for the confirmed commit
pid = "IQ,d4668"
assert ':candidate' in mgr.server_capabilities
assert ':validate' in mgr.server_capabilities
with mgr.locked(target='candidate'):
mgr.discard_changes()
print("Editing config")
mgr.edit_config(config=CONFIG, target="candidate")
mgr.validate()
mgr.commit(confirmed=True, timeout="10", persist=pid)
print ("Running the tests (5s)")
time.sleep(5)
# Could cancel the commit during the timeout
# res = mgr.cancel_commit(persist_id=pid)
print("Committing")
res = mgr.commit(confirmed=True)
print(res)
示例5: test_ssh
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def test_ssh(self):
""" Verify device reachable through SSH """
for dev in self.parent.parameters["dev"]:
log.info(
banner("Testing SSH Access to {}".format(dev.name))
)
# Retry loop, number of tries controlled by variable.
for _ in range(MAX_RETRIES):
try:
dev.connect(alias="admin", via="admin", learn_hostname=True)
except Exception as e:
log.error("Attempt number {} to connect with SSH failed.".format(_ + 1))
log.error(e)
else:
break
# If unable to connect, fail test
else:
self.failed(
"Failed to establish SSH connection to '{}'".format(
dev.name
)
)
示例6: main
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def main():
"""
Main method that retrieves the hostname from config via NETCONF.
"""
with manager.connect(host=HOST, port=PORT, username=USER,
password=PASS, hostkey_verify=False,
device_params={'name': 'default'},
allow_agent=False, look_for_keys=False) as m:
# XML filter to issue with the get operation
# IOS-XE pre-16.2 YANG model called urn:ios
# IOS-XE 16.2 - 16.4 YANG model called http://cisco.com/ns/yang/ned/ios
# IOS-XE 16.5+ YANG model called http://cisco.com/ns/yang/Cisco-IOS-XE-native
hostname_filter = '''
<filter>
<native xmlns="http://cisco.com/ns/yang/Cisco-IOS-XE-native">
<hostname></hostname>
</native>
</filter>
'''
result = m.get_config('running', hostname_filter)
xml_doc = xml.dom.minidom.parseString(result.xml)
hostname = xml_doc.getElementsByTagName("hostname")
print(hostname[0].firstChild.nodeValue)
示例7: __init__
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def __init__(self, module):
self._module = module
if not HAS_NCCLIENT:
self._module.fail_json(msg='Error: The ncclient library is required.')
try:
self.mc = manager.connect(host=module.params["host"], port=module.params["port"],
username=module.params["username"],
password=module.params["password"],
unknown_host_cb=ce_unknown_host_cb,
allow_agent=False,
look_for_keys=False,
hostkey_verify=False,
device_params={'name': 'huawei'},
timeout=30)
except AuthenticationError:
self._module.fail_json(msg='Error: Authentication failed while connecting to device.')
except Exception:
err = get_exception()
self._module.fail_json(msg='Error: %s' % str(err).replace("\r\n", ""))
raise
示例8: main
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def main():
"""Main method that retrieves the hostname from config via NETCONF (NXOS)."""
with manager.connect(host=HOST, port=PORT, username=USER, password=PASS,
hostkey_verify=False, device_params={'name': 'nexus'},
allow_agent=False, look_for_keys=False) as m:
# XML filter to issue with the get operation
hostname_filter = '''
<show xmlns="http://www.cisco.com/nxos:1.0">
<hostname>
</hostname>
</show>
'''
result = m.get(('subtree', hostname_filter))
# Pass the XML result as a string to the parseString function
xml_doc = xml.dom.minidom.parseString(result.xml)
hostname = xml_doc.getElementsByTagName("mod:hostname")
print(hostname[0].firstChild.nodeValue)
示例9: main
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def main():
"""
Main method that prints netconf capabilities of remote device.
"""
serial_number = """
<System xmlns="http://cisco.com/ns/yang/cisco-nx-os-device">
<serial/>
</System>
"""
for device in DEVICES:
with manager.connect(host=device, port=PORT, username=USER,
password=PASS, hostkey_verify=False,
device_params={'name': 'nexus'},
look_for_keys=False, allow_agent=False) as m:
# Collect the NETCONF response
netconf_response = m.get(('subtree', serial_number))
# Parse the XML and print the data
xml_data = netconf_response.data_ele
serial = xml_data.find(".//{http://cisco.com/ns/yang/cisco-nx-os-device}serial").text
print("The serial number for {} {} is {}".format(DEVICE_NAMES[device], device, serial))
示例10: connect
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def connect(host, port, user, password):
connection = manager.connect(host=host, port=port, username=user,
password=password, timeout=10, device_params={'name':'junos'},
hostkey_verify=False)
return connection
# execute show commands
開發者ID:PacktPublishing,項目名稱:Mastering-Python-Networking-Second-Edition,代碼行數:9,代碼來源:junos_netconf_3.py
示例11: main
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def main():
with manager.connect(**CONNECTION_PARAMS) as nc_connection:
get_config(nc_connection)
configure_device(
nc_connection,
config_data=CONFIG_DATA,
template_name='loopbacks.j2'
)
示例12: __init__
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def __init__(self, host, username, password,
verbose=False):
self.host = host
self.username = username
self.password = password
if verbose:
self.logging()
# self.connect()
# self.kafka_connect()
self.nc_conn = None
self.producer = None
self.sub = None
示例13: nc_connect
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def nc_connect(self):
self.nc_conn = manager.connect(
host=self.host,
username=self.username,
password=self.password,
device_params={'name':'csr'},
hostkey_verify=False,
allow_agent=False,
unknown_host_cb=self.unknown_host_cb
)
示例14: main
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def main():
with manager.connect(**constants.NC_CONN_PARAMS) as m:
nc_reply = m.get(filter=('xpath', XPATH_FILTER))
print(utils.prettify_xml(nc_reply.xml))
示例15: main
# 需要導入模塊: from ncclient import manager [as 別名]
# 或者: from ncclient.manager import connect [as 別名]
def main():
"""Test code that is testing NETCONF."""
conn = manager.connect(
host="srx2.lasthop.io",
username="pyclass",
password=getpass(),
device_params={"name": "junos"},
hostkey_verify=False,
allow_agent=False,
look_for_keys=False,
port=830,
timeout=60,
)
ipdb.set_trace()
rpc = new_ele("get-software-information")
nc_out = conn.rpc(rpc)
# It is an XML like thing
print(nc_out.tostring.decode())
print(nc_out.find(".//product-name"))
print(nc_out.find(".//product-name").text)
print(nc_out.find(".//product-model").text)
config = conn.get_config(source="running")
config_xml = config.data_xml
print(config_xml)