MEGAlink - Википедия - MEGAlink

MEGAlink
Протокол связи
Цельпротокол передачи файлов
Разработчики)Пол Майнерс
Введено1987; 33 года назад (1987)
На основеXMODEM
Аппаратное обеспечениемодемы

MEGAlink это протокол передачи файлов за модем -оборудован микрокомпьютеры написан Полом Майнерсом в 1987 году. Как и многие протоколы того времени, MEGAlink является расширенной версией основополагающего XMODEM. Хотя это была относительно простая и высокопроизводительная система, она остается относительно неясной, потому что ее затмили ZMODEM, который был выпущен годом ранее и быстро стал популярным.

История

XMODEM был представлен в 1977 году как то, что его автор назвал «быстрым взломом». У него был ряд довольно очевидных проблем, которые становились все более раздражающими по мере увеличения скорости модема в начале 1980-х. За этот период появился ряд новых протоколы передачи файлов для пользователей BBS появился для решения проблем в исходном XMODEM. Многие из них имели собственные незначительные проблемы или были ограничены определенными приложениями, что ограничивало их использование. XMODEM оставался чрезвычайно популярным на протяжении всего этого периода, поскольку это был один из немногих протоколов, который поддерживался повсеместно.

В 1986 г. Чак Форсберг вышел ZMODEM, радикально улучшенный протокол передачи файлов, предлагающий множество новых функций, высокую производительность и работающий со службами, нарушающими передачу XMODEM.[а] Единственным недостатком ZMODEM было то, что он был очень сложным, что делало его трудным или невозможным для реализации на некоторых машинах, особенно из-за большой установленной базы таких систем, как Коммодор 64.

MEGAlink был представлен как часть Meiners ' GT PowerComm эмулятор терминала для решения этой проблемы. Он предлагал высокую производительность, аналогичную ZMODEM, но при этом был намного проще в реализации. Несмотря на эту привлекательную комбинацию функций, MEGAlink так и не стал популярным, и несколько других эмуляторов терминала, похоже, добавили поддержку.[1] - обзорная статья 1988 года показывает только PowerComm и еще одну программу, поддерживающую его.[2]

Переход от 8-битных к 16-битным компьютерам происходил одновременно с внедрением MEGAlink, и к концу 80-х годов прошлого века любые преимущества с точки зрения простоты уже обсуждались. ZMODEM стал почти универсальным.

Описание

XMODEM

XMODEM это простой протокол, и это основная причина его популярности.[3]

Отправляемый файл разбивается на блоки по 128 байт, которые образуют данные полезной нагрузки своего пакеты. 3-байтовый заголовок, состоящий из SOH символ и два 8-битных целых числа добавляются перед данными и 1-байтовым контрольная сумма в конце, делая общий пакет длиной 132 байта. Протокол запускается получателем, который отправляет НАК символ, чтобы начать передачу, ждет пакета в ответ, а затем отправляет ACK если пакет был получен правильно, или НАК если бы это было не так.[4]

Поскольку в телефонной системе имеется определенное количество задержка, требуется некоторое время для ACK или же НАК чтобы вернуться по линиям и инициировать отправку следующего пакета. При 300 бит / с это представляет собой короткое время по сравнению со временем, необходимым для отправки пакета данных, поэтому это можно игнорировать. При скорости 2400 бит / с обычные задержки означают, что до 50% доступного времени тратится на ожидание ответов.[4]

Для решения этой проблемы было предложено множество решений. Один из них - сделать размер пакета больше, чтобы задержка представляла меньшую часть времени, необходимого для отправки пакета. Это использовалось в ряде протоколов, в частности YMODEM.[4] Другое решение - использовать раздвижное окно который позволяет отправлять несколько пакетов без необходимости ACK для каждого, как используется в WXMODEM и других.

MEGAlink

MEGAlink - это, по сути, комбинация функций из предыдущих попыток улучшить производительность XMODEM. Самым основным изменением было увеличение размера пакета со 128 до 512 байт. Это не только снижает относительное влияние задержки, но и увеличивает объем данных по сравнению с посторонней информацией, такой как байты заголовка и нижнего колонтитула, улучшая его эффективность канала.[5]

MEGAlink намеренно отказался от решения со скользящим окном, исключив необходимость отправки ACK вообще. Отправитель просто продолжал бы посылать пакеты до тех пор, пока НАК был получен. В НАК был отправлен с двумя последующими байтами, первый из которых содержит номер пакета, в котором произошла ошибка, а второй как два дополнения из этого числа. Затем отправитель перезапустит перевод с этого момента.[5]

Чтобы при необходимости быстро повторно отправить данные, отправитель должен был поддерживать буфер данных данных файла, чтобы можно было быстро перемотать к этому моменту. Машины той эпохи имели небольшой объем памяти, 64 КБ не были редкостью, поэтому большие буферы было нелегко организовать. Чтобы устранить тот факт, что у отправителя может не хватить памяти для отправки очень длинных потоков, MEGAlink разрешил отправителю запросить ACK в любой момент, что позволит ему очистить буфер при необходимости.[5]

Для этого отправитель отправил ASCII RS (Разделитель записей) символ. Если получатель видит RS вместо ожидаемого SOH в начале следующего пакета он немедленно отправляет ответ, состоящий из ACK и номер пакета и обратное, как в случае НАК. Затем отправитель может удалить из своего буфера любые данные, предшествующие этому пакету. Например, GT PowerComm использовал буфер, достаточно большой для 32 пакетов, и отправил RSs запрашивают каждые 16 пакетов или около того.[5]

Остальные изменения в протоколе более мелкие. Чтобы разрешить работу в некоторых сетях, например PC Pursuit, XON и XOFF персонажей сбежали с DLE а затем XORed с 64. Для этого требовалось любое DLE в исходных данных, которые нужно экранировать таким же образом.[5]

32-битный CRC

В исходной версии MEGAlink использовалась 16-битная циклическая проверка избыточности (CRC), как и многие другие ответвления XMODEM. Как и в этих версиях, получатель указал, что он может принимать CRC, отправив начальный C вместо НАК чтобы начать передачу. Позже MEGAlink был модифицирован для поддержки 32-битных CRC, что и было сделано путем запуска пакетов с ЭМ вместо того SOH. «Нулевой пакет», содержащий информацию о файле, всегда отправлялся со стандартным SOH и 16-битный CRC, только следующие пакеты данных использовали ЭМ формат.[5]

Примечания

  1. ^ XMODEM требовал 8-битных чистых ссылок, которые не всегда поддерживались основными онлайн-сервисами.

Рекомендации

Цитаты

Библиография

  • Бигли, Том; Тапамила, Глен (7 декабря 1987 г.). «Карманный справочник по протоколам передачи файлов». InfoWorld.CS1 maint: ref = harv (ссылка на сайт)
  • Кристенсен, Уорд (1 января 1982 г.). Обзор протокола XMODEM (Технический отчет).CS1 maint: ref = harv (ссылка на сайт)
  • Форсберг, Чак (10 октября 1985 г.). Ссылка на протокол XMODEM / YMODEM, автор - Чак Форсберг (Технический отчет).CS1 maint: ref = harv (ссылка на сайт)
  • Майнерс, Пол (9 августа 1987 г.). MEGAlink: протокол передачи файлов (Технический отчет).CS1 maint: ref = harv (ссылка на сайт)
  • "Лучшие коммуникационные программы условно-бесплатного ПО". Обзор Информационного центра. Апрель 1988. с. 1326.