标准I/O VS 网络IO 标准I/O又称为标准I/O流,从某种意义上讲是全双工的,因为程序能够在同一个流上执行输入和输出. Unix/Linux对网络的抽象是一种称为套接字的文件类型.和任何Unix/Linux文件一样,套接字也是用文件描述符来引用的,在这种情况下称为套接字描述符.引用进程通过读写套接字描述符来与运行在其他计算机上的进程通信. 然而对流的限制和对套接字的限制,有时候会相互冲突.(However, there are restrictions on full-duplex str
linux可通过五元组唯一确定一个链接:源IP,源端口,目的IP,目的端口,传输层协议.而一个端口不允许被两个及以上进程占用(一个进程可同时占用多个端口),据此是否可以推测一台linux服务器最多可以同时处理2^16(65536,或65K)个链接即并发请求呢? 一台服务器到底能够支持多少TCP并发连接呢? 1. 文件描述符限制 对于服务器来说,每一个TCP连接都要占用一个文件描述符,一旦文件描述符使用完,新的连接到来返回给我们的错误是"Socket/File:Can't open so many
查看tcp连接几个常用的命令 1 ss ss 列出所有的连接,包括tcp连接.udp连接.unix socket.raw socket ss -t 列出所有tcp连接 ss -tl 列出所有处于监听状态的tcp连接 ss -u 列出所有的udp连接 ss -p 列出连接时显示进程名字和pid ss -s 统计socket 找出某个进程监听的端口号: ss -ltp | grep pro_name 找出某个端口号被哪个进程占用: ss -p | grep port_num 列出某个端口上的tcp连