首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

传输

---- 传输 前言 打算系统学习下计算机网络,就来翻阅经典的自顶向下 本篇是第三章传输(书中翻译为运输,故下面运输传输可能会同时出现,anyway反正一个意思),主要关注TCP和UDP,还有注意拥塞控制...(logic communication) 功能,是在端系统中而不是在路由器中实现的 为了简化术语,我们将运输分组称为报文段(segment)。...multiplexing)与多路分解(demultiplexing) 传输协议支持的应用协议如图所示: 2、多路复用与多路分解 我们考虑接收主机怎样将一个到达的运输层报文段定向到适当的套接字。...TCP 协议是一种面向连接,可靠,基于字节流的传输通信协议。...RTT再将cwnd的值翻番,而是采用了一种较为 保守的方法,每个RTT只将cwnd的值增加一个MSS [RFC 5681] (3)快速恢复 快速恢复是TCP推荐的而非必需的构件[RFC5681] 结语 传输的学习

48120

Linux传输协议:UDP和TCP

传输和网络都是在linux内核中实现的,而linux内核是用C语言实现的,那UDP报头实际就是一个结构体,结构体成员变量实际就是UDP报头中的各个字段值,所以在分用时,只需要让指针指向数据包的前8个字节...Linux的文件系统联系起来,从而更好的理解传输向上交付有效载荷这个过程。...另外服务器是会收到来自大量的不同的客户端的连接请求的,所以服务器是需要将这些大量的连接管理好的,因为我们知道传输是在服务器主机的OS内部实现的,而操作系统需要管理连接,那采用的方式就一定是先描述,再组织...4.2 用UDP实现可靠性传输 1....其实用UDP实现可靠性传输,是有对应的方案的,因为摆在我们面前的TCP就是这个世界上最优秀的可靠性传输协议,而UDP也想要实现,其实就是在应用仿照内核TCP的机制来实现

37330
您找到你想要的搜索结果了吗?
是的
没有找到

基于epoll的TP传输实现

抽象TP传输设计   在使用epoll实现实际的传输之前,先设计一个抽象的传输,这个抽象的传输传输实现的接口。   ...接口中一共有以下几个通用的类或者接口: (1)Socket:通用的套接字,用于封装本地套接字,同时会在析构时自动关闭套接字,避免资源泄漏 (2)DataSink:通用的数据接收,当传输接收到数据时...:基本的服务器类,继承了Socket类 (6)BasicStream:基本的数据流泪,继承IStream和Socket类 1.1 抽象类图 1.2 Socket类实现   #ifndef SOCKET...基于epoll实现服务器和客户端   在前面的内容中已经完成了抽象TP传输和基础工具(消息队列、线程池、缓冲区抽象、事件循环和日志工具)的实现,接下来在抽象TP传输和基础工具的基础上完成基于epoll...机制服务器和客户端的实现

60230

传输 复习

为什么需要运输呢? 作用:从通信和信息处理的角度看,传输向它上面的应用提供通信服务,它属于面向通信部分的最高层。...因此 从传输的角度,真正通信的并不是主机而是主机的进程,传输为两主机提供端到端的通信。...传输有两个重要功能: 复用和分用 复用:在发送方的不同应用进程都可以使用同一个传输协议传送数据(当然也需要加上适当的协议首部) 分用:接收方的传输在剥去报文的首部后能够把这些数据正确交付给应用进程...PS:网络传输的数据单元为『数据报』,传输的数据单元为『报文段』,但为了方便起见,可以统称为『分组』。...如何实现流量控制? 由滑动窗口协议(连续ARQ协议)实现。 滑动窗口协议既保证了分组无差错、有序接收,也实现了流量控制。

40220

传输协议

TCP 和 UDP 是两种最为著名的传输协议,二者都使用 I P 作 为 网 络 协 议 尽管 TCP 和 UDP 都使用相同的网络( IP ), TCP 却向应用提供与 UDP 完全不同的服务...,开放式系统互联) 参考模型中一种无连接的传输协议,提供面向事务的简单不可靠信息传送服务,UDP提供了无连接通信,适合于一次传输少量数据,UDP报文没有可靠性保证、顺序保证和流量控制字段等,可靠性较差...但是正因为UDP协议的控制选项较少,在数据传输过程中延迟小、数据传输效率高,适合对可靠性要求不高的应用程序,或者可以保障可靠性的应用程序,如DNS、TFTP、SNMP等。...也就是说,通过TCP连接传送的数据,无差错,不丢失,不重复,且按序到达;UDP尽最大努力交付,即不保证可靠交付,Tcp通过校验和,重传控制,序号标识,滑动窗口、确认应答实现可靠传输。...3、UDP具有较好的实时性,工作效率比TCP高,适用于对高速传输和实时性有较高的通信或广播通信。

