网络体系结构 和网络原理之UDP和TCP

目录

网络分层 

一. 应用层 

http协议

二. 传输层

1. 介绍 

2.UDP协议

 (1)组成

(2)细节 

3.TCP协议 

(1)特性如下链接:

(2)组成 

(3)特点 

三. 网络层

四. 数据链路层

1.介绍

2.以太网协议

 3.mac地址和ip地址

五. 物理层

DNS


网络分层 

一. 应用层 

应用程序

现成的应用层协议有超文本协议http(不仅仅有文本).

http协议

http://t.csdnimg.cn/e0e8kicon-default.png?t=N7T8http://t.csdnimg.cn/e0e8k

自定义应用层协议,包含需要传输的信息以及格式,将信息转为字符串放入TCP或者UDP的socket中。常见传输格式xml,最流行的是json,但json仍然有网络带宽的消耗,protobuffer是将信息压缩为二进制,带宽消耗较小。

DNS介绍在最下面

二. 传输层

1. 介绍 

关注起点和终点

主要有TCP和UDP :

TCP:有连接,可靠传输,面向字节流,全双工。适用于需要确保数据完整性和顺序的场景。eg:文件传输,状态更新。

UDP:无连接,不可靠传输,面向数据报,全双工,接收缓冲区。适用于高速传输和对实时性要求较高的应用。


传输层一个重要概念:端口号

固定占2个字节,

表示范围0~65535(2^16-1),

0一般不用,1~1023是知名端口号,如80是http的端口号22是ssh的端口号(登录远程主机)

2.UDP协议

 (1)组成

UDP的首部长度固定为8个字节(64位)64k。它由源端口号、目标端口号、长度和校验和组成。每个字段都占用2个字节。

  1. 源端口号(Source Port):占用2个字节,表示发送方使用的端口号。
  2. 目标端口号(Destination Port):占用2个字节,表示接收方使用的端口号。
  3. 长度(Length):占用2个字节,表示UDP首部和数据的总长度,包括8字节的UDP首部和数据部分的长度。
  4. 校验和(Checksum):占用2个字节,用于检测UDP首部和数据在传输过程中是否发生错误。

UDP的简洁首部长度是其相对于TCP更轻量级的一个特点,但也意味着它没有TCP那样的可靠性保证和流量控制机制。因此,在使用UDP时需要注意数据的可靠性和完整性问题,并根据具体应用场景决定是否需要额外的机制来处理这些问题。

(2)细节 

✅1.当udp数据报携带信息过大,导致服务器与客户端交互的数据量接近64kb,超过上限会导致数据阶段,数据出错,解决办法:

1.将数据拆分为多个包,使用多个UDP传输()如何去拆包组包,开发测试成本大。

