- play_arrow Overview
- play_arrow NETCONF XML Management Protocol Overview
- play_arrow NETCONF and Junos XML Tags Overview
- XML and Junos OS Overview
- XML Overview
- XML and NETCONF XML Management Protocol Conventions Overview
- Map Junos OS Commands and Command Output to Junos XML Tag Elements
- Map Configuration Statements to Junos XML Tag Elements
- Using NETCONF Configuration Response Tag Elements in NETCONF Requests and Configuration Changes
-
- play_arrow Manage NETCONF Sessions
- play_arrow NETCONF Session Overview
- play_arrow Manage NETCONF Sessions
- Establish an SSH Connection for a NETCONF Session
- NETCONF Sessions over Transport Layer Security (TLS)
- NETCONF and Shell Sessions over Enhanced Outbound HTTPS
- NETCONF Sessions over Outbound HTTPS
- NETCONF Call Home Sessions
- NETCONF Sessions
- Sample NETCONF Session
- How Character Encoding Works on Juniper Networks Devices
- Configure RFC-Compliant NETCONF Sessions
- NETCONF Monitoring
- NETCONF Event Notifications
- play_arrow NETCONF Tracing Operations
- play_arrow NETCONF Protocol Operations and Attributes
- play_arrow NETCONF Request and Response Tags
- play_arrow Junos XML Protocol Elements Supported in NETCONF Sessions
- <abort/>
- <abort-acknowledgement/>
- <checksum-information>
- <close-configuration/>
- <commit-configuration>
- <commit-results>
- <commit-revision-information>
- <database-status>
- <database-status-information>
- <end-session/>
- <get-checksum-information>
- <get-configuration>
- <load-configuration>
- <load-configuration-results>
- <lock-configuration/>
- <open-configuration>
- <reason>
- <request-end-session/>
- <routing-engine>
- <unlock-configuration/>
- <xnm:error>
- <xnm:warning>
- play_arrow Junos XML Protocol Element Attributes Supported in NETCONF Sessions
-
- play_arrow Manage Configurations Using NETCONF
- play_arrow Change the Configuration Using NETCONF
- Edit the Configuration Using NETCONF
- Upload and Format Configuration Data in a NETCONF Session
- Set the Edit Configuration Mode in a NETCONF Session
- Handle Errors While Editing the Candidate Configuration in a NETCONF Session
- Replace the Candidate Configuration Using NETCONF
- Roll Back Uncommitted Changes in the Candidate Configuration Using NETCONF
- Delete the Configuration Using NETCONF
- Change Individual Configuration Elements Using NETCONF
- Merge Configuration Elements Using NETCONF
- Create Configuration Elements Using NETCONF
- Delete Configuration Elements Using NETCONF
- Replace Configuration Elements Using NETCONF
- Replace Patterns in Configuration Data Using the NETCONF or Junos XML Protocol
- play_arrow Commit the Configuration Using NETCONF
- play_arrow Ephemeral Configuration Database
- Understanding the Ephemeral Configuration Database
- Unsupported Configuration Statements in the Ephemeral Configuration Database
- Enable and Configure Instances of the Ephemeral Configuration Database
- Commit and Synchronize Ephemeral Configuration Data Using the NETCONF or Junos XML Protocol
- Managing Ephemeral Configuration Database Space
- Example: Configure the Ephemeral Configuration Database Using NETCONF
-
- play_arrow Request Operational and Configuration Information Using NETCONF
- play_arrow Request Operational Information Using NETCONF
- play_arrow Request Configuration Information Using NETCONF
- Request the Committed Configuration and Device State Using NETCONF
- Request Configuration Data Using NETCONF
- Specify the Source for Configuration Information Requests Using NETCONF
- Specify the Scope of Configuration Information to Return in a NETCONF Response
- Request the Complete Configuration Using NETCONF
- Request a Configuration Hierarchy Level or Container Object Without an Identifier Using NETCONF
- Request All Configuration Objects of a Specified Type Using NETCONF
- Request Identifiers for Configuration Objects of a Specified Type Using NETCONF
- Request A Specific Configuration Object Using NETCONF
- Request Specific Child Tags for a Configuration Object Using NETCONF
- Request Multiple Configuration Elements Simultaneously Using NETCONF
- Retrieve a Previous (Rollback) Configuration Using NETCONF
- Compare Two Previous (Rollback) Configurations Using NETCONF
- Retrieve the Rescue Configuration Using NETCONF
- Request an XML Schema for the Configuration Hierarchy Using NETCONF
-
- play_arrow NETCONF Utilities
- play_arrow NETCONF Perl Client
- play_arrow Develop NETCONF Perl Client Applications
- Write NETCONF Perl Client Applications
- Import Perl Modules and Declare Constants in NETCONF Perl Client Applications
- Connect to the NETCONF Server in Perl Client Applications
- Collect Parameters Interactively in NETCONF Perl Client Applications
- Submit a Request to the NETCONF Server in Perl Client Applications
- Example: Request an Inventory of Hardware Components Using a NETCONF Perl Client Application
- Example: Change the Configuration Using a NETCONF Perl Client Application
- Parse the NETCONF Server Response in Perl Client Applications
- Close the Connection to the NETCONF Server in Perl Client Applications
-
- play_arrow OpenDaylight Integration
- play_arrow Configure OpenDaylight Integration
-
- play_arrow Configuration Statements and Operational Commands
Understanding the YANG Modules for Junos Operational Commands
Juniper Networks publishes YANG modules that define the remote procedure calls (RPCs) for
Junos operational mode commands. Due to the large number of operational commands, there are
multiple YANG modules for each device family. There is a module for each top-level operational
command group (clear
, file
, monitor
, and so
on) where there is at least one command within that hierarchy with an RPC equivalent. There is
also a separate module for each area within the show
command hierarchy.
Starting in Junos OS Release 17.2, Junos YANG modules are specific to a device family and
use a new convention for the module namespace. In addition, each individual operational
command module defines its namespace prefix using the command hierarchy area of the RPCs
included in that module. Prior to Junos OS Release 17.2, the prefix for all operational
command modules was jrpc
.
Starting in Junos OS Release 17.4R1, Junos OS YANG modules use a new naming convention for the module’s name, filename, and namespace. For more information, see Understanding Junos YANG Modules.
The operational command modules define the RPCs corresponding to the operational commands in
the command hierarchy area indicated in the filename. The following example shows a portion of
the module containing the RPCs for commands in the clear
command hierarchy:
user@host> file show /var/tmp/yang/junos-rpc-clear@2017-01-01.yang /* * Copyright (c) 2017 Juniper Networks, Inc. * All rights reserved. */ module junos-rpc-clear { namespace "http://yang.juniper.net/junos/rpc/clear"; prefix clear; import junos-common-types { prefix jt; } organization "Juniper Networks, Inc."; contact "yang-support@juniper.net"; description "Junos RPC YANG module for clear command(s)"; revision 2017-01-01 { description "Junos: 17.4R1.17"; } rpc clear-cli-logical-system { description "Clear logical system association"; output { leaf output { type string; } } } rpc clear-cli-satellite { description "Clear satellite association"; output { leaf output { type string; } } } ...
YANG defines operations using the rpc
statement. The RPC definition can
include input
and output
substatements that describe the
operation's input and output parameters. Starting in Junos OS Release 23.1R1 and Junos OS
Evolved Release 23.2R1, the RPC's output
statement includes an accurate
output schema, and Junos devices emit the new schemas by default.
In earlier releases, the RPC's output schema includes the anyxml
statement
to represent an unkown chunk of XML in the RPC reply. To generate the RPC schemas containing
the anyxml
statement on a Junos device, configure the
device-specific
and emit-anyxml-in-rpc-output
statements
at the [edit system services netconf yang-modules]
hierarchy level. After you
configure the statements, the show system schema
command generates the
schemas that use anyxml
.
You can download the Junos native YANG modules from the Juniper Networks download site or the
Juniper/yang GitHub repository, or you can generate the modules on the local device.
To generate the operational command YANG modules on the local device issue the show
system schema format yang module module
command. The Junos OS
release determines the available command options.
In Junos OS Release 17.3 and earlier, specify the
juniper-command
module to generate all of the operational command modules.content_copy zoom_out_mapuser@host> show system schema format yang module juniper-command
Note:Starting in Junos OS Release 17.1, when you generate the
juniper-command
module, the output files are placed in the current working directory, which defaults to the user’s home directory. In Junos OS Release 16.2 and earlier, the output files are placed in the /var/tmp directory.In Junos OS Release 17.4R1 and later, specify an individual module name to return a single operational command module, or specify
all-rpc
to return all operational command modules.content_copy zoom_out_mapuser@host> show system schema format yang module all-rpc output-directory /var/tmp/yang
If you specify module juniper-command
or module all-rpc
,
the output files include both native Junos operational command modules as well as any standard
or custom operational command modules that have been added to the device. To use an RPC in
your custom YANG module, you must import the module that contains the desired RPC into your
custom module.
Starting in Junos OS Release 19.1R2 and 19.2R1, the show system schema
command must include the output-directory
command option and specify the
directory in which to generate the file or files. In earlier releases, you can omit the
output-directory
option when requesting a single module to display the
module in standard output.
To generate the modules from a remote session, execute the
<get-yang-schema>
Junos OS RPC or the
<get-schema>
NETCONF operation with the appropriate options.
You can configure the emit-extensions
statement at the [edit system
services netconf yang-modules]
hierarchy level to emit the YANG schemas with
additional Junos extension statements. The Junos extensions are defined in Understanding the Junos DDL Extensions YANG Module. The device emits the
junos:command
extension statement starting in Junos OS Release 22.4R1 and
Junos OS Evolved Release 22.4R1.
Starting in Junos OS Release 17.4R1, the native YANG modules generated on a local device
contain family-specific schemas, which are identical across all devices in the given device
family. In earlier releases, the generated modules contain device-specific schemas. To
generate device-specific modules in Junos OS Release 17.4R1 and later, configure the
device-specific
configuration statement at the [edit system
services netconf yang-modules]
hierarchy level.
Change History Table
Feature support is determined by the platform and release you are using. Use Feature Explorer to determine if a feature is supported on your platform.
junos
device family identifier instead of
junos-qfx
.junos:command
extension
statement in schemas emitted with extensions.show system
schema
command must include the output-directory
command
option and specify the directory in which to generate the file or files.juniper-command
module, the output files are placed in the current
working directory, which defaults to the user’s home directory