netty通讯--tcp心跳异常断开问题排查

一.netty通讯中tcp心跳维持有以下两种:

1.TCP协议自带的心跳机制来实现,默认2h心跳检测频率。

2.应用层通过协议实现心跳机制。

二.最近的一个物联网项目,整体的通讯架构如下:

服务端和客户端采用tcp连接,通过自定义协议维护心跳,分为两种工况,一种10s正常心跳,一种15min睡眠心跳, 实际通讯中遇到一个问题:客户端5min未有数据上报,平台会发送空包导致客户端断开。

通过tcpdump抓包分析,由于负责代理和负载均衡的Nginx和ELB有如下配置:

stream{
    upstream acpaccess{
        hash $remote_addr consistent;
        server  127.0.0.1:18000 max_fails=3 fail_timeout=10s;  
    }
    server{
        listen 80;
        proxy_connect_timeout 300s;
        proxy_timeout 5m;
        proxy_pass acpaccess;
    }
}

proxy_connect_timeout :连接超时300s后主动发起断开连接,导致客户端与云平台正常连接终端。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值