2.使用TCP,无包大小的限制(

3.升级UDP,比较麻烦。()UDP是在操作系统内核实现的.


✅2.网络传输中数据是有可能出错的,如何基于校验和来完成数据校验呢?


1.发送方,把要发送的数据整理好(称为 data1),通过一定的算法, 计算出校验和 checksum1发送方把 data1 和 checksum1 -起通过网络发送出去.
2.接收方收到数据,收到的数据称为 data2 (数据可能和 data1 就不一样了),收到数据 checksum1
3.接收方再根据 data2 重新计算校验和(按照相同的算法),得到 checksum2
4.对比 checksum1 和 checksum2 是否相同.如果不同,则认为 data2 和 data1 一定不相同如 5.checksum1 和 checksum2 相, 则认为 data1 和 data2 大概率是相同的 理论上存在不同的可能性。


✅3.在UDP中使用循环冗余校验(CRC):把需要进行校验和的数据的每个字节逐个累加,把结果保存在两个字节的变量中,累加过程溢出也没事。如果中间出现数据错误,第二次的校验和就和第一次不也一样。

更严谨的是md5,MD5进行了定长,分散(一个字节不同差异也很大),不可逆。MD5也适合作为hash算法(哈希表是把一个key通过hash函数转换为数组下标,hash函数尽量分散,哈希碰撞的可能从才能降低),


✅4.UDP特点:寄信

UDP进行网络通信可以通过java.net包下的DatagramSocketDatagramPacket类来实现

无连接:知道对方ip和端口号即可连接,

不可靠:发送端发送数据报后,如果因为网络问题并没有到接收方,UDP协议也不会给应用层返回任何错误信息。  

全双工:可以通过一个socket进行send和reseive,既能读也能写,即全双工;

缓冲区:UDP只有接收缓冲区,没有发送缓冲区。

UDP发送的数据会直接发送给内核,由内核将数据传给网络层协议进行后续传输动作;UDP具有接收缓冲区,这个缓冲区不能保证受到道德UDP报的顺序与发送UDP报的顺序一致;缓冲区满,再到达的UDP报就会被 丢弃。

大小受限:UDP协议首部有一个16位的最大长度,2个字节,也就是UDP能传输的最大长度是64KB(包含UDP首部)

面向数据报:以DataGaramSocket为单位传输

DatagramPacket sendPacket = new DatagramPacket(sendData, sendData.length, receiverAddress, receiverPort);

UDP是一种面向数据报的无连接协议,因此发送方和接收方之间不存在建立连接的过程,也没有可靠性保证。每个UDP数据报都是独立的,可能会丢失、重复或乱序。实际使用中可能需要考虑超时重传,分片传。

import java.net.DatagramSocket;
import java.net.DatagramPacket;
import java.net.InetAddress;

public class UDPExample {
    public static void main(String[] args) {
        try {
            // 创建发送方的UDP socket
            DatagramSocket senderSocket = new DatagramSocket();

            // 准备要发送的数据
            String message = "Hello, UDP!";
            byte[] sendData = message.getBytes();
            InetAddress receiverAddress = InetAddress.getByName("127.0.0.1"); // 接收方的IP地址
            int receiverPort = 12345; // 接收方的端口号

            // 创建要发送的数据报文
            DatagramPacket sendPacket = new DatagramPacket(sendData, sendData.length, receiverAddress, receiverPort);

            // 发送数据报文
            senderSocket.send(sendPacket);

            // 创建接收方的UDP socket
            DatagramSocket receiverSocket = new DatagramSocket(receiverPort);

            // 准备接收数据的缓冲区
            byte[] receiveData = new byte[1024];

            // 创建接收数据的数据报文
            DatagramPacket receivePacket = new DatagramPacket(receiveData, receiveData.length);

            // 接收数据报文
            receiverSocket.receive(receivePacket);

            // 解析接收到的数据
            String receivedMessage = new String(receivePacket.getData());
            System.out.println("Received message: " + receivedMessage);

            // 关闭socket
            senderSocket.close();
            receiverSocket.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

5.UDP无连接不可靠面向数据报的协议如果要基于传输层UDP协议来实现可靠传输应该如何设计?大小有限制,如果要基于传输层UDP协议,传输超过64k的数据,如何设计?

参考TCP可靠性的实现

5.2+5.1分片重组+序列化保证顺序;5.1确认应答;超时重传;滑动窗口控制流量,校验和.......


简单了解基于UDP的应用层协议
NFS: 网络文件系统
TFTP:简单文件传输协议
DHCP:动态主机配置协议
BOOTP:启动协议 (用于无盘设备启动)
·DNS: 域名解析协议

3.TCP协议 

(1)特性如下链接:

 http://t.csdnimg.cn/NHMHb

(2)组成 

 初心:可靠传输~

数据报=首部(报头)+载荷;一行4个字节

报头长度是不固定的,选项也是报头的一部分,TCP报头包括固定部分和可选部分。固定部分的长度是20个字节(160位),包括源端口号、目标端口号、序列号、确认号、数据偏移、控制位、窗口大小、校验和和紧急指针等字

报头最短是20个字节(没有选项),最长是60个字节(选项最多是40字节);

保留位(6位):有需要就用。比udp的64kb好。扩展余地。

TCP首部长度字段占用4个位(即4个二进制位也就是4个字节,32个比特位),它使用4位来表示长度。由于4位最多能表示16个不同的取值(从0000到1111),因此TCP首部长度字段的取值范围是0-15,表示TCP首部的长度是以32位(此处设定4字节,所以有4倍的设定关系)为单位的倍数。也就是说,长度值乘以4才得到TCP首部的实际长度。当TCP首部长度字段取值为5时,长度为5 * 4 = 20字节,即TCP首部固定部分的长度。

TCP协议的组成主要包括以下部分:

  1. 源端口号(Source Port):占用2个字节,表示发送方使用的端口号。
  2. 目标端口号(Destination Port):占用2个字节,表示接收方使用的端口号。
  3. 序列号(Sequence Number):占用4个字节,表示本次传输的第一个字节的序列号。
  4. 确认号(Acknowledgment Number):占用4个字节,表示期望接收到的下一个字节的序列号。
  5. 数据偏移(Data Offset):占用4个位,表示TCP首部长度,单位为4字节,因此TCP首部长度最大值为60字节。
  6. 保留位(Reserved):占用6个位,保留未来使用,必须设置为0。
  7. 控制位(Flags):占用6个位,包含ACK、SYN、FIN等标志位,用于控制TCP连接的建立、维护和关闭。其中ack为1,表示它表示应答报文,ack为0表示普通报文。SYN为。
  8. 窗口大小(Window Size):占用2个字节,表示接收窗口的缓冲区大小,用于流量控制。
  9. 检验和(Checksum):占用2个字节,用于检测TCP首部和数据在传输过程中是否发生错误。
  10. 紧急指针(Urgent Pointer):占用2个字节,表示紧急数据的位置,用于处理紧急数据。

(3)特点 

有连接

 Socket clientSocket = serverSocket.accept();
accept方法会阻塞当前线程直到有客户端连接请求到达并被接受
记得抛出异常防止网络故障类问题

可靠传输+面向字节流+全双工(既可以读也可以写)

 // 获取输入输出流
BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);

💡TCP的可靠不在于它是否可以把数据100%传输过去,而是

  • 1.发送方发去数据后,可以知道接收方是否收到数据;
  • 2.如果接收方没收到,可以有补救手段;

三. 网络层

关注路径规划,很多路径到底如何走?

地址管理:制定一系列规则,通过地址,描述出网络中一个地址的位置。

路由选择:ip数据报在网络中的转发。

IP协议链接如下:http://t.csdnimg.cn/53Pts

四. 数据链路层

1.介绍

关注路径中节点的连接,相邻节点之间如何转发?

数据链路层的作用是在两个相邻节点之间提供可靠的数据传输服务,

2.以太网协议

(1)以太网协议就是一种常见的数据链路层协议(通过光纤,网线来通信使用的协议,以太网协议)。横跨数据链路层和物理层。

(2)组成:类型描述载荷数据是什莫类型;

MTU(Maximum Transmission Unit):数据链路层数据包能携带的最大载荷长度。在以太网上传输的数据包大小不能超过1500个字节。会想起ip数据报的拆包组包,很可能是因为mtu而不是64kb的上限。不同的数据链路层协议的MTU是不一样的,也和物理层介质有关。

下面的两种

这里的6个字节目的地址(2^48)和源地址指的是mac地址。

.mac地址采用16进制表示,两个十六进制数字就是1个字节。(4个二进制位数字是一个字节表示0~15的数值)

 物理地址. . . . . . . . . . . . . : C4-75-AB-5C-9B-BB

在交换机中遇到 以太网数据帧 的时候,就需要进行转发,转发过程就需要根据mac地址判定数据从哪个网口转发。    转发表主要就通过arp协议生成 。

 3.mac地址和ip地址

ip协议立足于全局,关注整个网络通信过程的路径规划。

mac地址,以太网协议关注相邻两个设备之间的通信过程。

eg:我从西安到北京,源ip:西安,目的ip:北京;源mac:可能西安,目的mac:可能河北;

每次到达一个节点,源mac和目的mac都会改变

sum:

1. 网络拓扑结构:以太网规定了常见的拓扑结构,如总线型、星型、环型等,并规定了各种拓扑结构下的连接方式和限制条件。

2. 访问控制方式:以太网使用CSMA/CD(载波监听多点接入/碰撞检测)协议来控制节点对共享媒体的访问,以避免碰撞和冲突。

3. 传输速率:以太网支持多种传输速率,如10Mbps、100Mbps、1Gbps等,其中10Mbps和100Mbps是最常见的。

4. 以太网帧格式:以太网规定了数据在网络上的传输格式,也就是以太网帧格式。它包含了目的MAC地址、源MAC地址、类型/长度字段和数据字段等。

5. MAC地址:MAC地址是一个48位的硬件地址,用于唯一标识网络上的每个设备。以太网使用MAC地址来进行帧的寻址和传输。

6. ARP协议:ARP(地址解析协议)用于将IP地址转换为MAC地址。当一个设备需要与另一个设备进行通信时,它需要知道目标设备的MAC地址,而ARP协议就是用来解决这个问题的。

7. MTU:MTU(最大传输单元)指的是数据链路层能够承载的最大数据包大小。以太网规定了不同传输速率下的MTU大小,例如在10Mbps上,MTU为1500字节。

五. 物理层

关注设备

DNS

DNS是应用层协议,也是一套域名解析系统。它使得域名能够被解析为对应的IP地址,并提供了其他与域名相关的信息,比如 www.baidu.com,baidu就是域名,可以把域名和ip地址想象成键值对结构。

最早的域名解析系统就是hosts文件:这些都需要手写来维护

于是出现专属dns服务器,给dns服务器发起请求,查询当前域名对应IP,然后再访问目标网站。但是这样会面临高并发的情况。面对高并发,我们有开源节流方案:

节流:减少请求量,让每个上网的设备搞本地缓存

开源:号召网络运营商搞更多的DNS镜像服务器;用户就可以访问离自己最近的镜像        DNS服务器。

ipv6的DNS与ipv4截然不同。ipv6升级有意义!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/357476.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

dfs专题 P1255 数楼梯——洛谷(疑问)

题目描述 楼梯有 �N 阶,上楼可以一步上一阶,也可以一步上二阶。 编一个程序,计算共有多少种不同的走法。 输入格式 一个数字,楼梯数。 输出格式 输出走的方式总数。 输入输出样例 输入 #1复制 4 输出 #1复制…

【Python】Win11用GTK3实现多文档窗体弹出对话框

一、安装PyGObject PyGObject是GTK的Python绑定,用于Python中的GTK3程序。可以使用pacman命令来安装PyGObject、GTK3和其他必要的库。 1. 打开MSYS2终端: 可以直接通过MSYS2的快捷方式打开终端或者从开始菜单中找到MSYS2。 2. 更新MSYS2包管理器&…

回显服务器(基于UDP)

目录 基本概念 API学习 DatagramSocket DatagramPacket InetSocketAddress 回显服务器实现 服务端 思路分析 具体实现 完整代码 客户端 思路分析 具体实现 完整代码 运行测试 基本概念 发送端和接收端 在一次网络数据传输时: 发送端:…

Linux中的软链接与硬链接

Linux链接概念 Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。默认情况下,使用 ln 命令不加参数创建硬链接,加 -s 参数则创建软链接 硬链接…

2024不可不会的StableDiffusion之扩散模型(四)

1. 引言 这是我关于StableDiffusion学习系列的第四篇文章,如果之前的文章你还没有阅读,强烈推荐大家翻看前篇内容。在本文中,我们将学习构成StableDiffusion的第三个基础组件基于Unet的扩散模型,并针该组件的功能进行详细的阐述。…

RK3568平台开发系列讲解(Linux系统篇)platform 设备的注册

🚀返回专栏总目录 文章目录 一、platform_device_register 注册函数二、platform_device_unregister 反注册函数三、platform_device 结构体四、resource 结构体沉淀、分享、成长,让自己和他人都能有所收获!😄 一、platform_device_register 注册函数 platform_device_re…

海外云手机运营Instagram攻略

Instagram是世界著名的社交媒体平台,有着10亿实时用户,是跨境电子商务的优质流量来源。平台以女性用户为主,购物倾向高,转化率好。它被公认为外贸行业的优质社交媒体流量池。那么,如何使用海外云手机吸引Instagram上的…

【论文阅读】Long-Tailed Recognition via Weight Balancing(CVPR2022)

目录 论文使用方法weight decayMaxNorm 如果使用原来的代码报错的可以看下面这个 论文 问题:真实世界中普遍存在长尾识别问题,朴素训练产生的模型在更高准确率方面偏向于普通类,导致稀有的类别准确率偏低。 key:解决LTR的关键是平衡各方面&a…

力扣题集(第一弹)

一日练,一日功;一日不练十日空。 学编程离不开刷题,接下来让我们来看几个力扣上的题目。 1. 242. 有效的字母异位词 题目描述 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。 注意:若 s 和 t 中每个字符出现的次数…

JS图片二维码识别

前言 js识别QR图片&#xff0c;基于jsQR.js 代码 <!DOCTYPE html> <html> <head><meta charset"utf-8" /><title>图片二维码识别</title><script src"https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js">…

什么是消息队列?

消息用队列的模式发送&#xff0c; 把要传输的数据放在队列中&#xff0c; 产生消息的叫做生产者&#xff0c; 从队列里取出消息的叫做消费者。 一、组成 生产者&#xff1a;Producer 消息的产生者与调用端 主要负责消息所承载的业务信息的实例化 是一个队列的发起方 代理…

网站小程序分类目录网源码系统+会员注册登录功能 附带完整的搭建教程

随着互联网的发展&#xff0c;小程序分类目录网站已经成为了人们获取各类信息的重要渠道。而在这个领域中&#xff0c;罗峰给大家分享一款网站小程序分类目录网源码系统以其强大的功能和易用性&#xff0c;脱颖而出。本系统集成了会员注册登录功能&#xff0c;让用户能够更加便…

uniapp H5 实现上拉刷新 以及 下拉加载

uniapp H5 实现上拉刷新 以及 下拉加载 1. 先上图 下拉加载 2. 上代码 <script>import DragableList from "/components/dragable-list/dragable-list.vue";import {FridApi} from /api/warn.jsexport default {data() {return {tableList: [],loadingHi…

Redis核心技术与实战【学习笔记】 - 6.Redis 的统计操作处理

1.前言 在 Web 业务场景中&#xff0c;我们经常保存这样一种信息&#xff1a;一个 key 对应了一个数据集合。比如&#xff1a; 手机 APP 中的每天用户登录信息&#xff1a;一天对应一系列用户 ID。电商网站上商品的用户评论列表&#xff1a;一个商品对应了一些列的评论。用户…

12 数据仓库理论

数仓基本概述 数据仓库基本概念 数据仓库是一个为数据分析而设计的企业级数据管理系统。数据仓库可集中 、整合多个信息源的大量数据。 数仓核心架构 数据仓库建模概述 数据仓库建模意义 数据模型就是数据组织和存储方法&#xff0c;它强调从业务、数据存取和使用角度合理…

Django配置websocket时的错误解决

基于移动群智感知的网络图谱构建系统需要手机app不断上传数据到服务器并把数据推到前端标记在百度地图上&#xff0c;由于众多手机向同一服务器发送数据&#xff0c;如果使用长轮询&#xff0c;则实时性差、延迟高且服务器的负载过大&#xff0c;而使用websocket则有更好的性能…

链表与二叉树-数据结构

链表与二叉树-数据结构 创建叶子node节点建立二叉树三元组&#xff1a;只考虑稀疏矩阵中非0的元素&#xff0c;并且存储到一个类&#xff08;三元组&#xff09;的数组中。 创建叶子node节点 class Node{int no;Node next;public Node(int no){this.nono;} } public class Lb…

YOLOv8改进 | 可视化热力图 | 支持YOLOv8最新版本密度热力图,和视频热力图

一、本文介绍 本文给大家带来的机制是集成了YOLOv8最新版本的可视化热力图功能,热力图作为我们论文当中的必备一环,可以展示出我们呈现机制的有效性,本文的内容支持YOLOv8最新版本的根据密度呈现的热力图,同时支持视频检测,根据视频中的密度来绘画热力图。 在开始之前给…

薅运营商羊毛?封杀!

最近边小缘在蓝点网上看到一则消息 “浙江联通也开始严格排查PCDN和PT等大流量行为 被检测到可能会封停宽带”。 此前中国联通已经在四川和上海等多个省市严查家庭宽带 (部分企业宽带也被查) 使用 PCDN 或 PT&#xff0c;当用户的宽带账户存在大量上传数据的情况&#xff0c;中…

数据库管理-第141期 DG PDB - Oracle DB 23c(20240129)

数据库管理141期 2024-01-29 第141期 DG PDB - Oracle DB 23c&#xff08;20240129&#xff09;1 概念2 环境说明3 操作3.1 数据库配置3.2 配置tnsname3.3 配置强制日志3.4 DG配置3.5 DG配置建立联系3.6 启用所有DG配置3.7 启用DG PDB3.8 创建源PDB的DG配置3.9 拷贝pdbprod1文件…
最新文章