4.1 TCP连接

  TCP为HTTP提供了一条可靠的比特传输管道,按顺序正确的传输,步骤如下:

  1. 浏览器解析主机名。
  2. 查询这个主机名的IP地址(DNS)
  3. 获得端口号。
  4. 浏览器对服务器该端口号发起连接。
  5. 向服务器发送请求报文。
  6. 从服务器获取响应报文。
  7. 连接关闭。

4.1.2 TCP流是分段的、由IP分组传送

  TCP的数据是通过名为IP分组的小数据块来发送的。Http发送一份报文时,会以流的形式建立一条TCP连接按序传输。

  TCP在接收到流之后会将数据流砍成被称作段的小数据块,封装在IP分组中,通过因特网传输。

  每个TCP段由IP分组承载,每个IP分组包括:

    • 一个IP分组首部(20字节)
    • 一个TCP段首部(20字节)
    • 一个TCP数据块(0个或多个字节)

  IP首部包含源和目的的IP地址、长度和其他一些标记

  TCP段首部包含:TCP端口、控制标记等

4.1.3 用TCP套接字编程

  1.   s=socket(parameters)                   创建一个新的、未命名的套接字
  2.   bind(s,local IP:Port)                    向套接字赋一个本地IP及端口
  3. connect(s,remote IP:port)         创建与服务器的连接
  4. listen(s,...)                                    标识一个本地套接字,使其可以合理接收连接
  5. s2=accep(s)                                  等待某人建立一条到达本地端口的连接
  6. n=read(s,buffer,n)                     尝试从套接字缓存区读取n个字节
  7. n=write(s,buffer,n)                    尝试从缓存区向套接字写入n个字节
  8. close(s)                                        完全关闭TCP连接
  9.   shutdown(s,side)                         只关闭TCP连接的输入或输出端
  10.   getsocket(s,...)                            读取某个内部套接字配置选项的值
  11.   Setscoket(s,...)                            修改某个内部套接字配置选项的值

  例(盗图):

    

    注:先是请求连接,在连接成功才会发送报文。

4.2 TCP性能

  TCP连接握手需要以下步骤:

  1. 请求新的TCP连接时客户端向服务端附送笑的TCP分组,这个分组设置了SYN标记,表明是一个连接请求。
  2. 服务器接受连接,返回一个TCP分组。
  3. 客户端向服务端发送一条确认信息,现在可以传送数据了。

4.2.2 串行事物处理时延

  如果同时请求多个请求报文时,TCP的性能延时会叠加起来。以下几种可提高性能方法:

  1.并行连接

    通过多条TCP连接发起并发的HTTP请求。

  2.持久连接

    重用TCP连接,以消除连接及关闭延时。

  3.管道化连接

     通过共享的TCP连接发起并发HTTP的请求。

  4.复用连接

    交替发送请求和响应报文(试验阶段)

    

