第2章 TCP-IP的工作方式

TCP/IP协议系统

为了实现TCP的功能,TCP/IP的创建者使用了模块化的设计。TCP/IP协议系统被分为不同的组件,每个组件分别负责通信过程的一个步骤。这种模块化的好处在于让厂商方便地根据特定硬件和操作系统对协议软件进行修改。这样厂商在使用光纤网络时就不必重新构建一个全新的TCP/IP,只要修改其中的某一层就好。

TCP/IP模型

graph TD
应用层-->传输层
传输层-->网际层
网际层-->网络访问层
  • 网络访问层:提供了与物理网络连接的接口。针对传输介质设置数据的格式,根据硬件的物理地址实现数据的寻址,对数据在物理网络中的传递提供错误控制
  • 网际层:提供独立于硬件的逻辑寻址,从而让数据能够在具有不同物理结构的子网之间传递。提供路由功能来降低流量,支持网间的数据传递(网间是指多个局域网互相连接而形成的较大网络,比如大公司里的网络或Internet)。实现物理地址与逻辑地址的转换。
  • 传输层:为网络提供了流量控制、错误控制和确认服务。充当网络应用程序的接口
  • 应用层:为网络排错、文件传输、远程控制和Internet操作提供了应用程序,还支持api,从而使得针对特定操作系统编写的程序能够访问网络

当TCP/IP协议软件准备通过网络传递数据时,发送端计算机上的每一层协议都在数据上添加层信息,对应于接收端计算机上相应的层。例如:发送端计算机的网际层会向数据添加报头信息,这个过程有时也被称为封装。在接收端,当数据在协议栈里传递时,这些报头信息被逐步去除。

OSI模型

出现缘由:网络业界针对网络协议体系有一个标准的七层模型,称为“开放系统互连(OSI)”模型,这是ISO(国际标准化组织)为了标准化网络协议系统所做出的规范,目的在于提高网络互联性,并且方便软件开发人员以一种开放的方式来使用协议标准。

OSI把网络访问层的功能划分为数据链路层和物理层,将应用层划分为应用层、表示层、会话层。

graph TD

应用层-->表示层
表示层-->会话层
会话层-->传输层
传输层-->网络层
网络层-->数据链路层
数据链路层-->物理层

各层级的具体作用:

  • 物理层: 把数据转换为传输介质上的电子流或模拟脉冲,并且监视数据的传输
  • 数据链路层:提供与网络适配器相连的接口,维护子网的逻辑链接
  • 网络层:支持逻辑寻址与路由选择
  • 传输层:为网络提供错误控制和数据流控制
  • 会话层:在计算机的通信应用程序之间建立会话
  • 表示层:把数据转换为标准格式,管理数据加密与压缩。
  • 应用层:为应用程序提供网络接口,支持文件传输、通信等功能的网络应用

数据包

在数据发送过程中,其流程是从堆栈的上到下,每一层都把相关信息(称为报头)捆绑到实际的数据上。包含报头信息和数据的数据包就作为下一层的数据,再次被添加报头信息和重新打包。接受过程是恰恰相反的,在数据从下到上经过协议栈的过程中,每一层都解开相应的报头,比如:接收端计算机上的网际层会使用网际层的头信息,传输层会使用传输层的报头信息。

数据包在每一层具有不同的形式和名称。

  • 在应用层生成的数据包称为消息。
  • 在传输层生成的数据包封装了应用层的消息,如果它来自于传输层的TCP协议,就称为分段;如果来自于传输层的UDP协议,就被称为数据报
  • 网际层的数据包封装了传输层的片段,被称为数据报
  • 网络访问层的数据包封装了数据报,被称为帧。帧被访问层的最低子层转化为比特流

基本的TCP/IP协议联网系统

  1. 数据从工作于应用层的协议、网络服务或应用编程接口通过TCP或UDP端口传递到两个传输层协议(TCP或UDP)中的一个。程序可以根据需要通过TCP或UDP访问网络

    • TCP是面向连接的协议。面向连接的协议提供更复杂的流量控制和错误控制。TCP能够确保数据的发送质量,比UDP更可靠,但由于需要进行额外的错误检测和流量控制,因此比UDP的速度慢
    • UDP是个无连接的协议,比TCP快,但是不可靠,它把错误控制的责任推给了应用。
  2. 数据分段传递到网际层,IP协议在此提供逻辑寻址信息,并且把数据封装为数据报。
  3. IP数据报进入网络访问层,传递到与物理网络相连接的软件组件。网络访问层创建一个或多个数据帧,从而进去物理网络。在像以太网这样的局域网系统中,帧可能包含获得的物理地址信息。而这些是由网际层的ARP维护
  4. 数据帧被转化为比特流,通过网络介质进行传输

