缘起:

产品业务上有个类数据库服务的请求时间比较长(类似mysql的sql查询),为了优化减少并发时的请求数,做了一个并发时共用请求的优化。

通过单元测试后,想通过手动模拟看下效果,发现优化一直不能生效。

定位问题:

1、在mac下,同时开了两个chrome窗口,分别促发访问同一个接口(请求入口打印input,中间设定几秒的延时,出口打印output)。

  async test(ctx) {
console.log('input');
await bluebird.delay(10000);
console.log('output');
ctx.response.body = 'ok';
}

输出结果如下:

input
output
input
output

结果分析:两次请求无法并发执行,而是串行到一起,当第一个请求返回后,第二个请求才开始进入执行。

猜测:是否是在用的egg.js框架,给做的这种特性?为了方便调试环境的代码测试?可是之前看egg.js的代码也没看到这个功能呀?文档也没说明这个功能呀?

2、同事提出了疑惑“不可能是egg.js的实现,不然其它的框架难道都得实现一套”?

3、同样代码,用production模式执行下(如果可以串行,那么生产环境是不可能这么处理的)。

结果保持不变:

input
output
input
output

同样的代码,换koa框架进行测试。

同样的代码,换node原生http服务进行测试。
结果保持不变:

input
output
input
output

结果分析:终结了测试1中的猜想。只能是node或以下的实现。

4、测试下不同机器的浏览器同时访问。

结果为能并发成功:

input
input
output
output

测试了同一机器的不同类型的浏览器进行测试(用了chrome和safari)。

结果为能并发成功:

input
input
output
output 

结果分析:chrome 两个窗口访问请求并不是独立的。

猜测:chrome两个窗口相同的请求共用了tcp连接。(才想到http1.1的服用tcp请求的时候是按顺序的)。

5、打印出tcp连接对应的请求端的端口。

当在mac下两个chrome窗口的时候,

结果为:

input 54345
output 54345
input 54345
output 54345

当不同浏览器的请求的接口:

结果为:

input 54355
input 54356
output 54355
output 54356

结果分析:在纯chrome环境下,相同http请求共用了tcp连接,产生串行的效果。在区分浏览器的环境下,两个http请求分别使用了各自的tcp连接,能产生并发效果。

结论:在chrome浏览器,即使你开了两个窗口,但是它们还是不完全独立的,会共用tcp连接。产生请求串行效果。一定情况下方便调试。

  如果要测试并发的http请求。需要开启多个tcp连接。

node.js http接口调试时请求串行特性分析的更多相关文章

  1. Centos 7 上使用nginx为Node.js配置反向代理时错误:(13: Permission denied) while connecting to upstream

    错误来源:Centos 7 上使用nginx为Node.js配置反向代理时产生(13: Permission denied) while connecting to upstream的错误 nginx ...

  2. 记录一次用宝塔部署微信小程序Node.js后端接口代码的详细过程

    一直忙着写毕设,上一次写博客还是元旦,大半年过去了.... 后面会不断分享各种新项目的源码与技术.欢迎关注一起学习哈! 记录一次部署微信小程序Node.js后端接口代码的详细过程,使用宝塔来部署. 我 ...

  3. 用简单的 Node.js 后台程序浅析 HTTP 请求与响应

    用简单的 Node.js 后台程序浅析 HTTP 请求与响应 本文写于 2020 年 1 月 18 日 我们来看两种方式发送 HTTP 请求,一种呢,是命令行的 curl 命令:一种呢是直接在浏览器的 ...

  4. 使用Redis分布式锁控制请求串行处理

    1.需求背景 在一些写接口的场景下,由于一些网络因素导致用户的表单重复提交,就会在相邻很短的时间内,发出多个数据一样的请求.后台接口的幂等性保证一般都是先检查数据的状态,然后决定是否进行执行写入操作, ...

  5. 利用Node.js的Net模块实现一个命令行多人聊天室

    1.net模块基本API 要使用Node.js的net模块实现一个命令行聊天室,就必须先了解NET模块的API使用.NET模块API分为两大类:Server和Socket类.工厂方法. Server类 ...

  6. Node.js中,获取req请求的原始IP

    Node.js代码 var express = require('express'); var app = express(); var http = require('http'); var ser ...

  7. MVC打包压缩JS&CSS文件调试时过滤了一些文件

    BundleTable.这个确实是比较好用,打包并压缩了CSS,使之加载时减少流量. 但是在调试的时候会疑问为何有很多JS,CSS文件无法打包,其实是因为调试时VS自动过滤了如下文件:   后台跟踪了 ...

  8. node.js系列(实例):原生node.js实现接收前台post请求提交数据

    前台界面: 前台代码: <form class="form-horizontal" method="post" action="http:127 ...

  9. node.js在读取文件时中文乱码问题

    断更很久了........从今天开始会努力的持续更博,积极学习. 言归正传.今天在写node.js的demo时发现一个bug.我在node中读取本地的text文件时,发现英文的内容可以被读取,但是中文 ...