52310

网络传输(计算机网络传输大题)

概述 1.1 传输的意义 传输的由来 有了MAC地址和IP地址,我们已经可以在互联网上任意两台主机上建立通信。...“传输”的功能,就是建立”端口到端口”的通信。相比之下,”网络”的功能是建立”主机到主机”的通信。只要确定主机和端口,我们就能实现程序之间的交流。...网络可以把数据从一个主机传送到另一个主机,但是没有和进程建立联系;传输就是讲进程和收到的数据联系到一起,使数据能够为应用服务 所以说传输是主机才有的层次 1.2 传输的两个协议 1.3...UDP将可靠传输实现放到了应用,然后类似于TCP,实现确认机制,重传机制 UDP不属于连接型协议,因而具有消耗资源小,处理速度快等优点,所以通常音频、视频通话在传送时使用UDP比较多,因为它们即使丢失一两个数据包也不会对结果产生太大影响...UDP传输无法保证数据的可靠传输,只能通过应用实现了;实现的方式可以参考TCP可靠传输的方式,只是实现不在传输,转移到了应用 目前有如下开源程序利用UDP实现了可靠的数据传输;分别有RUDP

59730

MongoDB网络传输模块源码实现

本文为《MongoDB内核源码实现、性能调优、最佳运维实践系列》模块一:MongoDB网络传输模块源码 第二篇,您可点击此处查看第一篇:MongoDB网络传输模块源码实现及性能调优实践-体验内核性能极致设计...说明 在之前的>一文中分析了如何阅读百万级大工程源码、Asio网络库实现、transport传输网络模块中线程模型实现,但是由于篇幅原因...,传输网络模块中的以下模块实现原理没有分析,本文将继续分析遗留的以下子模块: transport_layer套接字处理及传输管理子模块 session会话子模块 Ticket数据收发子模块 service_entry_point...服务入口点子模块 service_state_machine状态机子模块(该《模块在网络传输模块源码实现三》中分析) service_executor线程模型子模块(该《模块在网络传输模块源码实现四...》中分析) 2. transport_layer 套接字处理及传输管理子模块 transport_layer套接字处理及传输管理子模块功能包括套接字相关初始化处理、结合asio库实现异步accept

1.3K20

传输协议——UDP

ftp服务器, 使用21端口 telnet服务器,使用23端口 http服务器, 使用80端口 https服务器, 使用443端口 0-1023: 知名端口号,HTTP、FTP、SSH应用协议...UDP协议 UDP协议端格式 有效载荷一定是上层——应用 给的,上层通过系统调用 把数据拷过来的 UDP报头的宽度是0-31,表示报头所对应的字节数 (4字节) 1. 报头和有效载荷如何分离?...UDP报头中包含16位目的端口号,将一个报文发送到主机上,根据目的端口号向上交付给应用,绑定该端口号的进程 报头(协议)的本质:结构化数据 基于 struct 有两种数据类型,一种为结构体,另一种为位段...struct udp_header 结构体 内部 包含 源端口号、目的端口号 、udp长度、校验和 借助位段的方式,取整形int的4字节中的16个比特位 将缓冲区数据从应用拷贝给操作系统内部...s,,让s+8,再次指向有效载荷 将s强转成 struct udp_header类型 ,指向结构体中的源端口号、目的端口号 、udp长度、校验和 UDP的特点 无连接:知道 对端的IP和端口号 就直接传输

14910

传输:TCP协议

