UNIX: разработка сетевых приложений
int sctp_opt_info(int <i>sockfd</i>, sctp_assoc_t <i>assoc_id</i>, int <i>opt</i>,void *<i>arg</i>, socklen_t *<i>siz</i>);<i>Возвращает: 0 в случае успешного завершения, -1 в случае ошибки</i>Здесь
— дескриптор сокета, с параметрами которого хочет работать пользователь. Аргументsockfdзадает идентификатор ассоциации, которую нужно выделить из списка всех ассоциаций данного сокета. Аргументassoc_idзадает параметр сокета для SCTP (список параметров приводится в разделе 7.10).opt— аргумент параметра сокета,Arg— указатель на переменную типаsiz, в которой хранится размер аргумента параметра сокета.socklen_t9.12. Функция sctp_peeloff
Как отмечалось ранее, любую ассоциацию, установленную через сокет типа «один- ко-многим», можно выделить в собственный сокет типа «один-к-одному». По семантике новая функция подобна
с дополнительным аргументом. Процесс передает дескрипторacceptсокета типа «один-ко-многим» и идентификаторsockfdвыделяемой ассоциации. Функция возвращает дескриптор нового сокета. Этот дескриптор имеет тип «один-к-одному», и он изначально связан с выбранной ассоциацией.idint sctp_peeloff(int <i>sockfd</i>, sctp_assoc_t <i>id</i>);<i>Возвращает: дескриптор нового сокета в случае успешного завершения, -1 в случае ошибки</i>9.13. Функция shutdown
Обсуждавшаяся в разделе 9.6 функция
может использоваться с конечной точкой SCTP, использующей интерфейс типа «один-к-одному». Поскольку архитектура SCTP не предусматривает наполовину закрытого состояния, реакция на вызовshutdownконечной точки SCTP отличается от реакции TCP. Когда конечная точка SCTP инициирует процедуру завершения ассоциации, оба собеседника должны закончить передачу данных, находящихся в очереди, после чего закрыть ассоциацию. Конечная точка, выполнявшая активное открытие, может вызватьshutdownвместоshutdownдля того, чтобы впоследствии подключиться к новому собеседнику. В отличие от TCP, закрывать сокет функциейclose, а затем создавать его снова здесь не требуется. SCTP разрешает конечной точке вызватьclose, а после завершения этой функции — открывать новые ассоциации через тот же сокет. Обратите внимание, что если конечная точка не дождется завершения последовательности закрытия ассоциации, установка нового соединения закончится неудачей. На рис. 9.4 приведена типичная временная диаграмма вызовов для этого сценария.shutdownРис. 9.4. Закрытие ассоциации SCTP вызовом shutdown
Обратите внимание, что на рис. 9.4 мы подразумеваем, что процесс подписан на события
. Если же он не подписался на эти события, функцияMSG_NOTIFICATIONсчитает нулевое количество байтов. Результаты вызова shutdown для TCP были описаны в разделе 6.6. В документации howto на функциюreadдля SCTP перечислены следующие константы:shutdown■
— та же семантика, что и для TCP (см. раздел 6.6); никаких особых действий протокол SCTP не предусматривает;SHUT_RD■
— запрещает отправку сообщений и инициирует процедуру завершения ассоциации SCTP. Этот параметр не дает возможности работать в наполовину закрытом состоянии, однако позволяет локальной конечной точке считать все данные, которые собеседник отправит до получения сообщения SCTP SHUTDOWN;SHUT_WR■
— запрещает вызовы read и write и инициирует процедуру завершения ассоциации SCTP. Данные, передававшиеся в момент вызоваSHUT_RDWRна локальную конечную точку, будут подтверждены и сброшены без всякого уведомления процесса.shutdown9.14. Уведомления
SCTP предоставляет разработчику приложений большое количество разнообразных уведомлений. С их помощью процесс может отслеживать состояние ассоциаций, с которыми он работает. Уведомления сообщают о событиях транспортного уровня, включая изменения состояния сети, установку ассоциаций, протокольные ошибки удаленного узла и неудачи при доставке сообщений. По умолчанию уведомления обо всех событиях отключены для сокетов обоих типов. Исключение делается для события
. Пример использования уведомлений будет приведен в разделе 23.7.sctp_data_io_eventПараметр сокета
позволяет подписаться на восемь событий. Из них семь штук генерируют дополнительные данные, которые процесс может получить через обычный дескриптор сокета. Уведомления добавляются к обычным данным, приходящим на соответствующий сокет, по мере того, как происходят события, генерирующие эти уведомления. При чтении из сокета, для которого включена подписка на уведомления, пользовательские данные и сообщения смешиваются друг с другом. Чтобы различить их, процесс должен использовать функцииSCTP_EVENTSилиrecvmsg. Для уведомлений о событиях полеsctp_recvmsgсодержит флагmsg_flags. Этот флаг говорит приложению о том, что считанное сообщение представляет собой не обычные данные, принятые от собеседника, а уведомление о каком-либо событии от локального стека SCTP.MSG_NOTIFICATIONУведомление любого типа имеет следующий формат. Первые восемь байтов идентифицируют тип уведомления и его полную длину. Включение подписки на событие
приводит к тому, что с каждой операцией чтения пользовательских данных процесс принимает структуруsctp_data_io_event. Вызовомsctp_sndrcvinfoэта структура помещается во вспомогательные данные. Приложение может также вызватьrecvmsg, которая использует указатель на структуруsctp_recvmsg.sctp_sndrcvinfoДва уведомления содержат поле кода причины ошибки SCTP (SCTP error cause field). Значения этого поля перечислены в разделе 3.3.10 RFC 2960 [118] и в разделе «CAUSE CODES» (коды причин) документа
.http://www.iana.org/assignments/sctp-parametersУведомления определяются следующим образом.
struct sctp_tlv {u_int16_t sn_type;u_int16_t sn_flags;u_int32_t sn_length;};/* уведомление о событии */
