从昨天到今天一真在搞这个网络断线检测的问题,一直没搞好,网上大多都说用ping
可以搞定,不过我就是搞不定,没办法之下想了个不是办法的办法,在
服务器上开了一个
UDP端口,监听数据,然后回发,不用TCP是因为TCP建立连接太慢了,我发送一个测试数据,数据量小用不着TCP。
这样终端通过去连接服务器的 UDP端口来判断网络状态,听起来不怎么靠谱,不过先用着了。
今天又遇到recvfrom阻塞接收的问题,网络不通就一直等,想改成非阻塞的,也不可靠谱。最后设置了一个超时时间。写这几句话就是想说
setsockopt设置
超时间的问题
setsockopt(uSock,SOL_SOCKET,SO_SNDTIMEO,(char*)&TimeOut,sizeof(TimeOut));
不行,一直是设置失败,后来改成下面这个就行了
struct
timeval tv_out;
tv_out.tv_sec = 10;//等待10秒
tv_out.tv_usec = 0;
setsockopt(sock_fd,SOL_SOCKET,SO_RCVTIMEO,&tv_out,
sizeof(tv_out))
网络上搜到的大都是第一种方法,可能是setsockopt函数已经变了,不适应以前的参数了
2010-08-06 17:43
send,recv在windows与linux下的超时设置linux下:
用socket发送数据前,可以先设置其属性,指定超时时间。超时时间包括接收超时时间和发送超时时间,假设设置接收超时时间为2秒,可以这样:
int time_out = 2000; // 2秒
setsockopt(sockfd, SOL_SOCKET,SO_RCVTIMEO, (char
*)&time_out,sizeof(time_out));
但是在程序中,你可能会发现这样设置之后,还是无效,用接收UDP数据时,recvfrom函数仍然阻塞在那里一动不动,为什么?原因是你没有设置socket为非
阻塞的。在设置超时时间之前,先将socket设置为非阻塞的:
fcntl(sockfd ,F_SETFL, O_NONBLOCK);
widows下:要先设置阻塞,然后再setsockopt
int iMode = 0;//block
ioctlsocket(s, FIONBIO,
(u_long FAR*) &iMode);
DWORD
TimeOut=1000*10;
//设置发送超时10秒
if(::setsockopt(s,SOL_SOCKET,SO_RCVTIMEO,(char
*)&TimeOut,sizeof(TimeOut))==SOCKET_ERROR)
........