Decodificación de datos de interfaz de telemetría de Junos con utilidades de UNIX
Puede usar utilidades de UNIX para descodificar datos de interfaz de telemetría de Junos en un servidor o recopilador que transmita datos desde un dispositivo de Juniper Networks. En el ejemplo de esta sección se muestra cómo descodificar un único paquete de datos transmitidos.
Preparación del recopilador para descodificar datos
Este ejemplo requiere lo siguiente:
Sistema operativo UNIX con la utilidad Netcat (nc).
Compilador de búferes de protocolo.
El protocolo de búfer de la interfaz de telemetría de Junos almacena archivos en búfer.
Este procedimiento muestra cómo preparar el recopilador para descodificar datos utilizando el sistema operativo Ubuntu.
Instale la utilidad Netcat.
sudo apt-get install netcat
Instale el compilador de búferes de protocolo.
sudo apt-get install protobuf-compiler
Instale la biblioteca del desarrollador de búferes de protocolo.
sudo apt-get install libprotobuf-dev
Compruebe que los archivos de biblioteca están instalados.
ls /usr/include/google/protobuf/descriptor.proto /usr/include/google/protobuf/descriptor.proto
Descargue e instale la versión más reciente de los archivos de búferes del protocolo de interfaz de telemetría de Junos.
Desde un navegador web, vaya a la URL de descarga del software Todas las plataformas Junos en la página de Juniper Networks: https://www.juniper.net/support/downloads/. Después de seleccionar el nombre de la plataforma Junos OS y el número de versión, vaya a la sección Herramientas y descargue el paquete Archivos de modelo de datos de la interfaz de telemetría de Junos .
tar –xvzf junos-telemetry-interface-15.1F6.9.tgz junos-telemetry-interface/telemetry_top.proto junos-telemetry-interface/logical_port.proto junos-telemetry-interface/lsp_mon.proto junos-telemetry-interface/firewall.proto junos-telemetry-interface/lsp_stats.proto junos-telemetry-interface/port.proto junos-telemetry-interface/NOTICE junos-telemetry-interface/license.txt
Nota:Asegúrese de anotar la ubicación de los archivos extraídos.
Decodificación de datos en el recopilador
En este procedimiento se muestra cómo capturar datos, descodificar datos sin procesar y utilizar los archivos de búferes de protocolo para descodificar datos.
Para descodificar datos:
Capture los datos.
Ejecute netcat en un servidor de telemetría de streaming de destino, o recopilador, en modo de escucha UDP para almacenar todos los datagramas entrantes en un archivo. Utilice el número de puerto de destino configurado en el perfil del servidor de streaming en su dispositivo de Juniper Networks.
nc -ul 0.0.0.0 20000 > data.gpb
Nota:Este comando almacena los datagramas en un archivo denominado
data.gpb. Ejecute este programa para capturar datos. Cuando desee dejar de recibir datos, deténgase con el programa enviando la señal de interrupción (Control + C)Decodificar datos sin procesar.
Nota:Este paso es opcional. No es necesario si conoce el tipo de mensaje codificado de los datos.
Descodifique el mensaje del
data.gpbarchivo.protoc --decode_raw < ../data.gpb 1: "hillrock:160.1.1.25" 2: 0 4: "S1:/junos/system/linecard/interface/logical/usage/:/junos/system/linecard/interface/logical/usage/:PFE" 5: 65265 6: 1477686534474 7: 1 8: 1 101 { 2636 { 7 { 1 { 1: "et-0/0/4:2.32767" 2: 1477642750 3: 813 4 { 12: 0x37363732332e3165 } . . .La siguiente estructura anidada en
2636identifica el tipo de sensor. El valor2636numérico identifica elJuniperNetworksSensormensaje, que se define en eltelemetry_top.protoarchivo. En este ejemplo, el identificador7numérico corresponde alLogicalPortmensaje definido en ellogical_port.protoarchivo. Utilice esta información en el siguiente paso para generar resultados más detallados.Descodificar el mensaje para incluir nombres de campo.
Ejecute el compilador de búferes de protocolo con la opción de descodificación. Además, especifique el tipo de mensaje de nivel superior (
TelemetryStream) y el archivo con la definición del mensaje,logical_port.proto. También debe incluir la biblioteca de búferes de protocolo de Goggle (gpb).protoc --decode TelemetryStream logical_port.proto -I /usr/include -I . < data.gpb system_id: "hillrock:160.1.1.25" component_id: 0 sensor_name: "S1:/junos/system/linecard/interface/logical/usage/:/junos/system/linecard/interface/logical/usage/:PFE" sequence_number: 65268 timestamp: 1477686536484 version_major: 1 version_minor: 1 enterprise { [juniperNetworks] { [jnprLogicalInterfaceExt] { interface_info { if_name: "et-0/0/4:2.32767" init_time: 1477642750 snmp_if_index: 813 parent_ae_name: "ae1.32767" ingress_stats { if_packets: 0 if_octets: 0 } egress_stats { if_packets: 0 if_octets: 0 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/7:3.0" init_time: 1477642750 snmp_if_index: 520 parent_ae_name: "ae0.0" ingress_stats { if_packets: 61203309 if_octets: 6487548454 } egress_stats { if_packets: 87416547 if_octets: 9266153982 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.0" init_time: 1477642750 snmp_if_index: 2512 ingress_stats { if_packets: 26266247 if_octets: 2784214806 } egress_stats { if_packets: 26247215 if_octets: 2781829290 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.1" init_time: 1477642750 snmp_if_index: 2522 ingress_stats { if_packets: 26266249 if_octets: 2784214972 } egress_stats { if_packets: 26249115 if_octets: 2781935590 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.2" init_time: 1477642750 snmp_if_index: 2523 ingress_stats { if_packets: 26266248 if_octets: 2784214912 } egress_stats { if_packets: 26249106 if_octets: 2781935086 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.3" init_time: 1477642750 snmp_if_index: 2524 ingress_stats { if_packets: 26266248 if_octets: 2784214820 } egress_stats { if_packets: 26248520 if_octets: 2781902320 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.4" init_time: 1477642750 snmp_if_index: 2525 ingress_stats { if_packets: 26266247 if_octets: 2784214760 } egress_stats { if_packets: 26247302 if_octets: 2781834112 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.5" init_time: 1477642750 snmp_if_index: 2526 ingress_stats { if_packets: 26266247 if_octets: 2784214760 } egress_stats { if_packets: 26247209 if_octets: 2781828904 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.6" init_time: 1477642750 snmp_if_index: 2527 ingress_stats { if_packets: 26266248 if_octets: 2784214820 } egress_stats { if_packets: 26247196 if_octets: 2781828226 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.7" init_time: 1477642750 snmp_if_index: 2528 ingress_stats { if_packets: 26266247 if_octets: 2784214760 } egress_stats { if_packets: 26247203 if_octets: 2781828618 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.8" init_time: 1477642750 snmp_if_index: 2529 ingress_stats { if_packets: 26266247 if_octets: 2784214760 } egress_stats { if_packets: 26247225 if_octets: 2781829850 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.9" init_time: 1477642750 snmp_if_index: 2530 ingress_stats { if_packets: 26266247 if_octets: 2784214760 } egress_stats { if_packets: 26247209 if_octets: 2781828954 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.32767" init_time: 1477642750 snmp_if_index: 648 ingress_stats { if_packets: 4 if_octets: 240 } egress_stats { if_packets: 0 if_octets: 0 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/4:2.32767" init_time: 1477642750 snmp_if_index: 813 parent_ae_name: "ae1.32767" ingress_stats { if_packets: 0 if_octets: 0 } egress_stats { if_packets: 0 if_octets: 0 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/7:3.0" init_time: 1477642750 snmp_if_index: 520 parent_ae_name: "ae0.0" ingress_stats { if_packets: 61206122 if_octets: 6487846632 } egress_stats { if_packets: 87420567 if_octets: 9266580102 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.0" init_time: 1477642750 snmp_if_index: 2512 ingress_stats { if_packets: 26267458 if_octets: 2784343172 } egress_stats { if_packets: 26248420 if_octets: 2781957020 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.1" init_time: 1477642750 snmp_if_index: 2522 ingress_stats { if_packets: 26267460 if_octets: 2784343338 } egress_stats { if_packets: 26250320 if_octets: 2782063320 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.2" init_time: 1477642750 snmp_if_index: 2523 ingress_stats { if_packets: 26267459 if_octets: 2784343278 } egress_stats { if_packets: 26250311 if_octets: 2782062816 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.3" init_time: 1477642750 snmp_if_index: 2524 ingress_stats { if_packets: 26267460 if_octets: 2784343292 } egress_stats { if_packets: 26249725 if_octets: 2782030050 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.4" init_time: 1477642750 snmp_if_index: 2525 ingress_stats { if_packets: 26267459 if_octets: 2784343232 } egress_stats { if_packets: 26248507 if_octets: 2781961842 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.5" init_time: 1477642750 snmp_if_index: 2526 ingress_stats { if_packets: 26267459 if_octets: 2784343232 } egress_stats { if_packets: 26248414 if_octets: 2781956634 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.6" init_time: 1477642750 snmp_if_index: 2527 ingress_stats { if_packets: 26267460 if_octets: 2784343292 } egress_stats { if_packets: 26248401 if_octets: 2781955956 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.7" init_time: 1477642750 snmp_if_index: 2528 ingress_stats { if_packets: 26267459 if_octets: 2784343232 } egress_stats { if_packets: 26248408 if_octets: 2781956348 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.8" init_time: 1477642750 snmp_if_index: 2529 ingress_stats { if_packets: 26267459 if_octets: 2784343232 } egress_stats { if_packets: 26248430 if_octets: 2781957580 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.9" init_time: 1477642750 snmp_if_index: 2530 ingress_stats { if_packets: 26267459 if_octets: 2784343232 } egress_stats { if_packets: 26248414 if_octets: 2781956684 } op_state { operational_status: "up" } } interface_info { if_name: "et-0/0/13:0.32767" init_time: 1477642750 snmp_if_index: 648 ingress_stats { if_packets: 4 if_octets: 240 } egress_stats { if_packets: 0 if_octets: 0 } op_state { operational_status: "up" } } } } }
Decodificación de datos UDP de interfaz de telemetría de Junos en el recopilador
El recopilador debe iniciar un agente de escucha en la dirección remota o en la combinación de puertos para leer los datos entrantes. Los datos entrantes se pueden decodificar utilizando los archivos telemetry_top.proto y el sensor proto.
Para simplificar el procedimiento de decodificación, los recopiladores pueden cargar todos los archivos proto enviados como parte del paquete Telemetry Software para decodificar los datos entrantes.
- Verifique los datos de streaming en las interfaces de administración y WAN. Especifique la dirección adecuada en el perfil del servidor de streaming.
- Las enumeraciones y float se transmiten como cadenas para la transmisión UDP. Las enumeraciones se conservarán como cadenas ya que gNMI usa el mismo formato.
- El ámbito del control del tipo de datos flotante está definido para una versión futura.
Cuando los datos de telemetría se transmitan a través de UDP, asegúrese de que los datos se decodifican correctamente y de que los campos desconocidos no se decodifican en el recopilador.
A continuación se muestran algunos problemas observados al transmitir datos de telemetría a través de UDP:
- Decodificación incorrecta: la decodificación incorrecta implica que los datos de telemetría no se transmiten correctamente a través de UDP. En el ejemplo siguiente, los datos resaltados en negrita indican que los datos no se decodificaron correctamente. Este comportamiento se debe a una codificación incorrecta o a un empaquetado incorrecto del archivo proto.
system_id: "r02.dtw01.icn" component_id: 65535 sensor_name: "mpls:/network-instances/network-instance/mpls:/network-instances/network-instance/mpls:rpd" sequence_number: 2421 timestamp: 1715024560793 version_major: 1 version_minor: 0 enterprise: { [juniperNetworks]: { [jnpr_network_instances_rsvp_ext]: { network_instance: { name: "master" mpls: { 153 { 151 { 152{ 151{ 51: "r02.dtw01.icn-r01.bos02.icn-01" 152{ 151{ 51: "AUTO" 52: 0 53: 12873154 } 152{ 151{ 51:1 52:200000 53: 0 54: 300 55: 1 61: 1549061 } 152 {A continuación se muestra el ejemplo de los datos que se decodifican correctamente:
system_id: "r0-RE0" component_id: 65535 sub_component_id: 0 sensor_name: "test_chassisd:/network-instances/:/network-instances/:rpd" sequence_number: 0 timestamp: 1719126223900 version_major: 1 version_minor: 0 enterprise { [juniperNetworks] { [jnpr_network_instances_ni_226_ext] { network_instance { name: "DEFAULT" protocols { protocol { identifier: "STATIC" name: "DEFAULT" static_routes { static { prefix: "10.0.0.0/8" state { prefix: "10.0.0.0/8" set_tag: "0" } next_hops { next_hop { index: "1" state { index: "1" next_hop: "10.220.127.254" metric: 0 recurse: false } interface_ref { state { interface: "re0:mgmt-0" subinterface: 0 } } } } } - Transmisión de datos incompleta: la transmisión de datos incompletos debe verificarse mediante la validación de datos en el archivo de salida.