• 关于tcp的知识记录


    1. 概念

      TCP(Transmission Control Protocol,传输控制协议),是一种面向连接的,可靠地,基于字节流的传输层通信协议。当应用层向TCP层发送用于网络间传输的用8位字节表示的数据流时,TCP则把数据流分割成适当长度的报文段,最大传输段大小(MSS)通常受该计算机连接的网络的数据链路层的最大传送单元(MTU)限制

    2. 特性

      有序性:为每个数据包编排序号,是接收端能够判断先后到达的次序混乱的数据包的原本顺序

      正确性:TCP用一个checksum函数来检验数据是否有错误,在发送和接收时都要计算校验和,这使得接收端能够判断数据是否在传输过程中被破坏

      可靠性:发送端采用超时重传并有确认机制识别错误或丢失数据,进行重发

      可控性:接收端和发送端的网络质量通常不同,TCP采用滑动窗口协议和拥塞控制算法是数据的发送速度达到合理值

    3. 三次握手

      建立连接时,客户端发送SYN包到服务器,并进入SYN_SENT状态,等待服务器确认

      服务器收到SYN包,反馈给客户端一个SYN+ACK包,此时服务器进入SYN_RECV状态

      客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK,客户单和服务器同时进入ESTABLISHED(TCP连接成功)状态,完成三次握手

    4. 四次关闭连接

      关闭请求方向另一方发送一个带有FIN附加标记的报文段

      接收方 收到这个FIN报文段之后,并不立即用FIN报文段回复,而是先向发送方 发送一个确认序号ACK,通知通知自己的相应的应用程序:对方要求关闭连接,使应用程序做相应的清理工作

      接收方的应用程序清理工作完成后,向 发送方发送一个FIN报文段

      发送方 收到这个FIN报文段之后,向接收方发送一个ACK,表示连接彻底释放

  • 相关阅读:
    当年的笔记_apache配置虚拟主机
    sqlserver 调优(三)
    bat命令自用其(一)
    Always On主辅延迟相关描述
    sqlserver中常用的windows命令行的操作
    mysql复制以及一主多从等常见集群概述
    sqlserver 调优(二)
    sqlserver 获取实例上用户数据库的数据字典
    sqlserver事务隔离小结
    mysql 慢查询的小结
  • 原文地址:https://www.cnblogs.com/jackchen001/p/8276299.html
Copyright © 2020-2023  润新知