• tcp keepalive


        if(-1 == setsockopt(client_fd, SOL_TCP, TCP_KEEPIDLE , (char *) &time_opt, sizeof(int)))
        {
            printf("setsockopt TCP_KEEPIDLE error, %u
    ", time_opt);
        }
        time_opt = (time_opt/2); //mo ack after 2S interval again
        if(-1 == setsockopt(client_fd, SOL_TCP, TCP_KEEPINTVL , (char *) &time_opt, sizeof(int)))
        {
            printf ("setsockopt TCP_KEEPINTVL error, %u
    ", time_opt);
        }
    
        time_opt = 2;//2 num stop send
        if(-1 == setsockopt(client_fd, SOL_TCP, TCP_KEEPCNT , (char *) &time_opt, sizeof(int)))
        {
            printf("setsockopt TCP_KEEPCNT error, %u
    ", time_opt);
        }
    
        time_opt = 1;
        if( -1 == setsockopt(client_fd, SOL_SOCKET, SO_KEEPALIVE , (char *) &time_opt, sizeof(time_opt)))
        {
            printf("setsockopt SO_KEEPALIVE error
    ");
        }
    View Code

    没太大意义。

    在对方已经关闭时,发keepalive 还有ack。单到了一定数量之后,发第10—-13个keepalive 对方就返回了rst。??

    如果可达,但应用程序退出,对方就发RST应答,发送TCP撤消连接。

    如果没有ack 就等keepalive cnt个没响应。rst。

    引用:

    1.如果主机可达,对方就会响应ACK应答,就认为是存活的。
    2.如果可达,但应用程序退出,对方就发RST应答,发送TCP撤消连接。
    3.如果可达,但应用程序崩溃,对方就发FIN消息。
    4.如果对方主机不响应ack, rst,继续发送直到超时,就撤消连接。
     
    、、、、

    下面来罗列一下判断远端已经断开的方法:

    法一:

    当recv()返回值小于等于0时,socket连接断开。但是还需要判断 errno是否等于 EINTR,如果errno == EINTR 则说明recv函数是由于程序接收到信号后返回的,socket连接还是正常的,不应close掉socket连接。

    法二:

      struct tcp_info info; 
      int len=sizeof(info); 
      getsockopt(sock, IPPROTO_TCP, TCP_INFO, &info, (socklen_t *)&len); 
      if((info.tcpi_state==TCP_ESTABLISHED))  则说明未断开  else 断开

    法三:

    若使用了select等系统函数,若远端断开,则select返回1,recv返回0则断开。其他注意事项同法一。

    法四:

    int keepAlive = 1; // 开启keepalive属性
    int keepIdle = 60; // 如该连接在60秒内没有任何数据往来,则进行探测 
    int keepInterval = 5; // 探测时发包的时间间隔为5 秒
    int keepCount = 3; // 探测尝试的次数.如果第1次探测包就收到响应了,则后2次的不再发.

    setsockopt(rs, SOL_SOCKET, SO_KEEPALIVE, (void *)&keepAlive, sizeof(keepAlive));
    setsockopt(rs, SOL_TCP, TCP_KEEPIDLE, (void*)&keepIdle, sizeof(keepIdle));
    setsockopt(rs, SOL_TCP, TCP_KEEPINTVL, (void *)&keepInterval, sizeof(keepInterval));
    setsockopt(rs, SOL_TCP, TCP_KEEPCNT, (void *)&keepCount, sizeof(keepCount));

    设置后,若断开,则在使用该socket读写时立即失败,并返回ETIMEDOUT错误

    法五:

    自己实现一个心跳检测,一定时间内未收到自定义的心跳包则标记为已断开。

  • 相关阅读:
    Android Studio 修改Logcat的颜色
    Android Studio 视图解析
    Android应用Design Support Library完全使用实例
    Android5.x新特性之 Toolbar和Theme的使用
    常见Android Native崩溃及错误原因
    判断App整体处于前台还是后台
    ubuntu学习: apt-get命令
    docker 学习笔记20:docker守护进程的配置与启动
    docker学习笔记18:Dockerfile 指令 VOLUME 介绍
    docker学习笔记17:Dockerfile 指令 ONBUILD介绍
  • 原文地址:https://www.cnblogs.com/wocgcow/p/5827435.html
Copyright © 2020-2023  润新知