我用httpclient访问接口,统计图有些不均匀,差距较大 ,有时只有几十毫秒,下图看到这种情况占多数,600-800毫秒之间的算是浏览器正常的产生调用接口的时间耗时

然后用jmeter跑时都是均值在600-800左右,每次很平均

让大家看我的统计时间耗时代码

结束时间返回结束

就耗时来说,用httpclient的相对网络开销占比不会大这么多吧 ,第二经常访问耗时不均匀的原因也找不到。

问题:两种不同的方式请求接口,输出结果是一样,如果发现两种在耗时上有差异,差异上的数据问题在哪里?一起来探讨下。

对比:取同一个接口count.do_收集数据,

①下图是通过HttpClient的方式请求,计时都在100ms左右

  ②下图是浏览器请求接口count.do_,计时如图

连续请求了几个页面得出下面表格

页面 总耗时 Queueing Stalled Request sent Waiting (TTFB) Content Download
监控页 1.95s 0.34ms 0.45ms 0.11ms 1.91s 37.73ms
首页 893.18ms 0.5ms   115.83ms 79us 776.29ms 0.48ms
人员管理页 1.03 s 0.34 ms 128.06 ms 90 μs 787.83 ms 111.20 ms
审计日志页 915.49 ms 0.63 ms 0.63 ms 77 μs 913.81 ms 0.56 ms
参数设置页 778.97 ms 0.35 ms 0.47 ms 0.15 ms 777.41 ms 0.58 ms

时间细分阶段说明(对上面浏览器各参数解读意思)

以下是有关在 Timing 标签中可能看到的各阶段的更多信息:

  • Queueing。 浏览器在以下情况下对请求排队:

    • 存在更高优先级的请求。
    • 此源已打开六个 TCP 连接,达到限值。 仅适用于 HTTP/1.0 和 HTTP/1.1。(批注:大部分页面都是超过6个接口的)
    • 浏览器正在短暂分配磁盘缓存中的空间
  • Stalled。 请求可能会因 Queueing 中描述的任何原因而停止。
  • DNS Lookup。 浏览器正在解析请求的 IP 地址。
  • Proxy negotiation。 浏览器正在与代理服务器协商请求。
  • Request sent。 正在发送请求。
  • ServiceWorker Preparation。 浏览器正在启动 Service Worker。
  • Request to ServiceWorker。 正在将请求发送到 Service Worker。
  • Waiting (TTFB)。 浏览器正在等待响应的第一个字节。 TTFB 表示 Time To First Byte(至第一字节的时间)。 此时间包括 1 次往返延迟时间及服务器准备响应所用的时间。
  • Content Download。 浏览器正在接收响应。
  • Receiving Push。 浏览器正在通过 HTTP/2 服务器推送接收此响应的数据。
  • Reading Push。 浏览器正在读取之前收到的本地数据。

分析

  ①在上面的表格中,stalled明显比较高,产生时间达到上限的tcp的连接,是接口等待时间连接

  ②Waiting (TTFB)在每次请求的时间都是占比非常高的,这里延迟比较高的可能性,也有浏览器处理等待响应时间浏览器问题的可能

最后,加了很多与浏览器相同的请求头,但是请求耗时依旧变化不大

所以,暂时得出结论,这种httpclient无法完全和浏览器请求相同,毕竟客户端和服务端之间有网络开销,您怎么看?欢迎有不同见解,请在评论区留言。

