zoukankan      html  css  js  c++  java
  • volley超时和重复请求问题

    原文: 

    Android Volley double post when have slow request 
    I have a problem with Volley POST request on slow network

    这哥们儿遇到的问题,在国内的我同样遇到了 
    情况描述: 
    一直用Volley很正常,调用服务器接口发布内容,成功就发布一条,不成功就没有; 
    最近服务器端在接收到我上传的图片或视频之后,做了处理,导致其接收速度和往常一样,但是对APP端的响应速度延迟了1-3秒,使得发布内容加倍,有时一条,有时两条三条, 
    查看log日志,自己手动调用mRequestQueue.add(request)以及mRequestQueue.start()的次数始终为1,但是与服务器联调时,服务器端的确被调用了两三次;谷歌后得知,这算是volley的一个bug吧(具体应该不算) 
    相应讨论:google groups

    解决方案

    方案一  对Request设置重试策略时,更改默认超时时间
            request.setRetryPolicy( new DefaultRetryPolicy( 500000,//默认超时时间,应设置一个稍微大点儿的,例如本处的500000 
            DefaultRetryPolicy.DEFAULT_MAX_RETRIES,//默认最大尝试次数 
            DefaultRetryPolicy.DEFAULT_BACKOFF_MULT ) );
     代码 :request.setRetryPolicy(new DefaultRetryPolicy(50000,DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));   
            DEFAULT_BACKOFF_MULT:​对于请求失败之后的请求,并不会隔相同的时间去请求Server,不会以线性的时间增长去请求,而是一个曲线增长,一次比一次长,如果backoff因子是2,当前超时为3,即下次再请求隔6S​
    方案二  在HurlStack中的openConnection方法中,在相应段落增加
            connection.setChunkedStreamingMode(0)
    PS:在实际项目中,我用了第一种方案,就解决了我的问题。。。
  • 相关阅读:
    Linux常用命令及示例(全)
    linux下安装配置svn服务器
    Kafka、Redis和其它消息组件比较
    ORACLE定时备份方案
    mysql库表优化实例
    携程apollp快速部署DVE集群
    windows 安装Zookeeper 配置集群
    Ubuntu 18.04 LTS 修改Host,使用Host访问
    PowerShell因为在此系统中禁止执行脚本......
    常用第三方工具的Docker命令
  • 原文地址:https://www.cnblogs.com/xgjblog/p/5066469.html
Copyright © 2011-2022 走看看