1 / 35

Petrozavodsk State University, Alex Moschevikin, 2004

TCP/IP. Литература по данной лекции: Н.Олифер, В.Олифер. Введение в IP сети http:// www.zeiss.net.ru / docs / technol / tcpip / tcp00.htm (TCP/IP крупным планом ) http:// www.citforum.ru /internet/comer/ contents.shtml ( Д.Комер. Протоколы TCP/IP)

zev
Download Presentation

Petrozavodsk State University, Alex Moschevikin, 2004

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. TCP/IP • Литература по данной лекции: • Н.Олифер, В.Олифер. Введение в IP сети • http://www.zeiss.net.ru/docs/technol/tcpip/tcp00.htm (TCP/IP крупным планом) • http://www.citforum.ru/internet/comer/contents.shtml (Д.Комер. Протоколы TCP/IP) • http://www.citforum.ru/internet/tcpip/index.shtml (Брежнев А.Ф., Смелянский Р.Л. Семейство протоколов TCP/IP) Rev. 2.02 / 19.04.2014 Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  2. История развития TCP/IP Интернет, базирующийся на стеке протоколов TCP/IP, развился из сети ARPANET (Advanced Research Projects Agency Network), построение которой началось в 1969 году в США на базе университетов под надзором министерства обороны. декабрь 1969года 1973 год Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  3. История развития TCP/IP 1977 год Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  4. OSI/RM и TCP/IP Стек TCP/IP (Transmission Control Protocol / Internet Protocol, протокол управления передачей/межсетевой протокол) в отличие от OSI/RM содержит всего 4 уровня: I – прикладной, II – транспортный, III – межсетевой, IV – физический (физического интерфейса). Все они в той или степени соответствуют уровням идеальной модели, т. е. выполняют похожие функции. Петрозаводский гос. университет, Алексей Мощевикин, 2006 Net Security

  5. Системы адресации Адресации: 1. Прикладной уровень (служба DNS, имя компьютеров в рабочих группах Windows, др. системы символьной адресации), адресация в глобальных и локальных сетях 2. сетевой уровень (IP, IPX адреса), адресация в глобальных сетях 3. канальный уровень (МАС адрес), адресация в локальных сетях Службы: ARP/RARP (Address Resolution Protocol) – 2-3 DNS (Domain Name Service) – 1-2 Возможны службы для связи систем адресации 1-3 Петрозаводский гос. университет, Алексей Мощевикин, 2006 Net Security

  6. Типы адресов Типы адресов • физический (например, MAC-адрес 00-0b-6a-85-b6-41, АТМ адрес NSAP, глобальный адрес X.25, логический адрес канального уровня) • сетевой (например, IP-адрес, две части: номер сети и номер интерфейса в этой сети). Узел может иметь несколько IP адресов по количеству сетей, к которым подключен. Одному физическому интерфейсу может быть приписано несколько IP адресов, или, наоборот, одному адресу сетевого уровня соответствует несколько адресов канального уровня, но чаще всего бывает соответствие MAC адрес - IP адрес (службы ARP и RARP), например, маршрутизатор обычно имеет несколько сетевых интерфейсов с парами МАС-адрес - IP адрес. • логический символьный (например, DNS-имя). Данная адресация соответствует прикладному уровню модели OSI/RM. Символьные логические адреса введены для удобства пользования глобальными адресами. Одному символьному имени может соответствовать несколько адресов сетевого уровня (например, распределенная структура серверов altavista.com)или одному IP адресу может соответствовать несколько символьных (для создания виртуальных серверов, названий веб-сайтов). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  7. Мультиплексирование Петрозаводский гос. университет, Алексей Мощевикин, 2006 Net Security

  8. Классы IP адресов IP адреса записываются в десятично-точечной нотации, каждый байт (значения в диапазоне 0-255) отделяется от соседнего точкой. Всего в Интернете возможно существование менее 232 хостов (сетевых интерфейсов). Выделение хоста в сети позволяет придерживаться четкой двухуровневой иерархической структуры. На данный момент существует бесклассовая система адресации (Classless Internet Domain Routing), характеризуемая любой длиной номера сети и хоста в пределах 32 бит. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  9. Соглашение о спец. IP адресах • Весь адрес состоит из 0 (0.0.0.0) - адрес данного узла, разрешается только при загрузке системы, не может быть адресом назначения. • Поле адреса сети = 0 (например, 0.0.0.134) - узел 134 принадлежит данной сети. • Весь адрес состоит из 1 (255.255.255.255) - ограниченное в пределах локальной сети (на канальном уровне, до первого маршрутизатора) широковещание (не может быть адресом отправителя). • В поле хоста все 1 (например, 135.202.255.255 для сети класса В) - то широковещание в конкретной сети (не может быть адресом отправителя). • 127.хх.хх.хх (например, 127.0.0.1) - localhost, loopback, обратная связь (никогда не передается в сеть, используется для тестирования стека TCP/IP на данном компьютере). • Закрытые сети (синонимы: частная сеть, сеть интранет, нереальные IP адреса, серые IP адреса, нетранслируемые в Интернет IP адреса) - для соответствующих классов сетей IP адреса в следующих диапазонах: 10.0.0.0 - 10.255.255.255 172.16.0.0 - 172.31.255.255 192.168.0.0 - 192.168.255.255 Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  10. Маска IP адреса Назначение маски IP адреса - отделять часть, отвечающую за номер сети от части, идентифицирующей номер хоста в данной сети. Использование: маршрутизация и ограниченное широковещание. Маска IP - это неразрывный последовательный бинарный ряд логических 1, оканчивающийся неразрывным рядом 0 общей длиной 32 бита. Например, маска IP адреса класса А: 11111111 00000000 00000000 00000000 маска IP адреса класса В: 11111111 11111111 00000000 00000000 маска IP адреса класса С: 11111111 11111111 11111111 00000000 маска длиной в 22 бита: 11111111 11111111 11111100 00000000 Иногда значение маски пишется справа после IP адреса через слеш и обозначает битовую длину части адреса, отвечающего за IP сеть,иногда в виде IP адреса, например: 134.171.0.14/25 или 255.255.255.128 – маска в 25 бит. Выделением IP адресов в глобальном адресном пространстве ведает InterNIC (Network Information Center), в России - РосНИИРОС (Российский научно-исследовательский институт развития общественных сетей). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  11. Использование маски Как определить номер узла в сети, номер сети, а также адрес ограниченного в пределах данной сети широковещания? Для этого необходимо наложить побитно маску сети на заданный IP адрес и проделать некоторые арифметические действия. Пример 1. Дано: IP адрес 192.168.31.240, сеть класса С (маска в 24 бита). Найти: номер сети, номер узла в сети, а также адрес ограниченного в пределах данной сети широковещания. IP адрес 11000000 10101000 00011111 11110000 маска 11111111 11111111 11111111 00000000 (255.255.255.0) --------------------------------------------------------------------------- номер сети 11000000 10101000 00011111 00000000 (192.168.31.0) номер хоста 00000000 00000000 00000000 11110000 (0.0.0.240) адрес широковещ. 11000000 10101000 00011111 11111111 (192.168.31.255) Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  12. Использование маски Пример 2. IP адрес 12.200.17.242, сеть с маской в 23 бита. IP адрес 00001100 11001000 00010001 11110010 маска 11111111 11111111 11111110 00000000 (255.255.254.0) --------------------------------------------------------------------------- номер сети 00001100 11001000 00010000 00000000 (12.200.16.0) номер хоста 00000000 00000000 00000001 11110010 (0.0.1.242) адрес широковещ. 00001100 11001000 00010001 11111111 (12.200.17.255) Пример 3. IP адрес 12.200.17.242, сеть с маской в 29 бит. IP адрес 00001100 11001000 00010001 11110010 маска 11111111 11111111 11111111 11111000 (255.255.255.248) --------------------------------------------------------------------------- номер сети 00001100 11001000 00010001 11110000 (12.200.17.240) номер хоста 00000000 00000000 00000000 00000010 (0.0.0.2) адрес широковещ. 00001100 11001000 00010001 11110111 (12.200.17.247) Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  13. ARP, RARP Отображение физических адресов на IP-адресаосуществляется при помощи протоколов ARP (Address Resolution Protocol) и RARP (Reversed ARP).Сетевой IP адрес не связан с МАС адресом, как это сделано в IPX. ARP:широковещательный запрос требуемого МАС адреса по известному IP адресу. ARP таблица (arp -a). RARP используется при старте бездисковых станций. Формат ARP/RARP пакета (инкапсулируется вкадр канального уровня) При ARP запросе поле "искомый MAC адрес" оставляют незаполненным. Значение этого полязаполняется узлом, опознавшим свой IP. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  14. DNS Распределенная база данныхдоменных имен поддерживается службойDomain Name Service.DNS обеспечивает иерархическую систему имен для идентификации узлов в сети Internet. Два вида запросов в DNS сервера: прямой (по доменному имениищется IP адрес) и обратный (доменное имя по IP адресу). Прямой поиск необходим при обычном Интернет-серфинге, когда браузер должен организовывать http сеансы связи с веб-серверами, IP адреса которых изначально неизвестны. Поиск в обратной зоне востребован некоторыми службами, напримерв ходе smtp связи (чаще всего с целью идентификации и примитивной защиты от взлома). Если DNServer не знает ответа на вопрос, он пересылает запрос в домен верхнего уровня (увеличивая собственный кэш возвратившимся корректным ответом). Корень базы данных управляется центром Internet Network Information Center, в котором определены домены верхних уровней (com, gov, net, edu, mil, org, biz, info, географические домены). Выделение доменного адреса и разделение на поддомены обеспечивается текущими владельцами доменных имен. Выделение доменного имени может быть бесплатной процедурой, если у обладателя доменного имени нет права коммерческого использования. NSLOOKUP - программа общения с сервером DNS. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  15. DHCP С помощью протокола DHCP (Dynamic Host Configuration Protocol) автоматизирован процесс назначения IP-адресов узлам сети. Различают статические (заранее выделенные) и динамические IP адреса. В ходе DHCP сеанса связи проходит договор не только о присвоении IP адреса данному сетевому интерфейсу, но и посылка дополнительной информации о конфигурации сети (например, адреса шлюза, маски сети, адресов прокси-серверов). Применяется в мобильных сетях и сетях с нехваткой "реальных" (транслируемых в Интернет) адресов, при осуществлении модемного доступа к провайдеру интернет услуг. DHCP общение происходит по архитектуре "клиент-сервер". Клиент посылает широковещательный запрос и все DHCP сервера (у каждого свой диапазон IP адресов) посылают в ответ свои конфигурационные предложения об IP адресе. После выбора хост отсылает подтверждение приема только конкретному серверу.Существует проблема в сотрудничестве DNS и DHCP в случае динамической раздачи "реальных" IP адресов - надо постоянно обновлять DNS таблицы. Поэтому на статические сервисы, видимые из Интернет, стараются назначать "реальные" IP адреса. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  16. Формат IP пакета IP (Internet Protocol)пакет инкапсулируется в кадр канального уровня, чаще всего его заголовки являются вложенными в кадр IEEE 802.2. • Версия (IPv4) • длина заголовка в 32 бит. словах • тип сервиса (для интеллектуальных маршрутизаторов, PPPDTRхх, P - приоритет (для будущего), D,T,R - запрашиваются мин. задержки, макс. пропускная способность, макс. надежность) Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  17. Поля IP пакета • Флаги Do not Fragment - DF, More Fragments - MF - еще фрагменты. (Использование - для определения MTU - Maximal Transfer Unit). • Time to live – времяжизни пакета в секундах. Это время уменьшается на количество секунд задержки на каждом маршрутизаторе или на 1 при любом переходе через маршрутизатор. Поле TTL введено для устранения бесконечного блуждания пакетов по Сети (например, в случае неправильной конфигурации маршрутизаторов и возникновения логических колец). • Опции IP (если есть) - для тестирования или отладки сети (например, запись маршрута или обязательное прохождение по маршруту). Минимальный размер заголовков IP уровня - 20 байт. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  18. UDP Заголовки и данные UDP (User Datagram Protocol) уровняинкапсулируются в поле данных IP уровня. UDP - протокол негарантированной доставки данных (транспортный и сеансовый уровни модели OSI/RM). UDP используется для отсылки данных некритичных к потере информации приложений (DNS запросы-ответы, ICQ, TFTP, игровые сервисы типа Quake). Также UDP почти всегда используется для рассылки групповых IP датаграмм. Некоторые IP адреса класса D статически закреплены за разными сервисами, например 224.0.0.1 означает "все системы в этой подсети", а 224.0.0.2 - "все маршрутизаторы в этой подсети". Групповой адрес 224.0.1.1 предназначен для сетевого протокола времени (NTP - Network Time Protocol), а 224.0.0.9 для RIP-2. В случае групповой рассылки датаграмм с использованием адресации класса D три младшие байта IP адреса также записываются в три младшие байта адреса назначения кадра групповой рассылки канального уровня (для Ethernet). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  19. Формат UDP заголовка Количество портов источника и назначения ограничены 16-ю битами (всего 65536 портов). Порты разделяют на именованные (закрепленные соответствующими RFC за определенными сервисами) и неименованные. Т.к. контрольная сумма в заголовках IP уровня охватывает только заголовок, на TCP и UDP уровнях необходимо контролировать качество самих переданных данных. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  20. DNS, порт 53 (ping lab127.ru) Перед запуском процедуры тестирования связи (посредством утилиты ping)компьютер с IP-адресом 172.20.176.62 (MAC-адрессетевого интерфейса90-E6-BA-71-0B-8C), на котором была запущена утилита, послал широковещательный DNS-запрос серверу ns.karelia.ru (на МАС-адрес маршрутизатора 00-0С-CE-CE-4E-4D). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  21. DNS (ping lab127.ru) 00-0C-CE-CE-4E-4D MAC-адрес получателя 90-E6-BA-71-0B-8CMAC-адресотправителя 08-00 тип вложения:IP 45-00 версия IP, длина заголовков, сервис 00-37 длина IP датаграммы (55 байтов) 07-03-00-80 фрагментация, флаги, TTL 11 тип вложения: UDP 68-85 контрольная сумма AC-14-B0-3E IP-адрес отправителя (172.20.176.62) C2-55-AC-85 IP-адрес получателя (194.85.172.133) D6-82 UDP-порт отправителя (порт 54914) 00-35 UDP-порт назначения (порт 53 DNS) 00-23-DE-74 длина и контрольная сумма 19-31 ID и флаги 01-00…00-01 DNS-запрос на lab127.ru типа A ПРИКЛАДНОЙ ПРЕДСТАВИТ. СЕАНСОВЫЙ ТРАНСПОРТНЫЙ СЕТЕВОЙ КАНАЛЬНЫЙ ФИЗИЧЕСКИЙ Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  22. IP фрагментация Приложениям, которые пользуются UDP для отправки данных, нет необходимости заботиться о размере получившейся в результате IP датаграммы (лишь бы она не выходила за пределы 64кб, максимального размера). Если она по размеру больше, чем MTU для данной сети, IP датаграмма будет фрагментирована. На рисунке приведен пример фрагментации поверх Ethernet. пакет 1 пакет 2 Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  23. TCP Заголовки и данные TCP (Transmission Control Protocol) уровняинкапсулируются в поле данных IP уровня, т.е. в IP датаграмму. TCP - протокол гарантированной доставки данных по предустановленному виртуальному соединению (транспортный и сеансовый уровни модели OSI/RM). Единицей данных протокола TCP является сегмент. Оба участника соединения должны договориться о максимальном размере сегмента, который они будут использовать. Этот размер выбирается таким образом, чтобы при упаковке сегмента в IP-пакет он помещался туда целиком, то есть максимальный размер сегмента не должен превосходить максимального размера поля данных IP-пакета. Максимальный размер сегмента не должен превышать минимальное значение на множестве всех MTU промежуточных IP сетей. TCP строит пакеты, упаковывая их в сегменты, устанавливает тайм-ауты в момент отправки, подтверждает принятые данные, меняет их порядок в случае хаотического прибытия (вследствие различных путей датаграмм), отбрасывает дублированные данные, осуществляет контроль потока данных, рассчитывает и проверяет контрольную сумму. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  24. Формат TCP заголовков • Номер последовательности (sequence number) идентифицирует количество байт в переданном потоке в одном направлении. При установлении нового соединения значения этого поля содержит исходный номер последовательности (выбирается псевдослучайным образом). • Поле номер подтверждения содержит номер последнего успешно принятого байта +1. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  25. Формат TCP заголовков • Длина заголовка выражается в 4х байтовых словах (максимальная длина TCP заголовка - 60 байт). • Битовые флаги: • URG - флаг срочности (запрет ожидания заполнения исходящего буфера при передаче), используется совместно с указателем срочности (смещением, складываемым с номером последовательности). Флаг используется, например, при нажатии CTRL+C в режиме telnet. • ACK - указатель подтверждения приема • PSH - получатель должен передать данные приложению как можно быстрее (используется очень часто для уменьшения времени передачи информации). • RST - сброс соединения. • SYN - сигнал установления соединения. • FIN - отправитель заканчивает отсылку данных. • Контроль потока данных на каждой стороне TCP соединения производится с использованием окна (0-65535 байт). Это количество байт, начинающееся с указанного в поле номера подтверждения, которое приложение собирается принять. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  26. Установление TCP соединения 1 0.0              svr4.1037 > bsdi.discard: S 1415531521:1415531521 (0)win 4096 <mss 1024>2 0.002402 (0.0024) bsdi.discard > svr4.1037: S 182308000:182308000 (0)ack 1415531522 win 4096 <mss 1024>3 0.007224 (0.0048) svr4.1037 > bsdi.discard: . ack 182308001 win 40964 4.155441 (4.1482) svr4.1037 > bsdi.discard: F 1415531522:1415531522 (0)ack 182308001 win 40965 4.156747 (0.0013) bsdi.discard > svr4.1037: . ack 1415531523 win 40966 4.158144 (0.0014) bsdi.discard > svr4.1037: F 182308001:182308001 (0)ack 1415531523 win 40967 4.180662 (0.0225) svr4.1037 > bsdi.discard: . ack 182308002 win 4096 Выше представлен дамп трафика (7 пакетов), сгенеренный программой tcpdump. Первые три пакета передаются для установления соединения с битом SYN, размер окна 4096 байт, значение максимальной длины сегмента (связана с MTU) передается в поле опций (только в первых пакетах). Для последовательного двустороннего разрыва TCP соединения необходимо переслать по сети 4 пакета с битами FIN и ответом на них ACK. Т.к. TCP соединение носит полнодуплексный характер (данные могут передвигаться в каждом направлении независимо от другого), каждое направление может быть закрыто независимо от другого. (Точка на месте флагов указывает на отсутствие флагов SYN, FIN, RST, PSH). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  27. Датаграммы Если у компьютера 1 возникает необходимость отправить датаграмму сетевого уровня компьютеру 2, то ему необходимо ее подготовить, инкапсулировать в кадр канального уровня и отправить его в среду передачи через свой единственный физический интерфейс. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  28. Режим promiscuous В обычном режиме функционирования сетевого интерфейса при получении кадра данные (46–1500 байтов) будут переданы обработчику верхнего уровня только в случаях, если адрес назначения, установленный в поле DA, широковещательный, либо он совпадет с уникальным МАС-адресом принимающей станции. Однако каждый адаптер Ethernet может быть переведен в режим, в котором будут обрабатываться все кадры, поступающие из среды передачи. На английском языке такой режим носит название "promiscuous", что переводится как "безразличный" или "неразборчивый". Этим свойством сетевых адаптеров можно пользоваться, например, для создания программных анализаторов сетевого трафика (tcpdump). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  29. Перехват трафика Возможный контроль трафика при его передаче между двумя выделенными цветом станциями Router Hub Switch Switch Hub – репитер Switch – коммутатор Router - маршрутизатор Hub Hub Для того, чтобы иметь возможность перехватить сетевой трафик, необходимо иметь устройство, функционирующее на физическом уровне. Благодаря переключению сетевого адаптера в режим promiscuous возможно создать программный анализатор трафика (или, например, программу перехвата паролей). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  30. Контроль трафика Internet Router/ Firewall/ Proxy/ Logger Router Switch Hub Сетевой уровень OSI/RM Hub Hub Канальный уровень OSI/RM Switch Физический уровень OSI/RM Router / Firewall / Proxy / Logger– устройство, отвечающее за безопасность внутренних сетей предприятия (Intranet). Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  31. Систематизация знаний Рекомендуется дополнить и заполнить таблицу Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  32. Тест на iq.karelia.ru Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  33. Видеофильм Warriors of the Net Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  34. Популярно о протоколах 1 Сжатие: У тебя отрезают левую руку на входе, а на выходе - пришивают клонированную правую (и зеркально повернутую, разумеется). То же с ногами и вообще со всем, что имеет регулярную структуру. Коррекция ошибок: К спине пришивают твою же фотографию. Если на выходе ты не похож - корректируют лицо. Время жизни пакета: Все перемещения по коридору - пока горит спичка. Не успел - умри героем. DNS: Чтобы узнать, где колодец в деревне Гадюкино, ты сначала идешь к президенту, потом к губернатору и т. д. Динамический IP: Каждое утро все меняются паспортами. Текст-ориентированный протокол: Вместо тебя отправляют твой словесный портрет. Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

  35. Популярно о протоколах 2 MIME-код: Справка, что ты не верблюд. Уровни протоколов: Чистое поле. Нужно перейти от одного края к другому. Строится огромная арка, внутри арки мостовая, посреди мостовой кладут ж/д полотно, к рельсам приваривают сваи и на них ставят огромную гранитную глыбу с туннелем внутри, в туннеле прокладывают трубу диаметром полметра, по которой ты и ползешь пока горит спичка к президенту (сжатый и с коррекцией ошибок). Пинги: Иди посмотри, Иван Петрович не ушел еще?. Маскарадинг: Один паспорт на всю семью. IPv6: Китайский паспорт. Источник: http://www.cooler-online.com/ Petrozavodsk State University, Alex Moschevikin, 2004 NETS and OSs

More Related