TCP协议是做用是用来进行端对端数据传送的,那么就会有发送端和接收端,在操做系统有两个空间即user space和kernal space。缓存
每一个Tcp socket链接在内核中都有一个发送缓冲区和接收缓冲区,TCP的全双工的工做模式以及TCP的流量(拥塞)控制即是依赖于这两个独立的buffer以及buffer的填充状态。服务器
单工:只容许甲方向乙方传送信息,而乙方不能向甲方传送 ,如汽车单行道。socket
半双工:半双工就是指一个时间段内只有一个动做发生,甲方能够向乙方传送数据,乙方也能够向甲方传送数据,但不能同时进行,如一条窄马路同一时间只能容许一个车通行。tcp
全双工:同时容许数据在两个方向上同时传输,它在能力上至关于两个单工通讯方式的结合。spa
一个socket的两端,都会有send和recv两个方法,如client发送数据到server,那么就是客户端进程调用send发送数据,而send的做用是将数据拷贝进入socket的内核发送缓冲区之中,而后send便会在上层返回。操作系统
也就是说send()方法返回之时,数据不必定会server
发送到对端即服务器上去(和write写文件有点相似),send()仅仅是把应用层buffer的数据拷贝进socket的内核发送buffer中,发送是TCP的事情,和send其实没有太大关系。接口
接收缓冲区把数据缓存入内核,等待recv()读取,recv()所作的工做,就是把内核缓冲区中的数据拷贝到应用层用户的buffer里面,并返回。若应用进程一直没有调用recv()进行读取的话,此数据会一直缓存在相应socket的接收缓冲区内。对于TCP,若是应用进程一直没有读取,接收缓冲区满了以后,发生的动做是:收端通知发端,接收窗口关闭(win=0)。这个即是滑动窗口的实现。保证TCP套接口接收缓冲区不会溢出,从而保证了TCP是可靠传输。由于对方不容许发出超过所通告窗口大小的数据。 这就是TCP的流量控制,若是对方无视窗口大小而发出了超过窗口大小的数据,则接收方TCP将丢弃它。进程
查看socket发送缓冲区大小,cat /proc/sys/net/ipv4/tcp_wmemip