Прямая инкапсуляция Интернет-сообщений - Direct Internet Message Encapsulation
Прямая инкапсуляция Интернет-сообщений (DIME) был Microsoft -предложенный в начале 2000-х годов Интернет-стандарт для потоковой передачи двоичных и других инкапсулированных данных через Интернет.
Согласно IETF веб-сайт, стандарт был снят и никогда не производился RFC положение дел. Однако в свое время Microsoft рекомендовала DIME для передачи файлов через Веб-сервисы. Он также использовался в Java EE, но различия в реализации протокола усложняли задачу.[нужна цитата ]
Первая версия[1] был представлен в IETF в ноябре 2001 г .; последнее обновление[2] был представлен в июне 2002 года. К декабрю 2003 года DIME проиграл, конкурируя с Механизм оптимизации передачи сообщений и SOAP с вложениями.[3] Microsoft теперь описывает DIME как «замененный спецификацией механизма оптимизации передачи сообщений SOAP (MTOM)».[4]
Стандарт задумывался как улучшенная версия MIME.[5] В частности, проблема с MIME заключается в том, что каждое сообщение должно быть закодировано как текст, а его разделы разделены разделителем, указанным в заголовке сообщения. Это означает, что весь поток данных должен быть известен отправителю до начала обмена, чтобы выбрать разделитель, который не встречается в данных. Это бесполезно, если весь поток недоступен при инициировании связи или если поиск стоит дорого. DIME больше ориентирован на потоковую передачу, позволяя, например, получателю обрабатывать фрагменты сообщения по мере их поступления, не дожидаясь всего сообщения.
Проблемы с HTTP
В этом разделе тон или стиль могут не отражать энциклопедический тон используется в Википедии.Январь 2015) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
DIME был определен формат передачи в уровень канала передачи данных в Модель OSI хотя обычно это передавалось через HTTP. Одна из трудностей заключалась в том, что он мог формировать HTTP-сообщение практически любого размера (предел - это информация о размере для каждого фрагмента, который составлял 32 бита, то есть 1 гигабит). Многие приемники HTTP не использовались для сообщений такого размера, и если бы они буферизовали сообщения, они просто не работали бы, ожидая короткого сообщения и получая огромное. Более того, если получатель HTTP был защищен, он, получив сообщение, отправил бы сообщение с запросом (код 400) отправителю. Поскольку HTTP не требует установления соединения, тогда он полностью потеряет возможно огромное количество данных, которые были отправлены ему, просто чтобы принять или отклонить вызов. Полностью удовлетворительного решения этой проблемы не было. Ответ на этот вызов, конечно, может быть успешным, за счет отправки данных дважды, что, если бы оно было огромным, скорее противоречит его сути. (Справедливо сказать, что любой другой метод отправки данных по HTTP страдает той же проблемой.) В альтернативном и, вероятно, лучшем решении критерии успешного запроса (например, имя пользователя и пароль) устанавливаются вне полосы пропускания, поэтому его можно отправить с сообщением в первый раз и не получить вызов (побочным продуктом протокола HTTP без установления соединения является то, что, поскольку каждое сообщение обрабатывается индивидуально, любой сообщение должно иметь возможность успешно включать свой ответ на запрос).
DIME был чрезвычайно быстрым по сравнению с практическим применением других протоколов. Поскольку данные были двоичными, а не, скажем, Base64 закодированный, он был относительно компактен, а встроенные в протокол методы разбиения на части и пакетов означали, что его можно было передать в потоковом режиме и прочитать подходящим приемником до того, как все сообщение будет прочитано.
Проблемы на сетевом уровне
Поскольку DIME был определен на уровне канала данных, было возможно инкапсулировать сообщение DIME в другом сообщении DIME. Это не помогло вообще для целей сжатия, но иногда было полезно для обхода сетевой инфраструктуры, такой как маршрутизаторы на сетевом уровне модели ОС, которая в противном случае заблокировала бы инкапсулированный трафик (будучи двоичными, они могут относиться к нему с подозрением). При этом другие протоколы, такие как MIME, также могут пострадать от этого. Поскольку DIME обычно использовался между доверенными клиентами, на маршрутизаторе можно было открыть определенный порт для прямой отправки и получения трафика DIME. Это не повлияло на аспекты безопасности, так как проблема все равно возникнет, просто он признал, что двоичный трафик был нормой для этого порта, и не дал большого количества ложные срабатывания.
Смотрите также
Рекомендации
- ^ «Архивная копия». Архивировано из оригинал на 2009-02-09. Получено 2006-01-26.CS1 maint: заархивированная копия как заголовок (связь)
- ^ «Архивная копия». Архивировано из оригинал на 2011-03-22. Получено 2006-01-26.CS1 maint: заархивированная копия как заголовок (связь)
- ^ Зальц, Рич (2003-12-12). "Re: Где я могу узнать о текущем состоянии DIME". Архивировано из оригинал на 2007-09-27. Получено 2006-10-31.
- ^ "Индексная страница спецификаций сообщений". Microsoft. Архивировано из оригинал на 2011-06-06. Получено 2006-10-31.
- ^ http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnservice/html/service01152002.asp