當前位置: 首頁>>代碼示例>>Python>>正文


Python manager.connect方法代碼示例

本文整理匯總了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 
開發者ID:CiscoDevNet,項目名稱:yang-explorer,代碼行數:26,代碼來源:runner.py

示例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 
開發者ID:CiscoDevNet,項目名稱:yang-explorer,代碼行數:18,代碼來源:runner.py

示例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 
開發者ID:cmoberg,項目名稱:netconf-yang-training,代碼行數:20,代碼來源:08_cmd-add-mpls-lsp-full.py

示例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) 
開發者ID:cmoberg,項目名稱:netconf-yang-training,代碼行數:22,代碼來源:08_cmd-add-mpls-lsp-full.py

示例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
                    )
                ) 
開發者ID:DevNetSandbox,項目名稱:sbx_iosxe,代碼行數:26,代碼來源:device_api_test.py

示例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) 
開發者ID:DevNetSandbox,項目名稱:sbx_iosxe,代碼行數:26,代碼來源:get_hostname.py

示例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 
開發者ID:HuaweiSwitch,項目名稱:CloudEngine-Ansible,代碼行數:25,代碼來源:ce.py

示例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) 
開發者ID:CiscoDevNet,項目名稱:netconf-examples,代碼行數:21,代碼來源:get_hostname.py

示例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)) 
開發者ID:DevNetSandbox,項目名稱:sbx_nxos,代碼行數:27,代碼來源:get_serial.py

示例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'
        ) 
開發者ID:dmfigol,項目名稱:network-programmability-stream,代碼行數:10,代碼來源:example.py

示例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 
開發者ID:dmfigol,項目名稱:network-programmability-stream,代碼行數:14,代碼來源:nc_dial_in_subscribe.py

示例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
        ) 
開發者ID:dmfigol,項目名稱:network-programmability-stream,代碼行數:12,代碼來源:nc_dial_in_subscribe.py

示例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)) 
開發者ID:dmfigol,項目名稱:network-programmability-stream,代碼行數:6,代碼來源:test_xpath.py

示例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) 
開發者ID:ktbyers,項目名稱:pyplus_course,代碼行數:29,代碼來源:ncclient3.py


注:本文中的ncclient.manager.connect方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。