TCP/IP协议工作原理简述

TCP/IP协议工作原理简述

Table of Contents

  • 1 概要
  • 2 应用层
  • 3 传输层
  • 4 网络层
  • 5 链路层

1 概要

协议是什么?协议是一组为完成特定需求或功能而定义的标准通讯格式。协议是服务于具体需求或功能的,它不能独立存在。

制定TCP/IP协议的目的是为了解决主机互联以及互联的主机上的应用通讯的问题。TCP/IP协议共有四层:应用层、传输层、网络层、链路层。应用层实际就是我们的应用程序,对于非具体应用而言这一层的协议是未定义的,需要我们自己根据我们具体的业务模型来制定。传输层桥接应用层和网络层,向下为我们的应用层数据填入端口标识,向上根据端口标识往各个应用分发数据包。网络层主要的功能是逻辑选路,确保我们的数据包能到达指定的目的地。链路层负责往/从有直接物理链路相连的主机或路由器发包/收包。

TCP/IP协议是工作在主机或路由器上的,这一点很明显,因为网络拓扑中的实体除了主机(路由器)就是链路,链路当然不能运行我们的协议,它只能传输数据。当主机A中的a程序需要跟主机B中的b程序通讯的时候,A主机会根据TCP/IP协议往我们的原始数据包中依次塞入:TCP首部字段(假如应用程序基于TCP协议)、IP首部字段、以太网首部字段,最后形成的数据包我们称之为以太网数据帧,任何一台主机发送和接收的都只能是以太网数据帧;B主机收到相应的以太网数据帧后,会依次丢弃:以太网首部字段、IP首部字段、TCP首部字段,然后再将剩下的数据包交给b程序。现如今,很多复杂的应用程序也采用类似的思想对应用层协议进行分层。

2 应用层

常见的应用层协议有:

  • echo 7/tcp(udp)
  • daytime 13/tcp(udp)
  • ftp 21/tcp(udp)
  • ssh 22/tcp(udp)
  • telnet 23/tcp(udp)
  • tftp 69/tcp(udp)
  • finger 79/tcp(udp)
  • http 80/tcp(udp)
  • https 443/tcp(udp) # http protocol over TLS/SSL

应用层协议与我们具体编写的应用相关,它是整个TCP/IP协议族的最上层协议,也是唯一由用户制定通讯格式的协议(标准委员会不能未卜先知)。数据传输一般是由应用层发起的,但它除了提供一个目标地址(域名或IP地址)之外,不涉及任何传输细节。应用层只专注于应用所属领域内的业务逻辑。

3 传输层

工作在传输层的协议主要有TCP和UDP协议。传输层主要负责主机内的应用层数据包的收取和派发工作。应用层组好包后将数据包交给传输层,传输层经过一定的处理(填充TCP或UDP首部字段)之后,再转交给IP协议模块;传输层从下层IP模块收包时,去掉本层相关的首部字段,再将数据包派发给各个应用程序。由于传输层服务的对象是主机内的所有应用程序,所以它需要特定的手段来区分不同的应用程序,此即,端口。

只做上面这些事情似乎有点少!对,标准委员会的人也是这么想的。所以,除了上面的核心业务之外,不同的传输层协议还提供了点增值服务。例如:TCP提供可靠的数据传输业务;UDP提供一对多的广播业务。

传输层同样不清楚传输细节,它只对上层应用层负责。

4 网络层

工作在网络层的协议主要有:IP协议、ICMP以及IGMP协议。其中IP协议最为重要,ICMP和IGMP协议也得依赖IP协议来收发包。

网络层的核心业务即是选路(确定数据包的下一跳),在所有的网络层协议中,IP协议负责该核心业务,所以我们有时候也直接用IP协议来指代网络层。在处理上层传输层和下层链路层发来的数据包时,IP协议的行为是不一样的,前者,仅仅填入本机和目的端IP地址;后者,对于本应交给本机的数据包提交给上层传输层,对于非交给本机的数据包也为它们指明下一跳(需特殊配置主机)。可以看到IP协议不仅对本机尽职尽责,同时也颇具助人为乐的精神,事实上,这种助人为乐的精神正是整个TCP/IP协议得以正常运转的核心。

IP协议为上层传输层下发的数据包或路过的数据包选好路后,它们并不亲自将包送达下一站,而是将它们交代给链路层去护送。

5 链路层

工作在链路层的协议主要包括:Ethernet、IEEE 802、ARP、RARP等协议。链路层的核心功能是:1. 将数据包发送给有直接物理链路相连的主机(或路由器) 2. 从有直接物理链路相连的主机(或路由器)处收取数据。链路层执行的是实际的收发包工作,所以,它们只能往/从有直接物理链路相连的主机(或路由器)发送/收取数据,毕竟,物理规律总是得遵守的。

链路层必须向物理链路上发送所有IP协议交代下来的数据包,必须将所有收到的数据包(以太网数据帧)交给IP协议处理。链路层是没有什么自主权的,不能擅自截留,不能擅自丢包,能做的仅仅是搬运,实实在在的搬砖工人。链路层也没什么智商,IP交给它的数据包虽然包含IP地址,但它却看不明白,它只认物理地址(即48位mac地址)。如果某个IP地址是它不久前去过的地方(ARP缓存),那当要送包再去往该IP地址时,它直接就能送;否则,就得挨个问一遍,有则去,没有就算了。而且它也很容易被欺骗,网关就经常骗它。网关为什么要欺骗它呢?因为IP协议决定的下一跳不一定就在局域网中(即跟当前主机没有直接相连的物理链路),而链路层工作能力有限,只能在局域网内发包,所以网关只好骗它说我就是目标地址的主机。

Date: 2015-12-20T21:07+0800

Author: ruleless

Org version 7.9.3f with Emacs version 24

Validate XHTML 1.0

时间: 2024-11-05 02:18:13

TCP/IP协议工作原理简述的相关文章

TCP/IP 协议工作原理与Linux系统下调优

TCP/IP建立连接的三次握手过程: 建立TCP连接共需要三个packet Client--> syn=1,ack=0,fin=0 -->  Server Client<--  syn=1,ack=1,fin=0 <--  Server Client-->  syn=0,ack=1,fin=0 -->  Server TCP/IP关闭连接的四个过程: 关闭TCP连接需要四个packet: Client-->  FIN  -->  Server Client&

TCP/IP协议族——ARP、DNS工作原理及实例详解

 测试网络: 通过VMware创建了两个虚拟机,并利用桥接方式联网以此模拟两台主机连接一台路由器的情况.测试网络图如下: ARP协议工作原理 ARP协议能实现任意网络地址到任意物理地址的转换,这里仅讨论IP地址到以太网地址(MAC地址)的转换.其工作原理是:主机向自己所在网络广播一个ARP请求,该请求包含目标机器的网络地址.此网络上的其他机器都将接收到这个请求,但只有被请求的目标机器会回应一个ARP应答,其中包含自己的物理地址. 以太网ARP请求/应答报文 以太网ARP请求/应答报文格式如下

TCP/IP协议族——IP工作原理及实例详解(上)

 IP协议详解 本文主要介绍了IP服务特点,头部结构,IP分片知识,并用tcpdump抓取数据包,来观察IP数据报传送过程中IP的格式,以及分片的过程. IP头部信息:IP头部信息出现在每个IP数据报中,用于指定IP通信的源端IP地址.目的端IP地址,知道IP分片和重组. IP数据报的路由和转发:IP数据报的路由和转发发生在出目标机器之外的所有主机和路由器上.他们决定数据报是否应该转发以及如何转发. IP服务的特点 IP协议是TCP/IP协议族的动力,它为上层协议提供无状态.无连接.不可靠的

TCP/IP协议族——IP工作原理及实例具体解释(上)

?? IP协议具体解释 本文主要介绍了IP服务特点,头部结构,IP分片知识,并用tcpdump抓取数据包.来观察IP数据报传送过程中IP的格式,以及分片的过程. IP头部信息:IP头部信息出如今每一个IP数据报中,用于指定IP通信的源端IP地址.目的端IP地址,指导IP分片和重组. IP数据报的路由和转发:IP数据报的路由和转发发生在出目标机器之外的全部主机和路由器上.他们决定数据报是否应该转发以及怎样转发. IP服务的特点 IP协议是TCP/IP协议族的动力.它为上层协议提供无状态.无连接.不

TCP/IP协议中分包与重组原理介绍

[原文链接] 引言 分片是分组交换的思想体现,也是IP协议解决的两个主要问题之一.在IP协议中的分片算法主要解决不同物理网络最大传输单元(MTU) 的不同造成的传输问题.但是分组在传输过程中不断地分片和重组会带来很大的工作量还会增加一些不安全的因素.我们将在这篇小论文中讨论IP分片的原因.原理.实现以及引起的安全问题. 一.什么是IP分片 IP分片是网络上传输IP报文的一种技术手段.IP协议在传输数据包时,将数据报文分为若干分片进行传输,并在目标系统中进行重组.这一过程称为分片(fragment

TCP/IP协议原理与应用笔记17:IP编址之 IP地址简介(重点)

1. IP地址(通用标识符) 对于同一个网络设备(主机或路由器)的不同网络连接,需要不同的IP地址进行标识 2. 主机标识符 主要有下面三种方式的主机标识方式: (1)Name:是什么,可读性强(了解主机的属性或者用途) (2)Address:在哪里,软件效率高. (3)Route(路由的标识):怎样到达 3. IP地址结构 (1)32 bit二进制地址 它模拟物理网的编址机制,如下示意图: (2)IP地址分类,如下: TCP/IP协议原理与应用笔记03:IP地址分类

TCP/IP协议原理学习笔记

昨天学习了杨宁老师的TCP/IP协议原理第一讲和第二讲,主要介绍了OSI模型,整理如下: OSI是open system innerconnection的简称,即开放式系统互联参考模型,它把网络协议从逻辑上分为了7层.即如上图所示: 1.物理层:主要定义物理设备标准,如网线的接口类型.光纤的接口类型.各种传输介质的传输速率等.它的主要作用是传输比特流(就是由1.0转化为电流强弱来进行传输,到达目的地后在转化为1.0,也就是我们常说的数模转换与模数转换).这一层的数据叫做比特. 2.数据链路层:定

TCP/IP协议原理与介绍

一.什么是TCP/IP? 顾名思义 TCP/IP(Transmission Control Protocol/Internet Protocol),传输控制协议/网际协议,TCP/IP是现代Internet的核心技术,由IETF定义.所有的系统.终端.线路.用户.开发者,都必须遵守TCP/IP协议族所规定的法则!IP世界的根本法就是TCP/IP协议族.这里我又扯到协议族了,就像快乐家族,不仅仅我们很熟悉的何炅.谢娜.不仅包括主持人,还有导演.摄像等等其他工作人员.TCP/IP也就像一个组,协议族

TCP/IP协议原理与应用笔记05:网关

      大家都知道,从一个房间走到另一个房间,必然要经过一扇门.同样,从一个网络向另一个网络发送信息,也必须经过一道“关口”,这道关口就是网关.顾名思义,网关(Gateway)就是一个网络连接到另一个网络的"关口".      按照不同的分类标准,网关也有很多种.TCP/IP协议里的网关是最常用的,在这里我们所讲的“网关”均指TCP/IP协议下的网关.  那么网关到底是什么呢?网关实质上是一个网络通向其他网络的IP地址. 比如有网络A和网络B,网络A的IP地址范围为"19