博客
关于我
[编程] 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学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>