(读书笔记)第2章 TCP-IP的工作方式的更多相关文章

  1. TCP/IP解析(一):TCP/IP的工作方式

    本文包括下面内容: 1.TCP/IP协议系统 2.OSI模型 3.数据包 4.TCP/IP的交互方式 1.TCP/IP模型的协议层 分为四层: 网络訪问层:提供与物理网络连接的接口.依据硬件的物理地址 ...

  2. 《Linux内核设计与实现》读书笔记——第一二章

    <Linux内核设计与实现>读书笔记——第一二章 第一章 Linux内核简介 1.1 Unix的历史 简洁:仅提供系统调用并有一个非常明确的设计目的. 抽象:Unix中绝大部分东西都被当做 ...

  3. 第6章 TCP/IP路由协议故障处理

    第6章 TCP/IP路由协议故障处理 一.缺省网关 当包的目的地址不在路由器的路由表中,如路由器配置了缺省网关,则转发到缺省网关,否则就丢弃. Show ip route :查看Cisco路由器的缺省 ...

  4. 《Linux内核设计与实现》第八周读书笔记——第四章 进程调度

    <Linux内核设计与实现>第八周读书笔记——第四章 进程调度 第4章 进程调度35 调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间,进程调度程序可看做在可运行态进程之间分配 ...

  5. 《Linux内核设计与分析》第六周读书笔记——第三章

    <Linux内核设计与实现>第六周读书笔记——第三章 20135301张忻估算学习时间:共2.5小时读书:2.0代码:0作业:0博客:0.5实际学习时间:共3.0小时读书:2.0代码:0作 ...

  6. 《Linux内核设计与实现》 第八周读书笔记 第四章 进程调度

    20135307 张嘉琪 第八周读书笔记 第四章 进程调度 调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间,进程调度程序可看做在可运行态进程之间分配有限的处理器时间资源的内核子系统.只有 ...

  7. 《Linux内核分析》读书笔记(四章)

    <Linux内核分析>读书笔记(四章) 标签(空格分隔): 20135328陈都 第四章 进程调度 调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间,进程调度程序可看做在可运行 ...

  8. 《深入分析Java Web技术内幕》读书笔记 - 第1章 深入Web请求过程

    第1章 深入Web请求过程 1 1.1 B/S网络架构概述 2 基于统一的应用层协议HTTP来交互数据. 1.2 如何发起一个请求 4 HTTP连接本质是建立Socket连接.请求实现方式:工具包如H ...

  9. 《LINUX内核设计与实现》第三周读书笔记——第一二章

    <Linux内核设计与实现>读书笔记--第一二章 20135301张忻 估算学习时间:共2小时 读书:1.5 代码:0 作业:0 博客:0.5 实际学习时间:共2.5小时 读书:2.0 代 ...

  10. 《Linux内核设计与实现》第四周读书笔记——第五章

    <Linux内核设计与实现>第四周读书笔记--第五章 20135301张忻 估算学习时间:共1.5小时 读书:1.0 代码:0 作业:0 博客:0.5 实际学习时间:共2.0小时 读书:1 ...

随机推荐

  1. python py_innodb_page_info.py -v /usr/local/var/mysql/ibdata1

    mylib.py #encoding=utf-8 import os import include from include import * TABLESPACE_NAME='D:\\mysql_d ...

  2. Docker,容器,虚拟机和红烧肉

    Docker火了,有多火你自己看看下面的统计数据就知道了 在发布4个月的时间里,下载量就超过50000次,github上收到超过4000个star,涌现了超过100个贡献者,并且有超过150个项目和超 ...

  3. Word常用实用知识1

    Word常用实用知识1 纯手打,可能有错别字,使用的版本是office Word 2013 转载请注明出处,谢谢. 快速输入日期(含格式) [插入]--[日期]   快速输入日期和时间(快捷键) 快速 ...

  4. python之FTP程序(支持多用户在线)

    转发注明出处:http://www.cnblogs.com/0zcl/p/6259128.html 一.需求 1. 用户加密认证 (完成)2. 允许同时多用户登录 (完成)3. 每个用户有自己的家目录 ...

  5. 安装Hadoop及Spark(Ubuntu 16.04)

    安装Hadoop及Spark(Ubuntu 16.04) 安装JDK 下载jdk(以jdk-8u91-linux-x64.tar.gz为例) 新建文件夹 sudo mkdir /usr/lib/jvm ...

  6. yum安装CDH5.5 Hadoop集群

    1.环境说明 系统环境: 系统环境:centos6.7 Hadoop版本:CDH5.5 JDK运行版本:1.7.0_67 集群各节点组件分配: 2.准备工作 安装 Hadoop 集群前先做好下面的准备 ...

  7. linux 标准目录

    转自 http://www.weixuehao.com/archives/492 装完Linux,首先需要弄清Linux 标准目录结构 / root -?启动Linux时使用的一些核心文件.如操作系统 ...

  8. arcpy.mapping常用四大件-MapDocument

    arcpy.mapping常用四大件-MapDocument by 李远祥 点开arcpy.mapping的帮助,可以看到其有限的几个类,看起来东西不是很多,但却是非常的使用.由于arcpy定位就是粗 ...

  9. Android 友盟分享详细集成过程及所遇问题解决

    最近项目需要针对微信.朋友圈.QQ.QQ空间集成友盟分享的功能,说实话,我也是第一次做,期间碰到过很多问题,这篇随笔就来写一下我是怎么集成友盟分享的,还有碰到哪些问题,都是怎样解决的! 其实集成友盟并 ...

  10. Git 和 GitHub 使用

    Git和GitHub的使用 Git是一款免费.开源的分布式版本控制系统. GitHub托管远程仓库,并提供一个web界面. 有2种协议支持从本地push代码到远程仓库. 一种是http,需要输入用户名 ...