0

SO_RCVTIMEO 根本没有在我的输出函数中创建超时条件。我正在使用 ARQ 滑动窗口协议设计文件传输服务。为了使事情井井有条,我从基本的停止等待开始。

这是我对 timeval 的初始化

    struct timeval tv;
    tv.tv_sec = 0;
    tv.tv_usec = 100000;

这是我在准备 recvfrom 超时时使用该结构和套接字

if(setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, &tv, sizeof(tv))<0)
{
fprintf(stderr, "Error in socket option for Timeout mechanism: %s",strerror(errno));
close(sock);
exit(EXIT_FAILURE);
}

if (-1 == bind(sock,(struct sockaddr *)&sa, sizeof(sa)))
{
    perror("error bind failed");
    close(sock);
    exit(EXIT_FAILURE);
}

这是应该超时的代码主体:

for(;;)
{
...
while((read_bytes=fread((char*)&(packet.body),sizeof(char),CHUNKSIZE,out_file))
{
...
while(1)
{
bytes_sent = sendto(sock, (struct sanpacket*)&packet, sizeof(struct sanpacket), 0,(struct sockaddr*)&sa, sizeof sa);
if (bytes_sent < 0) 
{
    fprintf(stderr, "%s\n", strerror(errno));
    exit(EXIT_FAILURE);
}
printf("Waiting for ACK packet\n");

recsize = recvfrom(sock, (struct sanpacket*)&packet, sizeof(struct sanpacket), 0, (struct sockaddr*)&sa, &fromlen);
if(errno == EAGAIN)
{
    printf("Timed out; resending packet with sequence number %d", packet.sequence_num);
    continue;
}
if (recsize < 0) 
{
    fprintf(stderr, "%s\n", strerror(errno));
    exit(EXIT_FAILURE);
}

}

问题:超时没有触发,但是 setsockopt 也没有返回任何错误。我无法知道我做错了什么。

如果我还能做些什么来澄清我的问题或环境,请告诉我。如果您对调试有任何建议,我将不胜感激。

4

1 回答 1

0

我忘记提及的背景是,这是在 Debian Linux 上编译的,而不是在我想使用的 Cygwin 平台上编译的。

所以我在想这个完全棘手的问题。然后我回想起奥卡姆的剃刀并想,对于正在发生的事情,最简单、最基本的解释可能是什么?

事实证明,Cygwin 不支持 setsockopt 超时。

我想说一些关于系统的必要性,您可以在该系统中吸引开发人员数小时的生命,但这是切题的,无论如何,Cygwin 还是一款出色的 Linux 模拟器。

于 2014-08-26T01:16:31.167 回答