摘要: 简介 sys_connect->inet_stream_connect->inet_stream_connect->tcp_v4_connect->tcp_connect对于tcp,inet_stream_connect()调用tcp_v4_connect发送三次握手的第一次syn请求, 并根据so 阅读全文
posted @ 2019-07-01 23:17 codestacklinuxer 阅读(958) 评论(0) 推荐(0) 编辑
摘要: static int __must_check tcp_queue_rcv(struct sock *sk, struct sk_buff *skb, int hdrlen, bool *fragstolen) { int eaten; /* 取队尾 */ struct sk_buff *tail 阅读全文
posted @ 2019-07-01 23:14 codestacklinuxer 阅读(321) 评论(0) 推荐(0) 编辑
摘要: 来之google 收索结果 f ull 和 empty 。信号量mutex作为互斥信号量,它用于控制互斥访问缓冲池,互斥信号量初值为 1;信号量 full 用于记录当前缓冲池中“满”缓冲区数,初值为0。信号量 empty 用于记录当前缓冲池中“空”缓冲区数,初值为n。新的数据添加到缓存中后,full 阅读全文
posted @ 2019-07-01 23:14 codestacklinuxer 阅读(1102) 评论(0) 推荐(0) 编辑
摘要: 直接看代码 //后面整理相关信息 /* * This function implements the receiving procedure of RFC 793 for * all states except ESTABLISHED and TIME_WAIT. * It's called fro 阅读全文
posted @ 2019-07-01 23:13 codestacklinuxer 阅读(825) 评论(2) 推荐(0) 编辑
摘要: fork、vfork、clone之间的差异 fork/vfork/clone这三者均为系统调用,进程或线程通过这三种系统调用的某一种来创建子进程/线程, 这三种调用的底层实现均为linux内核源码kernel/fork.c中的do_fork()函数来实现,它们间的唯一的差别就是传入的参数值有差异。 阅读全文
posted @ 2019-07-01 23:12 codestacklinuxer 阅读(165) 评论(0) 推荐(0) 编辑
摘要: void tcp_rcv_established(struct sock *sk, struct sk_buff *skb, const struct tcphdr *th, unsigned int len) 主要是处理已经连理连接的输入的tcp数据包。tcp_rcv_established实际上 阅读全文
posted @ 2019-07-01 23:11 codestacklinuxer 阅读(719) 评论(0) 推荐(0) 编辑
摘要: 后面详细分析 先上传 之前总结查看源码后的总结 Nagle算法的基本定义是任意时刻,最多只能有一个未被确认的小段。所谓“小段”,指的是小于MSS尺寸的数据块,所谓“未被确认”,是指一个数据块发送出去后,没有收到对方发送的ACK确认该数据已收到。也就是没有收到ack 的时候不会再次发送数据出去。该算法 阅读全文
posted @ 2019-07-01 20:50 codestacklinuxer 阅读(692) 评论(0) 推荐(0) 编辑