• connection_reset解决方案


    Connection reset具体的解决方案有如下几种:1、出错了重试;2、客户端和服务器统一使用TCP长连接;3、客户端和服务器统一使用TCP短连接。主要是这三种connection_reset解决方案。

    首先是出错了重试:这种方案可以简单防止“Connection reset”错误,然后如果服务不是“幂等”的则不能使用该方法;比如提交订单操作就不是幂等的,如果使用重试则可能造成重复提单。然后是客户端和服务器统一使用TCP长连接:客户端使用TCP长连接很容易配置(直接设置HttpClient就好),而服务器配置长连接就比较麻烦了,就拿tomcat来说,需要设置tomcat的maxKeepAliveRequests、connectionTimeout等参数。另外如果使用了nginx进行反向代理或负载均衡,此时也需要配置nginx以支持长连接(nginx默认是对客户端使用长连接,对服务器使用短连接)。

    使用长连接可以避免每次建立TCP连接的三次握手而节约一定的时间,但是我这边由于是内网,客户端和服务器的3次握手很快,大约只需1ms。ping一下大约0.93ms(一次往返);三次握手也是一次往返(第三次握手不用返回)。根据80/20原理,1ms可以忽略不计;又考虑到长连接的扩展性不如短连接好、修改nginx和tomcat的配置代价很大(所有后台服务都需要修改);所以这里并没有使用长连接。最后的解决方案是客户端和服务器统一使用TCP短连接:我

  • 相关阅读:
    【面经,数据分析岗】某头部汽车外企,简称车企;某医疗科技外企,简称医企
    成功实施自动化测试的优点
    IB数学TI nspire使用入门
    Elasticsearch 在bool查询中使用分词器
    MIT线性代数-方程组的几何解释
    快速幂实战
    分布式搜索———黑马旅游
    7.9 用户接口
    移动web开发02
    第八章《Java高级语法》第7节:枚举
  • 原文地址:https://blog.csdn.net/yetaodiao/article/details/127844059