传输中有两个重要的协议:TCP协议和UDP协议。本博文分享的是TCP协议,不仅分享其协议格式,特点等等,还有应答机制、超时传送机制、连接管理机制、滑动窗口、阻塞控制等等。...粘包问题 首先要明确, 粘包问题中的 "包" , 是指的应用的数据包,在TCP的协议头中, 没有如同UDP一样的 "报文长度" 这样的字段, 但是有一个序号这样的字段,站在传输的角度, TCP是一个一个报文过来的...用UDP实现可靠传输 这个问题其实很好回答,我们想想TCP的可靠性是怎么样去实现可靠的,不就是有序列化,保证数据传输有顺序,有确认应答,保证数据被接收,有超时重传,让丢包的数据重新发送,有滑动窗口流量控制...那么,要是UDP想要实现可靠传输,我们可以引入序列号、确认序号、超时重传等等。...这是因为, Linux内核协议栈为一个tcp连接管理使用两个队列: 1. 半链接队列(用来保存处于SYN_SENT和SYN_RECV状态的请求)。 2.

25430

3-传输

传输 传输概述 传输是整个TCP/IP协议栈核心之一,位于网络之上,应用之下。利用网络的服务,为上层应用提供服务。...与网络类似,传输也拥有面向连接的服务与无连接的服务两种,用途在于提供高效的可靠的,性价比高的数据传输 传输的作用在于为运行在不同主机上的应用进程提供逻辑通信(这里的逻辑通信指的是在传输角度看来两个进程间直接进行通信...,实际上还是通过下层提供的服务,不都安将数据向下层传递并在对方处向上传递后才实现通信),简言之,传输提供的是进程到进程间的通信 传输实体 完成传输任务的硬件或软件 传输实体可以在操作系统的内核 可以以一个链接库的形式绑定到网络应用中...可以以一个独立的用户进程运行 甚至可以实现在网络接口卡(网卡)上 传输与网络的区别 网络运行在由承运商操作的路由器上,因此用户无法真正控制网络。...传输架设在网络之上,允许用户控制服务质量 传输原语独立于网络原语,而网络原语会因为网络的不同而不同。传输的原语在向应用传输的原语可以屏蔽掉这些不同,只提供标准,统一的原语。

1.1K20

传输协议总结

传输就是在信纸的空白上写上新的“收信人”信息。每一所房子【某一个终端】会配备一个管理员(传输协议)。管理员从邮差手中接过信,会根据“收信人”,将信送给房子中的某个人。...传输协议TCP 面向字节流服务面向连接,可靠,有序的协议通过滑动窗口、拥塞控制实现可靠和速度应用提供的数据是一串无结构的字节流,传输可以对数据进行分段,数据没有长度限制DUP 面向报文服务无连接,...不可靠,无序的协议应用提供的是一系列报文,传输不对报文进行分割和拼装,报文长度受限制UDP面向报文、无连接、差错检验、表示不同应用进程(绕过TCP协议,实现相对简单的快速通信)图片协议分析语法:格式...在TCP协议中,我们使用连接记录TCP两端的状态,使用编号和分段实现了TCP传输的有序,使用advertised window来实现了发送方和接收方处理能力的匹配,并使用重复发送来实现TCP传输的可靠性...(参考:计算机网络【七】:可靠传输实现)拥塞窗口CWND: 慢启动:从小到大逐渐成倍增大拥塞窗口的值。

21930

传输:UDP协议

传输中有两个重要的协议:TCP协议和UDP协议。 本博文分享的是UDP协议,本文将从UDP的协议格式、UDP的特定以及其缓冲区入手。...传输 传输的作用是负责数据能够从发送端传输到接收端,主要是传输策略。 端口号 端口号标识的是一个主机上进行通信的不同的应用程序,通过IP+PORT,便能够确认全网唯一一个进程。...调用sendto会直接交给内核, 由内核将数据传给网络协议进行后续的传输动作,即即写即发。 UDP具有接收缓冲区....也就是说一个UDP能传输的数据最大长度是64K(包含UDP首部).然而64K在当今的互联网环境下, 是一个非常小的数字.如果我们需要传输的数据超过64K, 就需要在应用手动的分包, 多次发送, 并在接收端手动拼装...基于UDP的应用协议 NFS: 网络文件系统,TFTP: 简单文件传输协议,DHCP: 动态主机配置协议,BOOTP: 启动协议(用于无盘设备启动),DNS: 域名解析协议,也有我们自己写的UDP程序的应用协议

22320

tcpip详解 链路层 网络 传输 应用