随机推荐

  1. Oracle rac 监听状态异常远程连接问题解决(TNS-12541 TNS-12560 TNS-00511 Linux Error:111 ORA-12502)

    问题1现象 数据导出脚本执行失败,报错如下 ORA-12537 到服务器上查看,报错: [oracle@test ~]$ lsnrctl status LSNRCTL - Production on ...

  2. Java链接MySQL数据库的用配置文件和不用配置文件的代码

    1.利用配置文件(db.properties)链接MySQL数据库 package tool; import java.io.FileInputStream;import java.sql.Conne ...

  3. 【我的前端自学之路】【HTML5】web 存储

    以下为自学笔记内容,仅供参考. 转发请保留原文链接:https://www.cnblogs.com/it-dennis/p/10503539.html 什么是Web存储 cookie最大的缺陷是在每一 ...

  4. j2ee课程设计—基于activiti的请休假系统

    前言 课设基于SSM框架,数据库采用mysql,主要业务交给activiti,版本控制利用github. 参考资料: Intellij 部署SSM框架 Activiti就是这么简单 方大师的教材 下文 ...

  5. ios高级开发之多线程(二)NSThread技术

    多线程技术是有多套解决方案的,那么我们该如何选择呢? 技术方案 简介 语言 线程生命周期 使用频率 pthread 1.一套通用的多线程API 2.适用于UNIX,linux,windows等 3.跨 ...

  6. Python玩转Arduino——简单介绍

    关于Python语言的介绍安装请参考廖雪峰的Python教程 Python是一门解释型语言,虽然不能够像c语言一样编译上传到Arduino--什么你说MicroPython,我们再说Arduino呢- ...

  7. Unity3D|-使用ScriptableObject脚本化对象来制作一个简单的对象池

    ScriptableObject是一个用于生成单独Asset的结构.同时,它也能被称为是Unity中用于处理序列化的结构. 可以作为我们存储资源数据的有效方案.同时此资源可以作为我们AB包的有效资源! ...

  8. aop(execution()表达式)

    execution(* com.tp.soft.service..*.*(..)) 整个表达式可以分为五个部分: 1.execution(): 表达式主体. 2.第一个*号:表示返回类型,*号表示所有 ...

  9. 《Java8实战》读书笔记

    个人感悟: 1.lambda表达式,补充了JAVA在面向对象之外,面向过程的一面.在写面向过程代码的时候更方面了,甚至可以利用代码来做类似数学公式的运算(P64) 2.流,对集合的操作,就像用SQL对 ...

  10. 第一章 Java语言概述1

    1.人机交互有两种方法:一种是图形化界面,一种是命令行方式 2.如何打开命令行:开始-在运行命令行中输入cmd 3.常用的DOS命令: dir(directory):列出当前目录下文件及文件夹 md( ...