[Network]Transport Layer
1 Principles behind Transport Layer Services
1.1 Multiplexing/Demultiplexing
Multiplexing at sender side, Demultiplexing at receiver side.
How DemultiplexingIndex with: IP + Port num
This part indicates that transport layer processes data with multiplexing, which function the multiple processes communicate in the network simultaneously without critical collisions.Now we can actually go in to UDP, but I'd like to put the principles in one section. Other Principles below are more relative withTCP.
1.2 Reliable Data Transfer
Reliability is one of the most important problem of Network. And it is obvious that there is no absolute reliability, though we are trying to find a more reliable way for data transmitting.So, most of the implementation of reliable data transferring is built on unreliable data transferring. It is an altitude to make it more reliable.
1. rdt1.0: reliable transfer over a reliable channel
It seems to be an ideal version of rdt.
2. rdt2.0: channel with bit errors
use checksum to detect errors: stop-and-waitACK: receiver tells sender that the pkt OKNAK: receiver tells sender that the pkt BAD, and sender retransmitSo the rdt adds error detection and
receiver feedback
a fatal flaw: if ACK and NAK corrupt or duplicate.
3. rdt2.1: sequence number
Here are just two num 0 and 1.Sender must get the ACK/NAK before moving to next state.Receiver must check if the pkt is duplicate, here num 0 and 1.But the receiver can not know if the last ACK/NAK received OK at sender.
4. rdt2.2: a NAK-free protocol
Mostly same with rdt2.1 except without NAK1) receiver send ACK for last pkt received OK2) duplicate ACK at sender results in same action as NAK
5. rdt3.0: channel with errors and loss
new assumption: channel can lose pkts.Sender wait amount of time for ACK. timeout->retransmit->multiple pkt, receiver must detect.
6. Pipeling
There are two types of pipeling protocols:
1) Go-back-NSenderThere is N size window:
Timer for each pkt, timeout to retransmit. And the sender expects to get the pkt[nextseqnum].Receiver:Only send ACK for correctly-received pkt with highest sequence number - pkt[expectedseqnum].If receiving out-of-order pkt,discard,re-ACK with highest in-order sequence number.
2) Selective Repeat:It promote some disadvantages of GBN of discarding the disorderred pkts. It buffers the pkts and move the windows until the lowerbound is ACKed(sender) or received(received)
1.3 Flow Control (talked in TCP)
1.4 Congestion Control
This is different from flow control. Congestion is said that too many sources sending much data too fast fornetwork to handle(but flow control is said to send and receiver).There are several ways to congestion control, end systems lead(TCP) or network lead. I just want detail the congestion control in TCP below.
2 Transport Layer Protocols
2.1 UDP
1. Properties
1) connectionless: simple, small header, no congestion control
2) lost, deliver out of order
2. Checksum
An example
3. Segment Format
2.2 TCP
1. overview
end-to-endreliable, in-orderpipelinedata: MSSconnectionflow control
2. RTT and Time out
1) RTT
2) Time outtimeout = RTT + safety margina. margin
b. timeout
3. rdt
sender
ACK received: update the Sendbase to ACK=ytime out: send with smallest sequence numberreceiver
a. Formal: delay ACK
b. Higher than expected sequence: duplicated ACK of expected sequence
c. fill gaps: ACK of sequence at lower end of gap.
4. Retransmit
With the discussion above, if loss happens, there will likely be many duplicate ACKs. So sender will detect loss and begin tofast retransmit
Fast retransmit: resend segment before timer expire
5. Flow control
sender will not overflow the buffer of receiver.
Get the point above, sender limits unACKed data smaller thanspare room of receiver.
6. Connection Management
a. initiation work
seq num
flow control, buffer, rcvwindow
b. three way handshake
build:
1) client->server: SYN, initial seq num
2) server->client: SYNACK segment, server allocate buffers, specify initial seq num
3) client->server: reply ACK segment, may with data
close:
1) client->server: FIN
2) server->client: ACK first, after closing connection, send FIN
3) client->server: ACK
4) server: get ACK close.
7. Congestion control
To sum up the details of congestion control in TCP is that: send windows vary with the condition of congestion in the network. If the network is congested, the send will decrease the window size. If not the window will be enlarged. So the intension of sending
is according to the network condition.
How sender perceive congestion:
1) loss event: time out or 3 duplicate ACKs
Slow start
1) when connection begins, CongWin = 1 MSS
2) CongWin increase exponentially until loss event.
Loss
1) 3 dup ACKs:
Reno: CongWin half, win grow linear -- 3 dup ACKs indicate the network capable of delivering some segments.
Tahoe: same with time out
2) timeout: CongWin set to 1 MSS, win grow exponentially to a threshold then linearly. -- timeout is a more alarming condition
End.
[Network]Transport Layer的更多相关文章
- Transport layer and Network layer
http://stackoverflow.com/questions/13333794/networking-difference-between-transport-layer-and-networ ...
- [Network]Application Layer
1 Principles of Network Applications 1.1 Application Architectures Client-Server Peer-to-Peer Hybird ...
- Transport Layer Protocols
1 End-to-end Protocols(端到端协议) 传输层协议往往是主机对主机(host-to-host)或者说是端到端(end-to-end).通常希望传输层协议可以提供如下service: ...
- Host Controller transport layer and AMPs
The logical Host Controller Interface does not consider multiplexing/routing over the Host Controlle ...
- 传输层-Transport Layer(上):传输层的功能、三次握手与四次握手、最大-最小公平、AIMD加法递增乘法递减
第六章 传输层-Transport Layer(上) 6.1传输层概述 在之前的几章内容中,我们自底向上的描述了计算机网络的各个层次,还描述了一些处于不同层次下的经典网络协议(如以太网.无线局域网.或 ...
- 传输层-Transport Layer(下):UDP与TCP报头解析、TCP滑动窗口、TCP拥塞控制详解
第六章 传输层-Transport Layer(下) 上一篇文章对传输层的寻址方式.功能.以及流量控制方法做了简短的介绍,这一部分将介绍传输层最重要的两个实例:TCP协议和UDP协议,看一看之前描述的 ...
- Elasticsearch client node 启动时出现警告:exception caught on transport layer 及java.net.NoRouteToHostException: No route to host
发现该问题源自发现kibana不能打开sense,并且看见elasticsearch插件处于服务不可用状态,但是在client node上curl localhost:9200发现能够返回ES基本信息 ...
- 计算机网络自顶向下方法第3章-传输层 (Transport Layer).1
3.1 概述和运输层服务 运输层协议为运行在不同主机上的应用进程之间提供了逻辑通信(logic communication)功能. 3.1.1 运输层和网络层的关系 网络层提供了主机之间的逻辑通信,而 ...
- 计算机网络自顶向下方法第3章-传输层 (Transport Layer).2
3.5 面向连接的运输: TCP 3.5.1 TCP连接 TCP是因特网运输层的面向连接的可靠的运输协议. TCP连接提供全双工服务(full-duplex service). TCP连接是点对点的连 ...
随机推荐
- js 自定义方法 实现停留几秒 sleep
function sleep(numberMillis) { var now = new Date(); var exitTime = now.getTime() + numberMillis; wh ...
- ThinkPHP 连接Oracle的配置写法,(使用Oci扩展而非PDO的写法)
測试了非常多遍,TP官网根本就没有给出正确的写法,并且网上搜索到的全都是错误的. 跟踪代码.终于找出了正确的配置写法,备份例如以下.(by default7#zbphp.com) 'DB_TYPE' ...
- .NET 单点登录
<appSettings> <!--是否启用单点登录接口--> <add key="IsStartCas" value="f ...
- wamp的安装使用(转)
这次需要记录一下我搭建web服务器的过程. 第一步,确定自己要使用的平台:这次我用的是windows2008 server版本 第二步,计划是想要纯手工的安装apache.php等.但是我们可以下载一 ...
- HTML中心在页面上弹出自定义表单层(实现可能拖累)
使用DIV窗体来动态显示内容的原理:首先採用CSS和HTML隐藏弹窗中的内容,然后利用JavaScript(本教程中是JQuery)来动态显示它们.这样的效果不仅可以充分利用有限的版面空间,并且可以提 ...
- android如何使用自己定义JNI接口,以及NDK环境建设和使用的工具。
一.建筑环境: 1.需要的工具: A.cygwin (在windows下使用LINUX系统) ...
- key 串口
/******************************************************************** 函数功能:往串口发送一字节数据(可通过超级终端或者串口调试助 ...
- hdu4771 Stealing Harry Potter's Precious
注意--你可能会爆内存-- 假设一个直接爆搜索词-- 队列存储器元件被减少到-- #include<iostream> #include<map> #include<st ...
- 取证学习资料DVD
http://www.infiniteskills.com/training/learning-computer-forensics.html https://www.youtube.com/watc ...
- UBUNTU12.04下安装配置体验gnome3
年. ubuntu12.04默认采用unity界面,但是自己更加喜欢gnome3的操作方式. 安装gnome3: sudo apt-get install gnome-shell 其实安装成功后,注 ...