Node.js :HTTP请求和响应流程

 

HTTP请求和响应

  1. 域名解析,先搜索浏览器自身DNS缓存,看是否有缓存或者缓存已经失效

    chrome查看dns地址 :chrome://net-internets/#dns

  2. 搜索操作系统自身的缓存
  3. 读取本地的host文件
  4. 浏览器发起一个dns的一个系统调用
  5. 宽带服务商服务器查找自身缓存
  6. 运营商会发起一个迭代DNS解析请求
  7. 运营商服务器会把结果返回操作系统内核同时缓存起来
  8. 操作系统把结果返回给浏览器,最终返回ip地址
  9. 浏览器获得域名对应的ip地址后,发起http三次握手
  10. TCP/IP建立起来后,浏览器就可以向服务发送http请求
  11. 服务器接收到请求,根据路径参数,经过后端的处理后,把处理结果返回给浏览器。
  12. 浏览器拿到html页面代码,在解析和渲染时,里面的所有资源都需要经过这样的步骤

Timing 图形化显示请求资源耗费的时间

Stalled: 等待时机,浏览器要发生请求,到能发出请求的时间。不包括DNS查询和连接建立时间
Proxy negotiation: 代理协商的时间
Request sent 请求时间。从请求报文的第一个字节发出,到最后一个字节发送完毕的时间
Waiting(TTFB) 请求发出后至收到第一个字节响应的时间
Content Download 从接收到响应第一个字节开始到最后一个字节结束花费的时间


请求方法

get:请求资源
post:提交资源
put:更新
delete:删除
head:类似get
trace
options


状态码

1xx 请求已经接收
2xx 请求成功并处理成功 200:OK
3xx 重定向
4xx 客户端错误 400:客户端请求有语法错误 401:请求未经授权 403:收到请求,但不提供服务 404:资源未找到
5xx 服务器端错误 500:服务器端未知错误 503:服务器端当前不能处理请求


什么是回调?

回调是异步编程时的基础,将后续逻辑封装成起始函数的参数,逐层嵌套


什么是同步/异步?

同步是指:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式。
异步是指:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式。


什么是I/O?

磁盘的写入(in)磁盘的读取(out)


什么是单线程/多线程?

一次只能执行一个程序叫做单线程
一次能执行多个程序叫多线程


什么是阻塞/非阻塞?

阻塞:前一个程序未执行完就得一直等待
非阻塞:前一个程序未执行完时可以挂起,继续执行其他程序,等到使用时再执行


什么是事件?

一个触发动作(例如点击按钮)


什么是事件驱动?

一个触发动作引起的操作(例如点击按钮后弹出一个对话框)
什么是基于事件驱动的回调?
为了某个事件注册了回调函数,但是这个回调函数不是马上执行,只有当事件发生的时候,才会调用回调函数,这种函数执行的方式叫做事件驱动~这种注册回调就是基于事件驱动的回调,如果这些回调和异步I/O(数据写入、读取)操作有关,可以看作是基于回调的异步I/O,只不过这种回调在nodejs中是有事件来驱动的。


什么是事件循环?

事件循环Eventloop,倘若有大量的异步操作,一些I/O的耗时操作,甚至是一些定时器控制的延时操作,它们完成的时候都要调用相应的回调函数,从而来完成一些密集的任务,而又不会阻塞整个程序执行的流程,此时需要一种机制来管理,这种机制叫做事件循环.总而言之就是:管理大量异步操作的机制叫做事件循环。


Event Loop

回调函数队列。异步执行的函数会被压入这个队列; 队列被循环查询。


什么是作用域?

与调用函数,访问变量的能力有关 作用域分为:局部和全局(在局部作用域里可以访问到全局作用域的变量,但在局部作用域外面就访问不到局部作用里面所设定的变量)


什么是上下文?

与this关键字有关 是调用当前可执行代码的引用
this总是指向调用这个的方法的对象
js里的this 通常是当前函数的拥有者
this 是js的一个关键字 代表函数运行时自动生成的一个内部对象 只能在函数内部使用

1.作为对象的方法
this在方法内部,this就指向调用这个方法的对象
2.函数的调用
this指向执行环境中的全局对象(浏览器->window nodejs->global)
3.构造函数
this所在的方法被实例对象所调用,那么this就指向这个实例对象

更改上下文方法(更改this指向的内容,可方便地实现继承):call(list),apply(array);
根据call()、apply()改变上下文this指向的特性,也可以方便实现继承

function pet(words) { this.words = words this.speak = function () { console.log(this.words) } } function dog(words) { pet.call(this, words) //pet.apply(this,words) } var Dog = new dog('wang') dog.speak()


HTTP性能测试

使用apache ab测试
./ab -n1000 -c10 http://localhost:80/

参数说明:
-n :总共的请求执行数,缺省是1;
-c: 并发数,缺省是1;
-t:测试所进行的总时间,秒为单位,缺省50000s
-p:POST时的数据文件
-w: 以HTML表的格式输出结果

    在window系统下,需要先用cd命令定位到你的apache安装目录的bin文件夹

    

 

posted @ 2017-07-05 21:32  赞笔  阅读(1732)  评论(0编辑  收藏  举报