tcp处理
来源:互联网 发布:图片做视频的软件 编辑:程序博客网 时间:2024/06/13 01:29
进入包的处理(net/ipv4/tcp_input.c):
接收的段都由tcp_v4_do_rcv处理,该函数根据不同的状态交由不同的函数处理。LISTEN状态且已建立半连接的处理函数为tcp_v4_hnd_req,其他状态为tcp_rcv_state_process
tcp_rcv_established处理从一个建立的连接进入的tcp包,是处理tcp包的唯一入口点。Linux有两种方法处理tcp包:快速路径和慢速路径。
tcp_ack 处理ack或带ack的数据包
tcp_event_data_recv 处理tcp包。在接收到顺序数据段时处理。
tcp_data_queue() 处理数据段中的数据。套接字缓冲耗尽或者乱序,在这里面处理。此外还要处理重复数据段、窗口外数据段以及重传。
降窗函数tcp_cwnd_down
tcp_cong_void处理拥塞避免。实现了慢速启动和快速重传的拥塞控制算法。完全的拥塞控制机制在tcp_fastretrans_alert中实现。在tcp_ack中会调用tcp_fastretrans_alert函数
tcp_select_window计算通告窗口
tcp_push 发送数据
tcp_congestion_ops结构提纲了支持多种拥塞控制的机制。需要实现tcp_congestion_ops中的接口,必须实现ssthresh、cong_svoid。
必须将拥塞控制算法的名称添加到/proc/sys/net/ipv4/tcp_congestion_control中才能使用。比如要使用Bic和veno算法:
echo "bic veno">/proc/sys/net/ipv4/tcp_congestion_control
tcp_register_congestion_control将一个新的拥塞控制算法注册到tcp_congestion_ops中。除了reno,其他的拥塞控制算法都是作为模块在module_init中注册的。如bictcp_register、cubic_register。
选取某种拥塞控制算法tcp_set_congestion_control
0 0
- tcp处理
- TCP的TSO处理
- TCP消息边界处理
- TCP连接超时处理
- TCP超时处理
- TCP处理主要开销
- tcp连接超时处理
- tcp断开异常处理
- TCP粘包处理
- Kernel TCP连接处理
- Libnids中tcp流处理"tcp.c"
- TCP连接中断的处理
- tcp连接断连处理
- TCP/UDP select超时处理
- tcp连接断连处理
- tcp连接数 处理办法
- tcp ack 处理注释分析
- TCP UDP 包处理方式
- 错误经验截图
- iOS之代码规范
- Struts2——ModelDriven运用
- 查找数组中只出现一次的元素
- Mybatis 高级结果映射 ResultMap Association Collection
- tcp处理
- 枚举类型
- Linux + C + Epoll实现高并发服务器(线程池 + 数据库连接池)
- UCGUI编程三:背景窗口重绘
- CSS3中和动画有关的属性transform、transition 和 animation
- 安卓中多线程断点续传文件下载核心代码总结
- Mybatis中的#和$的区别
- 关于tq2440 boa服务器搭建
- android接收和发送短信代码-BroadcastReceiver应用