【发布时间】:2013-02-21 01:05:47
【问题描述】:
我有一个阻塞套接字(至少在下面的代码中是这样):
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
3 月 6 日 10:42:04 tcpclient: 在选择 fcntl ret=0, ret & O_NONBLOCK = 0 之后
3 月 6 日 10:42:14 tcpclient: authenticate: error on connect -> 操作正在进行中
这似乎是一个阻塞套接字,但返回非阻塞的典型错误? Linux 是 2.6.18-308.el5。有什么想法吗?
【问题讨论】:
-
timeout有哪个值? -
为了验证我的答案,我想做一些测试。因此,我想知道
dst在传递给connect()之前是如何初始化的。你确定它的成员sin_family设置正确吗?
标签: c linux sockets timeout connect