第8章:
ssize_t recvfrom(int sockfd, void * buff, size_t nbytes, int flags, struct sockaddr * from, socklen_t * addrlen);
ssize_t sendto(int sockfd, const void *buff, size_t nbytes, int flags, const struct sockaddr *to, socklen_t addrlen);
成功返回字节数,失败返回-1。
参数to:指向一个含有数据报接受者的协议地址,from参数指向一个将由该函数在返回时填写数据报发送这的协议地址。
UDP的connect函数:记录下服务器的ip地址和端口号,可以改用read,recv,recvmsg收发数据。
多次调用connect函数指定新的ip地址和端口号和断开套接字。
UDP 缺乏流量控制,因为无法保证服务器或者客户端收到1次多次多次同样的包。
第9章
SCTP套接字分为:1到1套接字和1到n套接字。1到1套接字对应一个单独的SCTP关联。1到n套接字对应多个SCTP关联。
SCTP建立一个连接需要4次握手,当客户端关闭一个关联时,服务器也自动关闭同一个关联。
sctp_bindx函数:
int sctp_index(int sockfd, const struct sockaddr *addrs, int addrcnt, int flags)
addrs是一个指向紧凑的地址列表的指针。addcnt是表格地址个数, flags是选择添加或者删除地址。
int sctp_connectx(int sockfd, const stuct sockadrr * addrs, int addrcnt)
sctp_connectx作用于连接到一个多宿对端主机,addrs在参数中指定addrcnt个全部属于同一对端的地址。addrs是一个紧凑的地址列表。
int sctp_getpaddrs(int sockfd, stcp_assoc_t id, struct sockaddr **addrs);
获取需要知道的对端的所有地址,id参数是一到多式套接字的关联标识,addrs是一个地址指针,二地址内容由本函数动态分配。
void sctp_freepaddrs(struct sockaddr * addrs)
释放有sctp_getpaddrs函数分配的资源,addrs是指向sctp_getpaddrs返回的地址数组指针。
ssize_t sctp_sendmsg(int sockfd, const void *msg, size_t msgsz, const struct sockaddr *to, socklen_t tolen, uint32_t ppid, unit32_t flags, unit16_t stream, unit32_t timetolive, unit32_t context)
msg参数指向一个长度为smgsz字节的缓冲区,将内容发给对端端点to,tolen参数存放在to中的地址长度,ppid参数指定将数据块传递的净荷协议标识符,flgs参数传递给SCTP栈中,用以标识SCTP现象,stream参数指定一个SCTP流号,timetolive表示消息的生命周期,context为上下文。
ssize_t sctp_recvmsg(int sockfd, void *msg, size_t msgsz, struct sockaddr * from, socklent_t fromlen, struct sctp_sndrcvinfo * sinfo, int msg_flags); 发送消息。
int sctp_peeloff(int sockfd , sctp_assoc_t idi) 获取一个1到1关联的套接字符。
第十章
SCT中流不同于TCP中的字节流,他是关联内部的具有先后顺序的一个消息序列。这种以流本身而不是以流所在的关联为单位进行消息排序的用法用于避免仅适用单个TCP字节流导致的头端阻塞现象。
头端阻塞发生在一个TCP分节丢失,导致其后续分节不按徐到达接收端的时候。该后续分节将接受端一直保持到第一个分节被发送端重传到接收端为止。该后续分节延迟递送确保接收应用进程能够按照顺序得到由发送应用进程发送的数据。而SCTP有多个流,能够尽可能的避免头端阻塞,因为流之间没有有序性。