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. HTTP权威协议笔记-7.缓存

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

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

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

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

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

  6. 转-HttpClient4.3 连接管理

    转 http://www.yeetrack.com/?p=782 2.1.持久连接 两个主机建立连接的过程是很复杂的一个过程,涉及到多个数据包的交换,并且也很耗时间.Http连接需要的三次握手开销很大 ...

  7. Mongodb Manual阅读笔记:CH4 管理

    4 管理 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mongodb Manual阅读笔 ...

  8. Struts2权威指南笔记

    Struts2权威指南笔记 1.mvc特点包括: ① 多个视图可以对应一个模型 ② 模型返回的数据与显示逻辑分离 ③ 应用层被分隔为三层,降低了各层之间的耦合,提供了应用的可扩展性 ④ 控制层的概念也 ...

  9. SOFA 源码分析 — 连接管理器

    前言 RPC 框架需要维护客户端和服务端的连接,通常是一个客户端对应多个服务端,而客户端看到的是接口,并不是服务端的地址,服务端地址对于客户端来讲是透明的. 那么,如何实现这样一个 RPC 框架的网络 ...

随机推荐

  1. bzoj2928: [Poi1999]飞弹

    惨啊…… 被卡常是一种什么感受&…… 很明显的分治. 我们首先可以找到所有点中的最低点,然后对所有点进行一次极角排序,选取一个点使得他各侧飞弹和地堡一样多,并对两侧继续进行分治. 很容易证明这 ...

  2. 无参数实例化Configuration对象以及addResource无法加载core-site.xml中的内容

    core-site.xml中配置的fs.default.name是hdfs://localhost:9000.但是这里读取出来的是本地文件系统.原因暂不知?有谁知道?

  3. CLR via C# 学习计划

    本书是学习c#的人必读书,计划今年完成,读透. 书是在亚马逊买的,虽然有点小贵,但是为了情怀,咬咬牙买了. 需要学习的: CLR基础 (CH1-CH3) 设计类型 (CH4-CH13) 基本类型 (C ...

  4. 研究dotnet动态语言IronPython(对应Java的Groovy)

    Java的标配动态语言Groovy,两者搭配可以说是完美!大规模运用的项目,如:Jenkins,通过动态语言可以弥补先天系统缺陷的bug,再者就是加强自己的业务逻辑等. 那么换过dotnet上,对应的 ...

  5. StringBuffer类 和 StringBuilder类

    上一篇中讲解了String类的用法.那么String有什么特点呢? 字符串特点:字符串是常量,其值在创建后就不能被修改.字符串的内容一旦发生变化,就会创建一个新的对象. 代码验证字符串特点: publ ...

  6. 浅谈分治算法在OI中的应用

    分治虽然是基本思想,但是OI中不会出裸分治让你一眼看出来,往往都是结合到找规律里面. 先来个简单的: 奇妙变换 (magic.pas/c/cpp) [问题描述]   为了奖励牛牛同学帮妈妈解决了大写中 ...

  7. SqlServer 在创建数据库时候指定的初始数据库大小是不能被收缩的

    当你在SqlServer创建数据库的时候可以指定数据库文件的初始大小,比如下图中我们将新创建的数据库MyDB的大小设置成了1024MB 那么你建好的数据库的确也就会占用1024MB左右的磁盘空间 不过 ...

  8. poj1785 Binary Search Heap Construction

    此题可以先排序再用rmq递归解决. 当然可以用treap. http://poj.org/problem?id=1785 #include <cstdio> #include <cs ...

  9. SQL Server数据库(SQL Sever语言 存储过程及触发器)

    存储过程:就像函数一样的会保存在数据库中-->可编程性-->存储过程 创建存储过程: 保存在数据库表,可编程性,存储过程create proc jiafa --需要的参数@a int,@b ...

  10. Java [Leetcode 338]Counting Bits

    题目描述: Given a non negative integer number num. For every numbers i in the range 0 ≤ i ≤ num calculat ...