Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Met_SNMP (управление сетями связи).doc
Скачиваний:
0
Добавлен:
01.07.2025
Размер:
1.95 Mб
Скачать

3.2.4. Поля протокола snmp

Наконец, мы добрались до расшифровки самого SNMP-сообщения. Чтобы разобрать отдельные его составляющие, приведем все поля, относящиеся к протоколу SNMP отдельно.

Итак, фрагмент SNMP-сообщения, вложенного в информационную часть протоколов UDP/IP/Ethernet выглядит так:

30 81 fb 02 01 00

0030: 04 06 76 6d 31 35 2d 31 a0 81 ed 02 04 35 97 ac

0040: 55 02 01 00 02 01 00 30 81 de 30 0c 06 08 2b 06

0050: 01 02 01 01 03 00 05 00 30 0e 06 0a 2b 06 01 02

0060: 01 02 02 01 05 01 05 00 30 0e 06 0a 2b 06 01 02

0070: 01 02 02 01 08 01 05 00 30 0e 06 0a 2b 06 01 02

0080: 01 02 02 01 09 01 05 00 30 0e 06 0a 2b 06 01 02

0090: 01 02 02 01 0a 01 05 00 30 0e 06 0a 2b 06 01 02

00a0: 01 02 02 01 0b 01 05 00 30 0e 06 0a 2b 06 01 02

00b0: 01 02 02 01 0c 01 05 00 30 0e 06 0a 2b 06 01 02

00c0: 01 02 02 01 0d 01 05 00 30 0e 06 0a 2b 06 01 02

00d0: 01 02 02 01 0e 01 05 00 30 0e 06 0a 2b 06 01 02

00e0: 01 02 02 01 10 01 05 00 30 0e 06 0a 2b 06 01 02

00f0: 01 02 02 01 11 01 05 00 30 0e 06 0a 2b 06 01 02

0100: 01 02 02 01 12 01 05 00 30 0e 06 0a 2b 06 01 02

0110: 01 02 02 01 13 01 05 00 30 0e 06 0a 2b 06 01 02

0120: 01 02 02 01 14 01 05 00

Для упрощения расшифровки данного сообщения, разобъем это сообщение на отдельные составляющие в соответствии с форматом, приведенным в разделе 2.2 и на рис. 7, 8 и 9, а также в соответствии с правилами кодирования SNMP-сообщений:

30 81 fb

04 06 76 6d 31 35 2d 31

a0 81 ed

02 04 35 97 ac 55

02 01 00

02 01 00

30 81 de

30 0c 06 08 2b 06 01 02 01 01 03 00 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 05 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 08 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 09 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0a 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0b 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0c 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0d 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0e 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 10 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 11 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 12 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 13 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 14 01 05 00

Учитывая рекомендации, приведенные в разделе 2.3, применим к данному формату конструкцию T-L-V, чтобы расшифровать отдельные ИЭ сообщения SNMP:

Конструкция – t-l-V (Tag-Length-Value)

30 81 fb

T L (……… V ……

02 01 00

T L V

04 06 76 6d 31 35 2d 31

T L V

a0 81 ed

T L (……… V ……

02 04 35 97 ac 55

T L V

02 01 00

T L V

02 01 00

T L V

30 81 de

T L (……… V ……

30 0c 06 08 2b 06 01 02 01 01 03 00 05 00

T L (T L ( V=OID ))

Остальные части кодируются аналогично:

30 0e 06 0a 2b 06 01 02 01 02 02 01 05 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 08 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 09 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0a 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0b 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0c 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0d 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 0e 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 10 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 11 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 12 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 13 01 05 00

30 0e 06 0a 2b 06 01 02 01 02 02 01 14 01 05 00

Учитываем, что ИЭ, кодируемые тэгом=30 или a0, содержащим в 6-м бите единицу, имеют составной тип, следовательно, внутри этих элементов содержатся другие ИЭ по принципу матрешки.

Расшифруем теперь отдельные части SNMP-сообщения:

30 81 fb

T L (……… V ……

– Заголовок протокола SNMP (флаг), содержащий тэг (30 - Sequence) и длину содержимого (81 fb – длинный формат, обозначающий, что в поле «Длина» содержится 1 байт, а его значение – fb’hex или 251 байт)

02 01 00

T L V

– Версия протокола SNMP (Тэг=02, что означает целое число в поле «содержимое», длина этого содержимого равна 1 байту, а 00 в поле содержимое – означает, что используется версия SNMPv1)

04 06 76 6d 31 35 2d 31

T L V

– поле “Community” длиной 6 байт, в котором содержится строка октетов (тэг=04), кодирующих содержимое в формате IA5.

В данном случае поля 76 6d 31 35 2d 31’hex означают, что пароль доступа к полю “Community” – vm15-1

a0 81 ed

T L (……… V ……

– имя PDU-SNMP. В данном случае – это Get-request (тэг=a0), а длина содержимого в этом PDU составляет ed’hex или 237’dec байт

Далее, учитывая, что имя данного PDU – Get, используем его формат (см. рис. 7 и 8 в разделе 2.2, а также форму записи на языке ASN.1 в разделе 2.3.5.3 для заголовка Get-PDU):

Заголовок SNMP

Заголовок PDU

(для Get, GetNext, Set, Response)

Переменные

(Идентификаторы объектов в MIB, значения параметров)

Версия

Пароль

(Community)

Тип

PDU

Идентификатор

PDU

Статус ошибки

Индекс ошибки

Имя

(Tag)

Длина

(L)

Значение

(Value)

Vers – 1

По умолчанию:

public

См. табл.1

Целое значение от 0 до 232-1

См. табл.2

См. ниже

***

****

Имя

(Tag)

Длина

(L)

T

L

V

T

L

V

T

L

V

T

L

V

T

L

V

T

L

V

T

L

T

L

V

Или в форме ASN.1:

The GetRequest-PDU

GetRequest-PDU ::=

[0]

IMPLICIT SEQUENCE {

request-id

RequestID,

error-status -- always 0

ErrorStatus,

error-index -- always 0

ErrorIndex,

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]