HTTP权威协议笔记-4.连接管理的更多相关文章

  1. HTTP权威协议笔记-6.代理

    6.1 Web的中间实体 Http的代理服务器即是客户端的服务器又是服务器的客户端. 它介于服务器与客户端之间,当客户端发送请求报文经过它时,它会像服务器一样正确的处理请求和返回响应,同时,代理服务器 ...

  2. HTTP权威协议笔记-7.集成点:网关、隧道及中继

    .8.1 网关 定义:网关类似与翻译器,它抽象出了一种能够到达资源的方法. 实用:网关可以自动将HTTP流量转换为其他协议,这样使用HTTP协议的一方就不需要了解其他协议,也可实现与其他程序或设备交互 ...

  3. TCP/IP 笔记 - TCP连接管理

    TCP是一种面向连接的单播协议,在发送数据之前,通信双方必须在彼此建立一条连接:这与UDP的无连接不同,UDP无需通信双方发送数据之前建立连接.所有TCP需要处理多种TCP状态时需要面对的问题,比如连 ...

  4. MQTT协议笔记之连接和心跳

    前言 本篇会把连接(CONNECT).心跳(PINGREQ/PINGRESP).确认(CONNACK).断开连接(DISCONNECT)和在一起. CONNECT 像前面所说,MQTT有关字符串部分采 ...

  5. HTTP权威协议笔记-7.缓存

    7.1 冗余的数据传输 缓存的作用:当客户端每次访问服务器,服务器都会返回一份相同文件,一些相同的字节会不断的在网络内传输,这样冗余的数据传输会耗尽昂贵的带宽,降低传输速度,加重Web服务器的负载. ...

  6. HTTP权威协议笔记-5.Web服务器

    5.1 Web服务器工作内容 建立连接--接受一个客户端的连接,或者将其拒绝 接受请求--从网络中读取一条HTTP报文 处理请求--对请求报文进行解释,并采取行动 访问资源--访问报文中指定的资源 构 ...

  7. HTTP权威协议笔记-3.Http报文

    3.1 报文流 http使用流入和流出来描述事物处理方向,报文包含:起始行.首部和主体. 3.2 起始行 起始行包含:请求行和回应行. 3.2.1请求行 请求行包含:方法.请求URL(描述了对哪个资源 ...

  8. 《HTTP权威指南》之HTTP连接管理及对TCP性能的考虑

    在上一篇博客中(<HTTP权威指南>之HTTP相关概念详解)我们简单对HTTP相关的基本概念做了一些简单的了解,但未对HTTP连接管理的内容做一些详细的介绍.本篇博客我们就一起来看一下HT ...

  9. 和我一起学《HTTP权威指南》——连接管理

    连接管理 1.TCP连接 几乎所有的HTTP通信都是由TCP/IP承载的. 浏览网页时客户端执行的操作: 如浏览http://www.joes-hardware.com:80/power-tools. ...

随机推荐

  1. ASP.MVC EASY UI 入门之 —— Tree &amp; ComboTree

    1.常规的EASY UI的tree和comboTree代码基本是官方的DEMO都有的,虽然很简单,但是还是要实践的做一次,才能更清晰的了解和使用它!先上效果图 因为用的是code first,所以数据 ...

  2. js常用功能汇总

    var Utils = function() { this.Tools; this.ui; }; Utils = new Utils(); Utils.prototype.Tools = { year ...

  3. jquery 延迟加载代码

    <!--引入以下两个js文件--> <script type="text/javascript" src="./js/jquery.min.js&quo ...

  4. MongoDB 复制

    副本集:简单说,副本集就是有自动故障恢复功能的主从集群.主从集群和副本集最为明显的区别:副本集没有固定的“主节点”.整个集群会选出一个主节点.当其不能工作时,变更到其他节点.二者看起来非常相似:副本集 ...

  5. cocos2d 缓存池 对象的再利用

    1.简单的叙述说明池 例如,我们知道,游戏的游戏类型跑酷,游戏元素都在不断重复.游戏的内容将继续从屏幕右侧的创建,当元件在屏幕的左侧的,将消失.假设不变new 对象.release 对象 性能影响.怎 ...

  6. python之numpy的安装

    这是我第一次写博客,我的第一次打算送给python的numpy库的安装指导,这是我看到一位大神的博客后产生的启发,真是控制不住自己,必须得写一下. 第一次安装numpy浪费了我一个下午,结果还没安装好 ...

  7. [C#]使用 C# 编写自己的区块链挖矿算法

    [C#] 使用 C# 编写自己区块链的挖矿算法 文章原文来自:Code your own blockchain mining algorithm in Go! ,原始文章通过 Go 语言来实现的,这里 ...

  8. 1.3 正则表达式和Python语言-1.3.5使用 search()在一个字符串中查找模式(搜索与匹配 的对比)

    1.3.5 使用 search()在一个字符串中查找模式(搜索与匹配的对比) 其实,想要搜索的模式出现在一个字符串中间部分的概率,远大于出现在字符串起始部分的概率.这也就是 search()派上用场的 ...

  9. android程序----&gt;android多线程下载(二)

    上篇我们讲到了android中下载的断点续传问题,今天我们开始学习下载的多线程问题.本次的多线程源码下载:androdi中多线程下载的实现代码.有关断点续传的问题,请参见博客:android程序--- ...

  10. Leetcode 题解 First Missing Positive

    Given an unsorted integer array, find the first missing positive integer. For example,Given [1,2,0]  ...