【问题标题】:Configuring Juniper routers with PHP NETCONF使用 PHP NETCONF 配置瞻博网络路由器
【发布时间】:2016-03-01 19:47:17
【问题描述】:

我正在使用 NETCONF 的 PHP 库:https://github.com/Juniper/netconf-php。到目前为止,我已经设法获得了脚本所需的配置部分,但最近的挑战仍然是将新配置加载到路由器中。我路由器上的日志:

Nov 27 14:34:48  router.nl sshd[78164]: subsystem request for netconf by user user
Nov 27 14:34:48  router.nl mgd[78168]: UI_CMDLINE_READ_LINE: User 'x', command 'xml-mode netconf need-trailer '
Nov 27 14:34:48  router.nl file[78167]: UI_LOGIN_EVENT: User 'x' login, class 'j-super-user' [78167], ssh-connection 'x.x.x.x 46796 x.x.x.x 22', client-mode 'netconf'
Nov 27 14:34:48  router.nl file[78167]: UI_NETCONF_CMD: User 'x' used NETCONF client to run command 'lock cannot reconstruct arguments'
Nov 27 14:34:48  router.nl file[78167]: UI_NETCONF_CMD: User 'x' used NETCONF client to run command 'edit-config cannot reconstruct arguments default-operation=merge cannot reconstruct arguments'
Nov 27 14:34:48  router.nl file[78167]: UI_NETCONF_CMD: User 'x' used NETCONF client to run command 'unlock cannot reconstruct arguments'
Nov 27 14:34:48  router.nl file[78167]: UI_NETCONF_CMD: User 'x' used NETCONF client to run command 'close-session'

它一直抱怨无法重构参数。这是我正在尝试使用的脚本:

require_once '../app/include/netconf/Device.php';

$deviceParams = [
    'hostname'  => 'x.x.x.x',
    'username'  => 'x',
    'password'  => 'password',
    'port'      => 22
    ];

$this->device = new Device($deviceParams);
$this->connectRouter();

$islocked = $this->device->lock_config();

$command = '<system><services><ftp/></services></system>';

if($islocked) {              
    $this->device->load_xml_configuration($command, 'merge');
}

$this->device->unlock_config();

$this->device->close();

我已经在 netconf { ssh { 树下设置了 traceoqptions,这是输出之一(一切似乎都还好):

Nov 30 10:41:57 [86546] Incoming:
<rpc><edit-config><target><candidate/></target><default-operation>merge</default-operation><config><configuration><system><services><ftp></ftp></services></system></configuration></config></edit-config></rpc>]]>]]>


Nov 30 10:41:57 [86546] Outgoing: <rpc-reply     xmlns="urn:ietf:params:xml:ns:netconf:base:1.0" xmlns:junos="http://xml.juniper.net/junos/12.3R8/junos">
Nov 30 10:41:57 [86546] Outgoing: <ok/>
Nov 30 10:41:57 [86546] Outgoing: </rpc-reply>
Nov 30 10:41:57 [86546] Outgoing: ]]>]]>
Nov 30 10:41:57 [86546] Incoming: <rpc><close-session/></rpc>]]>]]>

【问题讨论】:

    标签: php networking juniper-network-connect ietf-netconf


    【解决方案1】:

    我在我的 OP 中显示的第一个日志什么也没说,只是告诉我出了点问题。然而,在我尝试锁定/解锁配置后,traceoptions 确实告诉了我重要信息:

    Nov 30 12:06:43 [86767] Outgoing: <rpc-error>
    Nov 30 12:06:43 [86767] Outgoing: <error-type>protocol</error-type>
    Nov 30 12:06:43 [86767] Outgoing: <error-tag>operation-failed</error-tag>
    Nov 30 12:06:43 [86767] Outgoing: <error-severity>error</error-severity>
    Nov 30 12:06:43 [86767] Outgoing: <error-message>
    Nov 30 12:06:43 [86767] Outgoing: configuration database modified
    Nov 30 12:06:43 [86767] Outgoing: </error-message>
    Nov 30 12:06:43 [86767] Outgoing: </rpc-error>
    Nov 30 12:06:43 [86767] Outgoing: </rpc-reply>
    Nov 30 12:06:43 [86767] Outgoing: ]]>]]>
    

    快速搜索“配置数据库已修改”意味着仍有一些未提交的更改(http://www.juniper.net/documentation/en_US/junos13.3/topics/topic-map/junos-script-automation-service-template-automation.html,底部页面):

    Problem
    
    You see the following message when creating, updating, or deleting a service on a device through a NETCONF session:
    
    <output>
        configuration database modified
    </output>
    
    The configuration has previously uncommitted changes, and the service script cannot commit the service configuration changes.
    

    只需在配置模式下输入“commit”即可消除错误。我希望我已经/将来会帮助其他人。

    【讨论】:

      【解决方案2】:

      不确定 PHP 中的 netconf(仍在深入研究),但在 Python 中,您应该始终最好使用“配置私有”:

      junos_dev.open()
      with Config(junos_dev, mode='private') as cu:
        cu.load(some_string, format='set')
        #print cu.diff()
        cu.commit()
      junos_dev.close()
      

      现在我也在这里找到了相关功能: /** *应调用此方法以在“私有”模式下进行加载操作。 *@param 模式 * 打开配置的模式。 * 允许的模式:“私人” */ 公共函数 open_configuration($mode)

      【讨论】:

      • 感谢您的 python 版本。我不确定这将如何工作,但由于我目前正在学习 Python,我可能有一天需要这个 :-)
      猜你喜欢
      • 2021-04-07
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-08-19
      • 2012-02-07
      • 1970-01-01
      • 2022-12-04
      • 1970-01-01
      相关资源
      最近更新 更多