1.可以把七协议简化成四协议 链路层 网络 传输 应用 2.通过路由器连接的两个网络 网络ip提供的是一个逐跳协议,提供了一种不可靠的服务,中间有可能会丢 传输tcp在ip的基础上提供了可靠的传输...中间如果包裹丢了,卖家会重新发一个包裹,这里会有一个确认的过程 3.udp是不可靠的,它不会去确认,丢了就丢了,比如语音就用这个,syslog也用这个 4.icmp这个附属协议,ping就是用的这个 5.封装,每一都会留下自己的标记...,从应用开始加个头部,tcp加个头部,ip加个头部,以太网加个头部,封装成帧;帧的数据长度在46~1500字节之间 6.分用,接收方就是分用,从上面的封装中,解出来里面的头部 7.端口号,源端口号一般是随机分配的

76420

5.TCPUDP-传输

TCP/UDP(或TCP/IP)保留的传输端口号范围是 1 ~ 65535。公认端口:1 ~ 1023 。动态端口:1024 ~ 65535。...一、TCP(传输控制协议):用于精准的数据传输 TCP是面向连接形式的可靠服务,字节流形式传输。 TCP是建立在无连接的IP基础上 1.TCP传输特性 ① 可靠的传输服务。...TCP和IP是配合工作的,所以有些参数可直接传送给IP处理,TCP头和IP头合在一起使用。...3.窗口:利用窗口控制数据流量的传输。 2.TCP传输头 ? TCP传输头格式.png (1)源端口、目标端口: 各占 16 位。 源端口:说明源服务访问点。...UDP头.png 1.UDP传输特性 提供无连接的传输服务,不可靠,甚至可以对用户数据不进行校验(当UDP校验和字段为0)。 2.字段: 源端口、目标端口、段长、校验和 16位。

48920

传输:TCP和UDP

传输:TCP和UDP 使用IPv4和IPv6的应用程序 平时我们使用的tcpdump、ping、traceroute属于TCP/IP协议族,虽然叫TCP/IP协议族,但是这个协议族还涉及到许多其他成员...ESTABLISHED状态下接收到FIN: [from ESTABLISHED to CLOSE_WAIT] [TCP状态转换图] 数据捎带 在TCP的建立连接的三次握手和终止连接的四次挥手之间,是数据分节的传输...TCP数据传输 [TCP数据分节传输] TCP还是UDP 上图这样的单一分节的请求和接收,使用TCP时,包括连接建立和连接终止的7个分节,以及最后一次客户对服务器数据的应答,有8个分节额外需要消耗。...存在TIME_WAIT状态的两个理由 实现终止TCP全双工连接的可靠性 假设最后一个主动关闭方发给被动方的ACK丢失,被动方就会重发最终的FIN,因此主动一方必须维护状态信息,以允许它重发对应的ACK。...为了实现全双工关闭(两个方向数据流都彻底关闭),TCP必须正确处理这四个分节中任何一个分节的丢失情况。

1.3K30

MongoDB transport_layer网络传输模块源码实现

说明 在之前的>和>一文中分析了如何阅读百万级大工程源码...、Asio网络库实现、线程模型、transport_layer套接字处理及传输管理子模块、session会话子模块、Ticket数据收发子模块、service_entry_point服务入口点子模块。...本文将继续分析网络传输模块中service_state_machine服务状态子模块,即状态机调度子模块的源码实现。...adaptive线程模型,任务入队以及工作线程调度任务执行的流程将在后续的线程模型子模块中分析,也可以参考:> 此外,scheduleNextWithGuard...cleanTask任务 在数据读写过程、客户端链接关闭、访问DB数据等任何一个环节异常,则会进入State::EndSession状态。

45530

应用安全传输如何进行协议选型?

(1)语法:即数据与控制信息的结构或格式 (2)语义:即需要发出何种控制信息,完成何种动作以及做出何种响应 (3)时序:即事件实现顺序的详细说明 im协议设计分为三:应用、安全传输。...xmpp协议可以实现跨域的互通。例如gtalk和校内通用户聊天。只要服务端实现了s2s服务(server to server) ,不过现在的im基本没有互通需求 ,所以这个服务基本没有人实现。...包头负责传输和解析效率,与业务无关。包体保证扩展性,与业务相关。...四、im传输协议设计 可选的协议有TCP和UDP 现在的im传输基本都是使用TCP,有了epoll等技术后,多连接就不是瓶颈了,单机几十万链接没什么问题。...先聊这么多,希望对大伙进行应用/安全/传输协议选型有帮助。

1.3K50
领券