博客
关于我
[编程] TCP协议概述
阅读量:658 次
发布时间:2019-03-15

本文共 1498 字,大约阅读时间需要 4 分钟。

TCP 协议概述

1.TCP提供一种面向连接的、可靠的字节流服务。

2.两个应用程序通过TCP连接交换8bit字节构成的字节流。

3.每个TCP首部都包含源端和目的端的端口号,用于寻找发端和收端应用进程。这两个值加上IP首部中的源端IP地址和目的端IP地址唯一确定一个TCP连接。

4.一个IP地址和一个端口号也称为一个插口(socket),出现在最早的TCP规范(RFC793)

 

TCP 保证可靠性:

1.应用数据被分割成 TCP 认为最适合发送的数据块

2.当 TCP 发出一个段后,它启动一个定时器,等待目的端确认收到这个报文段,超时重发

3.当 TCP 收到发自 TCP 连接另一端的数据,它将发送一个确认

4.TCP 将保持它首部和数据的检验和

5.如果必要, TCP 将对收到的数据进行重新排序

6.TCP 还能提供流量控制

 

TCP是一个面向连接的协议。

1.使用telnet与tcpdump互相配合进行测试

115.159.28.111.51142 > 10.141.14.117.http: Flags [S], seq 1784777886, win 29200,

10.141.14.117.http > 115.159.28.111.51142: Flags [S.], seq 1181145550, ack 1784777887, win 28960,

115.159.28.111.51142 > 10.141.14.117.http: Flags [.], ack 1, win 229,

 

seq:Sequence number(顺序号码)

ack:Acknowledge number(确认号码)

syn:SYN(synchronous建立联机)

 

主机A:115.159.28.111   主机B:10.141.14.117.http

第一次握手:A发送syn=1, 产生随机seq=1784777886

第二次握手:B发送 随机产生seq=1181145550,ack=接收到的seq+1 1784777887

第三次握手:A发送 ack=1,

 

TCP首部标志位:

S SYN 同步序号

F FIN 完成发送

R RST 复位

P PST 推送

. 置为0

 

结束连接:

TCP 有一个特别的概念叫做 half-close,这个概念是说,TCP 的连接是全双工(可以同时发送和接收)连接,因此在关闭 连接的时候,必须关闭传和送两个方向上的连接。客户机给服务器一个 FIN 为1的 TCP 报文,然后服务器返回给客户端一个确认 ACK 报文, 并且发送一个 FIN 报文,当客户机回复 ACK 报文后(四次握手),连接就结束了。

 

客户端状态迁移:

CLOSED->SYN_SENT->ESTABLISHED->FIN_WAIT_1->FIN_WAIT_2->TIME_WAIT->CLOSED

服务端状态迁移:

CLOSED->LISTEN->SYN 收到->ESTABLISHED->CLOSE_WAIT->LAST_ACK->CLOSED

 

长连接:指在一个连接上可以连续发送多个数据包,在连接保持期间,如果没有数据包发送,需要双方发链路检测包。

短连接:是指通讯双方有数据交互时,就建立一个连接,数据发送完成后,则断开此连接,即每次连接只完成一项业务的发送。

 

ulimit -a

ulimit -n用于限制进程能够打开的文件描述符的最大数目。因为任何设备在linux下都是文件,通信的接口也有专门的接口文件负责,所以linux下进程tcp链接的最大并发量也受限于该值

转载地址:http://rsnmz.baihongyu.com/

你可能感兴趣的文章
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>