HttpClient与浏览器调用服务接口差异的更多相关文章

  1. 【起航计划 037】2015 起航计划 Android APIDemo的魔鬼步伐 36 App->Service->Remote Service Binding AIDL实现不同进程间调用服务接口 kill 进程

    本例和下个例子Remote Service Controller 涉及到的文件有RemoteService.java ,IRemoteService.aidl, IRemoteServiceCallb ...

  2. Python调用服务接口

    #! /usr/bin/env python # coding=utf-8 ############################################################## ...

  3. Jinkins流水线脚本使用curl命令调用服务接口,并且使用url传参。

    curl http://xxx.xx.xx.xx:xxxx/jenkins/publish?fileName=${fileName}&tag_name=${tag_name} 如图调用不符合c ...

  4. 使用接口的方式调用远程服务 ------ 利用动态调用服务,实现.net下类似Dubbo的玩法。

    分布式微服务现在成为了很多公司架构首先项,据我了解,很多java公司架构都是 Maven+Dubbo+Zookeeper基础上扩展的. Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按 ...

  5. So easy Webservice 3.使用HttpClient工具调用Webservice接口

    首先,看看webservice服务调用演示: a) 登录http://www.webxml.com.cn b) 单击手机查询服务 c) 选择要调用的方法 例如: getMobileCodeInfo 输 ...

  6. 通过HttpClient调用服务

    /** * 通过HttpClient调用服务 * * @param url 路径 * data json数据 * @return */ //post请求方法public String sendItsm ...

  7. C#使用windows服务定时调用api接口

    使用VS创建windows服务项目: 创建好项目  会出现一个设计界面 右键弹出对话框 选择添加安装程序 名字什么的自己可以改: 项目目录: 打开项目中的ProjectInstaller.Design ...

  8. 调用URL 接口服务

    1.Net调用URL 接口服务 using System; using System.Collections; using System.Configuration; using System.Dat ...

  9. 一个新实验:使用gRPC-Web从浏览器调用.NET gRPC服务

    今天给大家翻译一篇由ASP.NET首席开发工程师James Newton-King前几天发表的一篇博客,文中带来了一个实验性的产品gRPC-Web.大家可以点击文末的讨论帖进行相关反馈.我会在文章末尾 ...

随机推荐

  1. for in 循环 和for循环 for of循环

    for in 循环得到的是数组的key值 for  in 循环用以遍历对象的属性 var scores=[10,11,12]; var total=0; for(var score in scores ...

  2. 边缘化搭建 DotNet Core 2.1 自动化构建和部署环境(上)

    写在前面 写这篇文章的缘由是由于笔者的对新兴技术方向有所追求,但个人资产有限,只能容许购买一台阿里云低配1核2G服务器.服务器上搭建了 Centos7 & Docker & Jenki ...

  3. Java工程师学习指南 完结篇

    Java工程师学习指南 完结篇 先声明一点,文章里面不会详细到每一步怎么操作,只会提供大致的思路和方向,给大家以启发,如果真的要一步一步指导操作的话,那至少需要一本书的厚度啦. 因为笔者还只是一名在校 ...

  4. 从零开始学 Web 之 ES6(五)ES6基础语法三

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  5. PHP-CPP开发扩展(一)

    PHP-CPP是一个用于开发PHP扩展的C++库.PHP-CPP提供了一系列完善的文档.易于使用和扩展的类,让你可以相对快速的创建PHP的原生扩展. 为什么使用PHP-CPP 很快 用C++编写的代码 ...

  6. SQL 必知必会·笔记<7>汇总数据——使用聚合函数

    有时候我们需要对表中的数据进行汇总,而不需要数据本身,为了方便这些类型的检索,SQL给出了5个聚合函数,SQL聚合函数在各主要的SQL实现中得到了相当一致的支持.如下: 1.1 AVG()函数 AVG ...

  7. jQgrid学习笔记

    jQgrid学习笔记

  8. 微信分享JSSDK-invalid signature签名错误的解决方案

    核对官方步骤,确认签名算法. 确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 页面工具进行校验. 确认con ...

  9. Linux 源码安装 FFmpeg

    加班次数频繁,已经快一年没有写博了.由于此次在项目中使用到了 FFmpeg 来处理音视频,顾记录下在 Linux 系统中源码安装 FFmpeg 以便不时之需. 1. 安装 yasm yasm 是一个汇 ...

  10. Struts2学习(四)———— ognl表达式、值栈、actionContext之间的关系

    一.什么是Ognl? 通过百度百科查询到的解释,其中详细的说明了OGNL的作用. 下面我们就对OGNL这5个作用进行讲解 1.存取对象的任意属性,简单说就是对javabean进行操作(重要) 2.调用 ...