趣谈网络协议---UDP协议:因性善而简单,难免碰到“城会玩”

本文深入解析TCP和UDP的区别,包括面向连接与无连接的特点,可靠交付、拥塞控制及UDP的资源消耗、广播能力和速度优势。同时,列举了UDP在内网资源、广播需求和速度敏感场景中的五大应用案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TCP 和 UDP 有哪些区别?
TCP是面向连接的,UDP是面向无连接的。

所谓的建立连接,是为了在客户端和服务端维护连接,而建立一定的数据结构来维护双方交互的状态,用这样的数据结构来保证所谓的面向连接的特性。

例如:

  • TCP提供可靠交付。通过TCP连接传输的数据,无差错、不丢失、不重复、并且按序到达。
  • TCP是面向字节流的。UDP是基于数据报的。
  • TCP是可以有拥塞控制的。
  • TCP是一个有状态服务。

UDP 包头是什么样的?
在这里插入图片描述

UDP三大使用场景
1、需要的资源少,网络比较好的内网,或对于丢包不敏感的应用。DHCP基于UDP,一般获取IP地址都是内网请求,且一次请求不到没有关系。TFTP基于UDP,批量安装操作系统时用到TFTP,没有操作系统系统的时候,不适合维护复杂的状态机。

2、不需要一对一沟通,可以广播的应用。DHCP时广播协议。D类地址是组播地址,VXLAN需要组播,也基于UDP。

3、需要处理速度快,时延低,可以容忍少数丢包,但要求即便网络拥塞,也毫不退缩。

基于UDP的“城会玩”的五个例子

1、网页或APP的访问。QUIC(Quick UDP Internet Connections,快速UDP互联网连接)基于UDP,在应用层师兄快速连接建立、减少重传时延,自适应拥塞控制。

2、流媒体协议。

3、实时游戏。

4、IoT物理网。因为物联网终端资源少。

5、移动通信领域。因为移动通信网络协议本身比较复杂,TCP显得多余了。

### P2P网络协议介绍 #### 定义与特点 P2P(Peer-to-Peer)网络是一种分布式网络架构,在这种架构下,所有节点既是客户端也是服务器。这些节点能够相互请求并提供资源和服务,而不依赖于集中式的服务器[^1]。 #### 工作原理 在网络中,各个对等节点可以直接相互通信,并共享计算能力、带宽以及存储空间等资源。当某个节点需要获取特定数据时,它会查询临近的多个节点而不是单个中心服务器;一旦找到所需的数据副本,则可以从多个源同时下载片段直至完成整个文件的组装[^2]。 #### 协议层面上的操作机制 对于具体的消息传递而言,某些实现可能会采用像`store`这样的子协议来进行操作管理——例如保存或检索信息单元。这类活动通常是在更广泛的广播框架之上执行,比如通过Libp2p库创建的安全流通道与其他参与者交互[^3]。 #### 应用场景与发展历程 随着技术进步,基于P2P模式的应用不断涌现和发展壮大。特别是在区块链领域内,去除了传统意义上的中间件之后,使得交易验证变得更加透明高效。然而值得注意的是,“纯正”的P2P体系强调完全分布化特性,这与那些保留了一定程度集权控制的设计有所区别[^4]。 ```python # Python伪代码展示如何在一个简单的P2P环境中发起一次资源共享请求 def request_resource(peer_id, resource_name): # 向邻居节点询问是否有该资源 neighbors = get_neighbors() for neighbor in neighbors: response = send_query(neighbor, {"type": "resource_request", "id": peer_id, "name": resource_name}) if response['status'] == 'success': download_from_peer(response['source'], resource_name) break def download_from_peer(source_peer, resource_name): print(f"正在从{source_peer}下载 {resource_name}") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值