博客
关于我
第五章 基于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 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>
    MySQL 数据库备份种类以及常用备份工具汇总
    查看>>
    mysql 数据库存储引擎怎么选择?快来看看性能测试吧
    查看>>
    MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
    查看>>
    MySQL 数据库的高可用性分析
    查看>>
    MySQL 数据库设计总结
    查看>>
    Mysql 数据库重置ID排序
    查看>>
    Mysql 数据类型一日期
    查看>>
    MySQL 数据类型和属性
    查看>>
    mysql 敲错命令 想取消怎么办?
    查看>>
    Mysql 整形列的字节与存储范围
    查看>>
    mysql 断电数据损坏,无法启动
    查看>>
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>