TCP客户用connect函数来建立与TCP服务器的连接。
#include <sys/socket.h>
int connect(int sockfd, const struct sockaddr *servaddr, socklen_t addrlen);
sockfd是由socket函数返回的套接字描述符,第二个参数、第三个参数分别是一个指向套接字地址结构的指针和该结构的大小。套接字地址结构必须含有服务器的IP地址和端口号。
客户在调用函数connect前不必非得调用bind函数,因为如果需要的话,内核会确定源IP地址,并选择一个临时的端口作为源端口。
如果是TCP套接字,调用connect函数将激发TCPTCP的三次握手 过程,而且仅在连接建立成功或出错的时候才返回,其中出错返回可能有以下几种情况。
(1)若TCP客户没有收到SYN分节的响应,则返回ETIMEOUT出错,举例来说,调用connect函数时,4.4BSD内核发送一个SYN,若无响应则等待6s后再发送一个,若仍无响应则等待24s后再发送一个。若总共等了75s后仍未收到响应则返回出错。
(2)若对客户的SYN的响应是RST(表示复位),则表明该服务主机在我们指定的端口上没有进程在等待与之连接。这是一种硬出错,客户一接收到RST就马上返回ECONNREFUSED出错。
RST是TCP在发生错误时发送的一种TCP分节,产生RST的三个条件是:目的地为某端口的SYN达到,然而该端口上没有正在监听的服务器;TCP想取消一个已有的连接;TCP接收到一个根本不存在的连接上的分节。
(3)若客户发出的SYN在中间的某个路由器上引发一个“destination UNreachable”(目的不可达)ICMP错误,则认为是一种软错误,客户主机内核保存该消息,并按第一种情况中所述的时间间隔继续发送SYN。若在某个规定的时间后仍未收到响应,则把保存的消息作为EHOSTUNREACH或ENETUNREACH错误 返回给进程。以下两种情形也是有可能的:一是按照本地系统的转发表,根本没有达到远程系统的路径;二是connect调用根本不等待就返回。
若connect失败则该套接字不再可用,必须关闭。我们不能对给定主机尝试再次调用connect函数。当循环调用函数connect为给定主机尝试各个IP地址直到有一个成功时,在每次connect失败后,都必须close当前的套接字描述符,并重新调用socket。
TCP客户端使用connect函数建立与服务器的连接,该函数涉及TCP的三次握手过程。如果连接建立成功或出现错误(如超时、RST响应或目的不可达)时,connect将返回。遇到错误时,套接字必须关闭,且不能重复尝试连接同一主机。
1万+

被折叠的 条评论
为什么被折叠?



