Существующие четыре пары запросов/ответов используются в процессе согласования характеристик обмена:
| DO (код варианта) | Запрос от партнера на выполнение операции. |
| WILL (код варианта) | Согласие партнера. Запрашиваемый вариант согласован. |
| DO (код варианта) | Запрос от партнера на выполнение операции. |
| WON'T (код варианта) | Отказ партнера. Состояние обмена не меняется. |
| WILL (код варианта) | Указывает на желание начать операцию. |
| DO (код варианта) | Согласие партнера. Запрашиваемый вариант согласован. |
| WILL (код варианта) | Указывает на желание начать операцию. |
| DONT (код варианта) | Отказ партнера. Состояние обмена не меняется. |
| WON'T (код варианта) | Подтверждение сохранения текущего состояния обмена. |
При запуске соединения между партнерами производится обмен множеством сообщений. Иногда согласование варианта работы происходит и в середине сеанса. Некоторые сигналы выбора варианта начинают дополнительное согласование (subnegotiations), с обменом соответствующей информацией.
Что происходит, когда обе стороны отказываются от каждого запроса выбора варианта? Ответ прост — сеанс остается в режиме NVT.
13.6.1 Типы терминалов
Очень важен выбор типа терминала (Terminal Type). При этом происходит дополнительное согласование. Клиент посылает WILL TERMINAL TYPE, сообщая серверу типы терминалов, которые он может эмулировать. При желании ознакомиться с этой информацией сервер отвечает: DO TERMINAL TYPE.
Далее при дополнительном согласовании сервер запросит у клиента указать один из типов терминала, которые может эмулировать клиент. Клиент ответит сообщением установленного формата. Сервер продолжит запросы, пока не найдет в ответах клиента нужного типа терминала или пока не закончится список доступных для эмуляции клиентом типов терминалов. Допустимые типы терминалов определены в RFC Assigned Numbers: это могут быть DEC-VT100, HP-2648 или IBM-3278-2.
13.6.2 Согласование типа терминала VT100
В приведенном ниже примере диалога мы запустили сеанс telnet и ввели команду toggle options (переключение варианта), указывающую telnet на отображение операций по согласованию параметров. Команда open используется для запуска регистрации. Партнеры согласовывают между собой эмуляцию терминала ASCII VT100, выбирая следующие характеристики:
■ Сервер не будет посылать сообщений Go Ahead, поскольку сеанс работает в полнодуплексном режиме.
■ Используется дополнительное согласование типа терминала для указания на эмуляцию определенной модели терминала ASCII.
■ Сервер будет выполнять эхо-печать всех символов от клиента.
Ни одна из сторон не обязана ожидать ответа на запрос перед посылкой другого запроса. Согласующая сторона может отвечать на запросы в иной последовательности, чем они были отправлены. В результате иногда нужно распутать серию сообщений о согласовании, прежде чем станет понятна последовательность выполнения операций.
> telnet
telnet> toggle options
Will show option processing.
telnet> open cantor.cs.yale.edu
Trying 128.36.12.26 ... Connected to cantor.cs.yale.edu.
Escape character is '^]'.
SENT do SUPPRESS GO AHEAD
SENT will TERMINAL TYPE (ответ)
RCVD do TERMINAL TYPE (без ответа)
RCVD will SUPPRESS GO AHEAD (без ответа)
RCVD will ECHO (ответ)
SENT do ECHO (ответ)
login:
13.6.3 Согласование характеристик терминала 3270
Аналогичный обмен происходит при установке эмуляции типа терминала IBM 3270. Показанный ниже диалог представляет согласование регистрации на хосте IBM VM с терминала 3270. В этом примере удаленный хост выводит на экран сведения для дополнительного согласования при установке типа терминала. Партнеры согласовывают между собой эмуляцию терминала IBM 3278 Model 2 с выбором следующих характеристик:
■ Дополнительное согласование типа терминала специфицирует для терминала 3270 вариант "3278 модель 2".
■ Клиент и сервер запрашивают вариант END OF RECORD, чтобы установить для терминала 3270 блочный режим.
■ Обе стороны соглашаются использовать 8-разрядные двоичные данные для представления потока данных терминала 3270.
> tn3270
tn3270> toggle options
Will show option processing.
tn3270> open uoft.utoledo.edu
Trying...
Connected to uoft.utoledo.edu.
RCVD do TERMINAL TYPE (ответ)
SENT will TERMINAL TYPE (без ответа)
Received suboption Terminal type - request to send.
Sent suboption Terminal type is IBM-3278-2.
RCVD do END OF RECORD (ответ)
SENT will END OF RECORD (без ответа)
RCVD will END OF RECORD (ответ)
SENT do END OF RECORD (ответ)
RCVD do BINARY (ответ)
SENT will BINARY (без ответа)
RCVD will BINARY (ответ)
SENT do BINARY (ответ)
RUNNING
13.7 Управление текстовым клиентом telnet
Время от времени требуется осуществить взаимодействие с текстовым клиентом telnet и вывести или установить его параметры. Локальные команды конкретной реализации можно выяснить, если запустить telnet и напечатать "?" или "help".
> telnet
telnet> ?
Commands may be abbreviated. Commands are: