概述
目录
一、网口基础
OSI 7层模型
TCP/IP 4层模型
二、网口协议
UDP/TCP协议
(1)UDP协议
(2)TCP协议
IP协议
以太网协议
APR&RARP协议
一、网口基础
常见的网口传输模型有 OSI 7层模型与TCP/IP 4层模型,下面分别对这两种模型进行介绍
OSI 7层模型
OSI 7层模型:
(1)物理层
物理层的主要功能是:利用传输介质为数据链路层提供物理连接,实现比特流的透明传输。使其上面的数据链路层不必考虑网络的具体传输介质是什么。
(2)数据链路层
数据链路层的具体工作是接收来自物理层的位流形式的数据,并封装成帧,传送到上一层;同样,也将来自上层的数据帧,拆装为位流形式的数据转发到物理层;并且,还负责处理接收端发回的确认帧的信息,以便提供可靠的数据传输。
(3)网络层
数据链路层的数据在这一层被转换为数据包,然后通过路径选择、分段组合、顺序、进/出路由等控制,将信息从一个网络设备传送到另一个网络设备。
(4)传输层
该层的主要任务是:向用户提供可靠的端到端的差错和流量控制,保证报文的正确传输。传输层的作用是向高层屏蔽下层数据通信的细节,即向用户透明地传送报文。
(5)会话层
会话层的任务就是组织和协调两个会话进程之间的通信,并对数据交换进行管理。
(6)表示层
其主要功能是“处理用户信息的表示问题,如编码、数据格式转换和加密解密”等。
(7)应用层
它是计算机用户,以及各种应用程序和网络之间的接口,其功能是直接向用户提供服务,完成用户希望在网络上完成的各种工作。
OSI7层模型的小结
由于OSI是一个理想的模型,因此一般网络系统只涉及其中的几层,很少有系统能够具有所有的7层,并完全遵循它的规定。
在7层模型中,每一层都提供一个特殊的网络功能。从网络功能的角度观察:下面4层(物理层、数据链路层、网络层和传输层)主要提供数据传输和交换功能,即以节点到节点之间的通信为主;第4层作为上下两部分的桥梁,是整个网络体系结构中最关键的部分;而上3层(会话层、表示层和应用层)则以提供用户与应用程序之间的信息和数据处理功能为主。简言之,下4层主要完成通信子网的功能,上3层主要完成资源子网的功能。
TCP/IP 4层模型
TCP/IP4层模型:
(1)网络接入层
包括用于协作IP数据在已有网络介质上传输的协议。实际上TCP/IP标准并不定义与ISO数据链路层和物理层相对应的功能。相反,它定义像地址解析协议(Address Resolution Protocol,ARP)这样的协议,提供TCP/IP协议的数据结构和实际物理硬件之间的接口。
(2)网络层
本层包含IP协议、RIP协议(Routing Information Protocol,路由信息协议),负责数据的包装、寻址和路由。同时还包含网间控制报文协议(Internet Control Message Protocol,ICMP)用来提供网络诊断信息。
(3)传输层
对应于OSI七层参考模型的传输层,它提供两种端到端的通信服务。其中TCP协议(Transmission Control Protocol)提供可靠的数据流运输服务,UDP协议(Use Datagram Protocol)提供不可靠的用户数据报服务。
(4)应用层
对应于OSI七层参考模型的应用层和表达层。因特网的应用层协议包括Finger、Whois、FTP(文件传输协议)、Gopher、HTTP(超文本传输协议)、Telent(远程终端协议)、SMTP(简单邮件传送协议)、IRC(因特网中继会话)、NNTP(网络新闻传输协议)等
TCP/IP 4层模型的小结
一般我们实际使用的模型为TCP/IP模型,它的协议包含下面3个:
传输层:UDP协议(选择)/TCP协议(更加复杂:三次握手+四次挥手)
网络层:IP协议
数据链路层:以太网协议
用户之间的传输是“透明的”(对用户不可见),实际上传输是用户层数据向下传输,经过传输层添加UDP头/TCP头;经过网络层添加IP头;经过数据链路层添加MAC头和校验;发送到物理层;再经过路由器(只有网络层+数据链路层+物理层)的接收与转发,到达另一个用户的物理层。
另一个用户的数据链路层去掉数据的MAC头和校验,发送到网络层,网络层去掉IP头,发送到传输层,传输层去掉UDP头/TCP头,发送到用户层,完成数据的传输。
二、网口协议
UDP/TCP协议
(1)UDP协议
source port 源端口、destination port目的端口:是应用的标识,各16bit
length :UDP包长度,16bit
checksum:校验(可以不做全0)16bit
(2)TCP协议
通信开始:三次握手
通信结束:四次挥手
第一次握手:建立连接时,客户端申请开始,等待服务器确认;
第二次握手:当服务端收到来自客户端请求连接的报文后,发送同意应答到客户端
第三次握手:当客户端收到连接同意的应答后,还要向服务端发送一个确认报文段,表示:服务端发来的连接同意应答已经成功收到。
第一次挥手:客户端向服务器发送申请结束
第二次挥手:服务器向客户端发送应答
第三次挥手:服务器向客户端发送申请结束
第四次挥手:客户端向服务器发送应答
UDP与TCP的区别:
通过 TCP 连接传输的数据无差错,不丢失,不重复,有错误校验,TCP 报文头里面的序号能使 TCP 的数据按序到达;报文头里面的确认序号能保证不丢包;TCP 拥有流量控制及拥塞控制的机制。
UDP主要应用在需要资源少,网络情况稳定的内网,或者对于丢包不敏感的应用。它不面向连接,所以可以做到一对多,承担广播或者多播的协议。应用于需要处理速度快,可以容忍丢包的场景(直播,实时游戏,互联网)
IP协议
IP头分为IPV4和IPV6,它们的地址数量不同,IPV4协议的地址为32位,所以可以提供的地址数为2^32-1;IPV6则是2^128-1,一般IPV4已经够用
version:版本0100表示IPv4,如果为0110表示IPv6(4bit)
IHL:头部长度(可变)4字节为单位,没有options为5(4bit)
type of service:服务类型(8bit)
total length:整个IP包的长度(16bit)
identification:包的ID号(16bit)
flags:IP包是否有分割(3bit)
fragment offset:在什么地方切割(13bit)
time to live:IP包生命周期(8bit)
表示该IP数据包可以经过的路由器的最大数量。最大为256表示可以穿越256台路由,该字段采用减法的方式赋值,比如在开始时8个bit全部置位1,没经过一台路由器该字段的值减1。如果该字段的值减到了0还没有送达目的地,那么该IP数据包将被丢弃。最初设计这个字段是为了防止IP报文在网络中循环无限传输,占用带宽等问题。
protocol:协议字段0x01表示ICMP协议、0x06表示TCP协议、0x11表示UDP协议(8bit)
header checksum:首部校验和
用来使接收端检验收到的报文是否正确。计算方法:首先把首部中的该字段全部置0,然后对首部中的每个16bit进行反码求和,得到的值就是该字段的值,填入后。将该数据包发给接收端后,接收端将进行相同的操作,对每个16bit进行反码求和(此时首部校验和字段为非0字段),所以计算后的值若为全1表示正确,否则表示收到的数据包不正确,动作为丢弃。
source IP address: IP首地址(32bit)xxxx. xxxx. xxxx. xxxx
destination IP address: IP末地址(32bit)
以太网协议
以太网帧是在链路层,链路层的主要职能是检错和校验,以太网帧格式如下:
前导码:55h (7byte)
帧前定界符:D5h (1byte)
destination address:目的MAC地址 (6byte)
source address:源MAC地址 (6byte)
以太网的MAC帧:固定为0800H(2byte)
DATA:上层协议封装的数据(46~1500byte)
帧校验序列(FCS) (4byte)
总的的数据封装如下:
7byte 前导码+1byte帧前定界符+14byte以太网帧头+20byte IP头+8byte UDP头+数据+4byte FCS校验
APR&RARP协议
IP地址与MAC地址的互相获得需要依靠ARP协议和RARP协议
(1)ARP协议
在以太网协议规定中,同一局域网中的一台主机要和另一台主机进行直接通信,必须知道目标主机的MAC地址(硬件地址)。而在TCP/IP协议中,网络层和传输层只关心目标主机的IP地址。这就导致在以太网中使用IP协议时,数据链路层的以太网协议接到上层IP协议提供的数据中,只包含目的主机的IP地址。
ARP是一种地址解析协议,是一个位于数据链路层的协议,主要负责将IP地址解析为对应的MAC地址。ARP协议只适用于局域网。另外,当发送主机和目的主机不在同一个局域网中时,即使知道目的主机的MAC地址,两者也不能直接通信,必须经过路由转发才可以。所以此时,发生主机通过ARP协议获得的将不是目的主机的真实MAC地址,而是一台可以通往局域网外的路由器的MAC地址。于是此后发送主机发送到目的主机的所有帧,都将发往该路由器,通过它向外发送。这种情况成为ARP代理。
(2)RARP协议
ARP协议是根据IP地址找其对用的MAC地址,而RARP则是根据MAC地址找其对应的IP地址,所以称为“逆向ARP”。具有本地磁盘的系统引导时,一般是从磁盘上的配置文件中读取IP地址,然后即可直接用ARP协议找出与其对应的主机MAC地址。但是无盘机,如X终端或无盘工作站,启动时是通过MAC地址来寻址的,这时就需要通过RARP协议获取IP地址。
最后
以上就是安静微笑为你收集整理的FPGA网口实现与详解(1)一、网口基础二、网口协议的全部内容,希望文章能够帮你解决FPGA网口实现与详解(1)一、网口基础二、网口协议所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复