ブロッキングソケットがあります(少なくとも次のコードではそう見えます):
sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
if (sock < 0) {
ERROR("%s: error opening socket", __func__);
return (RESP_ERROR);
}
t.tv_sec = timeout;
t.tv_usec = 0;
int rf = fcntl(sock, F_GETFD);
ERROR("fcntl ret=%d, ret & O_NONBLOCK = %d", rf, rf & O_NONBLOCK);
if ((setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, (char *)&t, sizeof (t)) < 0)
|| (setsockopt(sock, SOL_SOCKET, SO_SNDTIMEO, (char *)&t, sizeof (t)))) {
strerror_r(errno, err, 254);
ERROR("%s: error on setsockopt -> %s", __func__, err);
close(sock);
return (RESP_ERROR);
}
rf = fcntl(sock, F_GETFD);
ERROR("after select fcntl ret=%d, ret & O_NONBLOCK = %d", rf, rf & O_NONBLOCK);
if (connect(sock, (struct sockaddr *)&dst, sizeof (dst)) != 0) {
strerror_r(errno, err, 254);
ERROR("%s: error on connect -> %s", __func__, err);
close(sock);
return (RESP_ERROR);
}
そして、これはログからです:
3 月 6 日 10:42:04 tcpclient: fcntl ret=0、ret & O_NONBLOCK = 0
Mar 6 10:42:04 tcpclient: fcntl ret=0 を選択した後、ret & O_NONBLOCK = 0
Mar 6 10:42:14 tcpclient: 認証: 接続エラー -> 操作が進行中
これはブロッキング ソケットのようですが、非ブロッキングに典型的なエラーを返しますか? Linux は 2.6.18-308.el5 です。何か案は?