-->

UNIX: разработка сетевых приложений

На нашем литературном портале можно бесплатно читать книгу UNIX: разработка сетевых приложений, Стивенс Уильям Ричард-- . Жанр: ОС и Сети. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале bazaknig.info.
UNIX: разработка сетевых приложений
Название: UNIX: разработка сетевых приложений
Дата добавления: 16 январь 2020
Количество просмотров: 381
Читать онлайн

UNIX: разработка сетевых приложений читать книгу онлайн

UNIX: разработка сетевых приложений - читать бесплатно онлайн , автор Стивенс Уильям Ричард

Новое издание книги, посвященной созданию веб-серверов, клиент-серверных приложений или любого другого сетевого программного обеспечения в операционной системе UNIX, — классическое руководство по сетевым программным интерфейсам, в частности сокетам. Оно основано на трудах Уильяма Стивенса и полностью переработано и обновлено двумя ведущими экспертами по сетевому программированию. В книгу включено описание ключевых современных стандартов, реализаций и методов, она содержит большое количество иллюстрирующих примеров и может использоваться как учебник по программированию в сетях, так и в качестве справочника для опытных программистов.

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала

Перейти на страницу:

29     inet6_srcrt_print(CMSG_DATA(cmsg));

30     Inet6_rth_reverse(CMSG_DATA(cmsg), CMSG_DATA(cmsg));

31    }

32   }

33   iov[0].iov_len = n;

34   Sendmsg(sockfd, &msg, 0);

35  }

36 }

Включение параметра IPV6_RECVRTHDR и подготовка структуры msghdr

12-13
 Чтобы получить информацию о маршруте, мы должны установить параметр сокета
IPV6_RECVRTHDR
. Кроме того, мы должны использовать функцию
recvmsg
, поэтому мы настраиваем поля структуры
msghdr
, которые не требуют изменения.

Настройка изменяемых полей и вызов recvmsg

21-24
 Мы устанавливаем размер полей длины и вызываем
recvmsg
.

Поиск и обработка маршрута от отправителя

25-32
 Мы перебираем вспомогательные данные, используя
CMSG_FIRSTHDR
и
CMSG_NXTHDR
. Несмотря на то, что мы ожидаем получить только один объект вспомогательных данных, выполнить такой перебор всегда полезно. Если мы обнаруживаем заголовок маршрутизации, он распечатывается функцией
inet6_srcrt_print
(листинг 27.7). Затем маршрут обращается функцией
inet6_rth_reverse
для последующего использования при возвращении пакета клиенту. В данном случае обращение производится без копирования в новый буфер, так что можно использовать старый объект вспомогательных данных для отправки пакета клиенту.

Отправка эхо-пакета

33-34
 Мы устанавливаем длину пакета и передаем его клиенту вызовом
sendmsg
.

Благодаря наличию вспомогательных библиотечных функций IPv6 наша функция

inet6_srcrt_print
становится почти тривиальной.

Листинг 27.7. Функция inet6_srcrt_print: вывод маршрута

 1 #include "unp.h"

 2 void

 3 inet6_srcrt_print(void *ptr)

 4 {

 5  int i, segments;

 6  char str[INET6_ADDRSTRLEN];

 7  segments = Inet6_rth_segments(ptr);

 8  printf("received source route: ");

 9  for (i = 0; i < segments; i++)

10   printf("%s ", Inet_ntop(AF_INET6, Inet6_rth_getaddr(ptr, i),

11    str, sizeof(str)));

12  printf("n");

13 }

Определение количества сегментов маршрута

7
 Количество сегментов маршрута определяется функцией
inet6_rth_segments
.

Перебор сегментов

9-11
 Мы перебираем сегменты маршрута, вызывая для каждого из них
inet6_rth_getaddr
и преобразуя адреса в формат представления функцией
inet_ntop
.

Клиенту и серверу, работающим с маршрутами IPv6, не нужно ничего знать о формате этих маршрутов внутри пакета. Библиотечные функции интерфейса скрывают детали форматирования, но не мешают нам программировать с той же гибкостью, которая была в IPv4, где параметры нужно было строить вручную.

27.7. «Закрепленные» параметры IPv6

Мы рассмотрели использование вспомогательных данных с функциями

sendmsg
и
recvmsg
для отправки и получения следующих семи различных типов объектов вспомогательных данных:

1. Информация о пакете IPv6: структура

in6_pktinfo
, содержащая адрес получателя и индекс интерфейса для исходящих дейтаграмм либо адрес отправителя и индекс интерфейса для приходящих дейтаграмм (индекс принимающего интерфейса) (см. рис. 22.5).

2. Предельное количество транзитных узлов для исходящих или приходящих дейтаграмм (см. рис. 22.5).

3. Адрес следующего транзитного узла (см. рис. 22.5).

4. Класс исходящего или входящего трафика (см. рис. 22.5).

5. Параметры транзитных узлов (см. рис. 27.6).

6. Параметры получателя (см. рис. 27.6).

7. Заголовок маршрутизации (см. рис. 27.8).

В табл. 14.4 приведены значения полей

cmsg_level
и
cmsg_type
для этих объектов, а также значения для других объектов вспомогательных данных.

Вместо того чтобы отсылать эти параметры при каждом вызове функции

sendmsg
, мы можем установить соответствующие параметры сокета. Параметры сокета используют те же константы, что и вспомогательные данные, то есть уровень параметра всегда должен иметь значение
IPPROTO_IPV6
, а название параметра может быть
IPV6_DSTOPTS
,
IPV6_HOPLIMIT
,
IPV6_HOPOPTS
,
IPV6_NEXTHOP
,
IPV6_PKTINFO
,
IPV6_RTHDR
или
IPV6_TCLASS
. Закрепленные параметры могут быть заменены для конкретного пакета в случае сокета UDP или символьного сокета IPv6, если при вызове функции
sendmsg
задать какие-либо другие параметры в качестве объектов вспомогательных данных. Если при вызове функции
sendmsg
указаны какие-либо вспомогательные данные, ни один из закрепленных параметров не будет послан с этим пакетом.

Концепция закрепленных параметров также может быть использована и в случае TCP, поскольку вспомогательные данные никогда не отсылаются и не принимаются с помощью функций

sendmsg
или
recvmsg
на сокете TCP. Вместо этого приложение TCP может установить соответствующий параметр сокета и указать любой из упомянутых в начале этого раздела семи объектов вспомогательных данных. Тогда эти параметры будут относиться ко всем пакетам, отсылаемым с данного сокета. Поведение при повторной передаче пакетов, первоначально переданных до изменения закрепленных параметров, не определено: могут использоваться как старые, так и новые значения параметров.

Не существует способа получить параметры, принятые в IP-пакете по TCP, потому что в этом протоколе отсутствует соответствие между пакетами и операциями чтения из сокета, выполняемыми пользователем.

Перейти на страницу:
Комментариев (0)
название