6-я лекция

реклама
Санкт-Петербургский государственный университет
информационных технологий, механики и оптики
Кафедра проектирования компьютерных систем
В. А. Козак
Вычислительные сети
Лекция 6
Транспортный и прикладной
уровни
Санкт-Петербург, 2009
Транспортный уровень
• Сердцевина всей иерархии протоколов, посредник между
приложениями и транспортной инфраструктурой сети;
• Работает на пользовательских машинах;
• Обеспечивает передачу данных между приложениями
(прикладными процессами) вне зависимости от физических
характеристик использующейся сети или сетей с требуемой
степенью надежности;
• Может управлять соединением, обнаруживать потерянные пакеты
и искаженные данные;
• Протоколы предназначены для взаимодействия типа «точка—
точка».
• Примеры протоколов: TCP, UDP, SPX.
Сокеты
• Сокет - абстрактный объект, представляющий конечную точку
соединения.
• Сокет - комбинация IP-адреса и номера порта, например
10.10.10.10:80.
• Интерфейс сокетов впервые появился в BSD Unix.
UDP (User Datagram Protocol)
• UDP (пользовательский дейтаграммный протокол). UDP
позволяет приложениям отправлять инкапсулированные IPдейтаграммы без установления соединений.
• Смысл использования UDP вместо обычного IP заключается в
указании портов источника и приемника.
• UDP не занимается контролем потока, контролем ошибок,
повторной передачей после приема испорченного сегмента.
TCP (Transmission Control Protocol)
• TCP (протокол управления передачей) протокол для
обеспечения надежного сквозного байтового потока
по ненадежной интерсети.
• Размер сегментов (дейтаграмм) ограничивается
размером полезной нагрузки IP-пакета (65 515 байт) и
максимальной единицой передачи (MTU, Maximum
Transfer Unit) сети.
• На практике размер максимальной единицы передачи
составляет обычно 1500 байт (что соответствует
размеру поля полезной нагрузки Ethernet).
• При передаче используется механизм скользящего
окна.
• Используется для передачи трафика, чувствительного
к потерям.
Заголовок TCP сегмента
Прикладной уровень (Application layer)
• Является набором разнообразных протоколов, с
помощью которых пользователи сети получают
доступ к разделяемым ресурсам, организуют
совместную работу.
• Обеспечивает взаимодействие сети и пользователя.
• Разрешает приложениям пользователя иметь доступ
к сетевым службам, таким как обработчик запросов к
базам данных, доступ к файлам, пересылке
электронной почты.
• Отвечает за передачу служебной информации.
• Предоставляет приложениям информацию об
ошибках.
• Формирует запросы к уровню представления.
• Пример: HTTP, POP3, SMTP.
Наиболее популярные протоколы
• Telnet - протокол удаленного доступа, позволяет
входить в систему и выполнять действия над ней.
• SSH - протокол, позволяющий производить удалённое
безопасное управление операционной системой и
туннелирование TCP-соединений, шифрует весь
трафик.
• HTTP – передача данных (обычно гипертекстовые
страницы).
• FTP - пересылка файлов и удаленный доступ к ним.
• SFTP – протокол для операций с файлами поверх
надёжного и безопасного соединения.
Наиболее популярные протоколы
•
•
•
•
SMTP – отправка почтовых сообщений.
POP3 – прием (закачка) эл. почты.
IMAP - доступ к хранилищу эл. почты.
XMPP (Jabber) - протокол для мгновенного обмена
сообщениями и информацией о присутствии.
• RTP – транспортный протокол реального времени.
Используется в IP-телефонии для передачи
речевого трафика.
• SIP – сигнальный протокол IP-телефонии, управляет
процессами создания, завершения, управления и
конфигурирования телефонных соединений.
RTP (Real-Time Transport Protocol )
• RTP - транспортный протокол реального масштаба
времени, реализованный на прикладном уровне.
• Основная функция RTP - уплотнение нескольких
потоков реального масштаба времени в единый поток
пакетов UDP.
• Нет никаких гарантий касательно доставки, дрожания
(неустойчивой синхронизации) и т. д.
• Каждый пакет, посылаемый с потоком RTP, имеет
номер, на единицу превышающий номер своего
предшественника. При потере пакета необходимо
путем интерполяции аппроксимировать (приблизить,
предположить) пропущенное значение.
Заголовок RTP
Всемирная паутина (World Wide Web)
• Всемирная паутина (World Wide Web) - распределенная
система, предоставляющая доступ к связанным между
собой документам, расположенным на различных
компьютерах, подключенных к Интернету
• Web-страница -> Web-сайт -> Web-сервер -> WWW
• С 1994 года развитием Всемирной паутины руководит
Консорциум Всемирной паутины (World Wide Web
Consortium, W3C)
Ключевые технологии WWW
• HTTP (HyperText Transfer Protocol - протокол
передачи гипертекста)
• URI (Uniform Resource Identifier - единообразный
идентификатор ресурса)
• URL (Uniform Resource Locator - единообразный
локатор ресурса)
• Ключевые технологии формирования Web-страниц:
HTML, CSS, XML, DOM, Java-апплеты, скрипты
(JavaScript, VBScript), Flash и т.д.
HTTP (HyperText Transfer Protocol)
• Протокол прикладного уровня передачи данных (изначально —
в виде гипертекстовых документов). Работает поверх ТСР, порт
80 и 8080.
• Модель клиент-сервер.
• Достоинства: простота, расширяемость, распространённость.
• Основные заголовки: Content-Length, Content-Type, ContentEncoding, Content-Language, Connection.
• Особенности:
– Установление и закрытие соединения непосредственно с
сервером производится по ТСР. Контроль за
пользовательскими данными возложен на ТСР;
– Использует принцип запрос/ответ;
– Сервер не сохраняет параметры предыдущих сессий и не
сохраняет своего текущего состояния;
– Возможность кэширования (proxy и в браузере).
Алгоритм работы HTTP
• Анализ URL (адреса документа). Для определения IP-адреса
сервера по имени хоста (host name) используется DNS.
• Установление ТСР-соединения с сервером.
• Отсылка запроса на сервер. Возможны методы GET, POST, HEAD
и др.
• Анализ ссылок без имени хоста (после первого одиночного слэша):
URL: http://www.sut.ru/news
Анализируется: /news
• Формирование и пересылка ответа.
Коды ответов:





1xx: Informational (Информационные)
2xx: Success (Успешно)
3xx: Redirection (Перенаправление)
4xx: Client Error (Ошибка клиента)
5xx: Server Error (Ошибка сервера)
Электронная почта (email, e-mail)
Электронная почта - технология и предоставляемые ею услуги по
пересылке и получению электронных сообщений по
распределённой компьютерной сети.
Формат адреса: user@example.com — пользователь user на машине
example.com (с появлением почтовых серверов example.com –
адрес сервера, на котором зарегестрирован user).
Почтовые протоколы: SMTP / POP3 (IMAP, MAPI), веб-интерфейсы,
X.400 и др.
Структура письма:
• Заголовок SMTP-протокола
• Письмо (в терминологии протокола SMTP — 'DATA')
а) Заголовок письма
б) Тело письма.
Электронная почта (email, e-mail)
Компоненты:
• MTA (Mail Transfer
Agent - агент
пересылки почты)
• MDA (Mail Delivery
Agent -агент
доставка почты)
• MUA (Mail user
agent — почтовый
агент
пользователя)
• MRA (Mail retrive
agent — почтовый
сервер, забирающий
почту с другого
сервера)
Скачать