理解网络协议

1.查看网络配置 : ipconfig

2. ip地址 : ipv4(4字节, 32bit), ipv6, 用来标识主机的网络地址

3.端口号(0~65535) : 用来标识主机上的某个进程, 1 ~ 1024 知名端口号, 如果是服务端的话需要提供一个特定的端口号, 客户端的话是随机分配一个端口号

4.协议 : 简单来说就是接收数据和发送数据的双方做好的约定, 如发送时如何组织数据, 接收时如何解析数据

5.网络中的五元组 : 源IP地址, 源端口号, 目的IP地址, 目的端口号, 协议

6.协议分层 :

(1) OSI七层模型(简单了解就行)

(2) TCP/IP五层模型 :

应用层 : 和用户打交道, 接收和展示用户的数据

传输层 : 完成端到端的传输准备, 端口号

网络层 : 规划出最合适的网络传输路径, ip

数据链路层 : 根据网络层的IP地址, 来提供两个网络设备之间的通信功能

物理层 : 把真实的BIT数据流, 通过转化成光电信号在传输介质中传输 (网络:电信号, 光纤:光信号)

7. 封装和分用

封装是在发送方进行的对数据的处理

分用时在接收方进行的对数据的处理

发送方 :

(1)应用层 : 按照程序员自定义的协议组织数据, 主要确定消息体的内容, 然后调用系统提供的 API (socket api)进行发送操作, 将消息的处理方移交给下一层

(2)传输层 : (传输层众多协议中最典型的两种: TCP, UDP), 主要是确定源端口号和目的端口号

(3)网络层 : 规划出端到端的网络路径, 主要确定源IP地址和目的IP地址 , IP协议

(4)数据链路层 : 加入帧头和帧尾之后, 把数据以二进制的形式发送给物理层, 帧头有MAC地址(写死在网卡中, 出厂时就确定下来了), 帧尾有CRC(校验和, 发送方通过某种算法对载荷进行运算, 保存起来, 接收方在收到数据之后, 取出载荷以相同的算法进行运算, 如果得到的结果与校验和相同, 就表示接收到的载荷与发送的载荷一致, 否则载荷是无效的)

(5)物理层 : 根据以太网协议把具体的数据(报文)转化成光电信号, 通过传输介质进行传输

接收方 :

(6)物理层 : 接收到光电号之后, 根据以太网协议把信号转化为二进制

(7)数据链路层 : 解析出帧头, 载荷, 帧尾, 将帧头, 帧尾去掉, 把载荷交给上一层

(8)网络层 : 根据IP协议解析报文件, 取出载荷交给上一层

(9)传输层 : 根据TCP协议解析报文件, 取出载荷交给上一层

(10)应用层 : 按照程序员自定义的协议解析消息体

发送方的数据从应用层到物理层的过程叫应用的封装

接收方的数据从物理层到应用层的过程叫应用的分用

相关推荐
sunfove2 小时前
光网络的立交桥:光开关 (Optical Switch) 原理与主流技术解析
网络
Kevin Wang7275 小时前
欧拉系统服务部署注意事项
网络·windows
min1811234565 小时前
深度伪造内容的检测与溯源技术
大数据·网络·人工智能
汤愈韬5 小时前
NAT策略
网络协议·网络安全·security·huawei
汤愈韬5 小时前
Full Cone Nat
网络·网络协议·网络安全·security·huawei
zbtlink5 小时前
现在还需要带电池的路由器吗?是用来干嘛的?
网络·智能路由器
桌面运维家6 小时前
vDisk配置漂移怎么办?VOI/IDV架构故障快速修复
网络·架构
dalerkd6 小时前
忙里偷闲叙-谈谈最近两年
网络·安全·web安全
汤愈韬6 小时前
NAT ALG (应用层网关)
网络·网络协议·网络安全·security·huawei
运维栈记8 小时前
虚拟化网络的根基-网络命名空间
网络·docker·容器