博客
关于我
第五章 基于TCP的服务器端/客户端(2)
阅读量:724 次
发布时间:2019-03-21

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

TCP网络编程相关学习笔记

《TCP/IP网络编程》一书中,关于TCP套接字的I/O缓冲机制和数据传输机制的学习有些难度。特别是关于如何实现一个可靠的客户端和服务器之间的通信,需要深入理解TCP协议的原理。

主要学习了TCP协议的核心知识点,包括:

  • TCP套接字中的I/O缓冲特性
    • 每个TCP套接字都有自己独立的I/O缓冲区,缓冲区会在套接字创建时自动生成
    • 即使关闭套接字,输出缓冲中的数据仍会继续发送
    • 关闭套接字后,输入缓冲中的数据会丢失
    • 因此在开发多并发连接时需要注意缓冲区的分配与管理
    • write函数和read函数都不会等数据立即传输完成,需要理解其工作机制
    1. TCP的可靠传输机制
      • TCP会控制数据流的传输流量,避免出现缓冲溢出的风险
      • 数据传输过程中,数据包会被分配序号,发送方和接收方需要通过ACK确认接收状态
      • 如果收到某个数据包没有ACK,发送方会重转该数据包重新发送
      • 为此,TCP协议会启动计时器等待ACK应答,如果超时没有响应则实现数据包重转
      • 这些机制确保了数据能够可靠、完整地送达接收方
      1. TCP连接的建立与断开
        • TCP连接的建立采用三次握手机制
        • youngest也称为SYN+ACK序列,这是建立连接的第一步
        • 断开连接时会经历四次握手,双方各发送一次FIN报文
        • FIN报文的作用是通知通信对方可以关闭连接
        1. TCP数据交换的三次握手过程
          • 数据交换过程中发送方会持续发送数据包,接收方则通过ACK报文确认接收状态
          • 每次ACK号会增加传输的字节数,并且带有序号,以便接收方重建接收数据的顺序
          • 这样的机制确保了数据的完整性和有序性

          了解了这些TCP协议的实现细节,可以帮助更好地理解网络编程中的数据传输机制。

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

    你可能感兴趣的文章
    MySQL Server 5.5安装记录
    查看>>
    mysql server has gone away
    查看>>
    mysql slave 停了_slave 停止。求解决方法
    查看>>
    MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
    查看>>
    MYSQL sql语句针对数据记录时间范围查询的效率对比
    查看>>
    mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
    查看>>
    mysql Timestamp时间隔了8小时
    查看>>
    Mysql tinyint(1)与tinyint(4)的区别
    查看>>
    mysql union orderby 无效
    查看>>
    mysql v$session_Oracle 进程查看v$session
    查看>>
    mysql where中如何判断不为空
    查看>>
    MySQL Workbench 使用手册:从入门到精通
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>
    MySQL —— 视图
    查看>>