ss命令(来自iproute2工具集,作为netstat的较新的替代方案)在--help中有以下选项
-0, --packet display PACKET sockets
-t, --tcp display only TCP sockets
-S, --sctp display only SCTP sockets
-u, --udp display only UDP sockets
-d, --dccp display only DCCP sockets
-w, --raw display only RAW sockets
-x, --unix display only Unix domain sockets在这里,RAW和UNIX域套接字究竟有什么区别?
PACKET套接字实际上是什么?
发布于 2018-09-01 07:42:58
原始套接字是网络插座 (通常是AF_INET或AF_INET6 )。它可用于创建原始IP包,这些包可用于故障排除或无需使用SOCK_STREAM实现您自己的TCP实现:
原始套接字允许在用户空间中实现新的IPv4协议。原始套接字接收或发送原始数据报,不包括链路级别的标头。[
raw(7)]
像nmap这样的工具使用原始套接字,以便在初始的SYN,SYN-ACK之后停止TCP握手,因为TCP连接从未完全建立。作为网络套接字,它使用sockaddr_in作为地址。
然而,原始套接字的创建通常受到限制。只有特权进程才能创建它们。
另一方面,unix套接字不是网络套接字(AF_UNIX)。这是一个本地插座:
AF_UNIX(也称为AF_LOCAL)套接字家族用于有效地在同一台机器上的进程之间进行通信。[unix(7)]
它使用另一个地址结构(sockaddr_un)。这是一个没有通过网络层的在单个进程间通信系统上实现双向通信的通用方法。
数据包套接字是驱动程序级别上的原始数据包:
分组套接字用于在设备驱动程序(OSI第2层)级别接收或发送原始数据包。它们允许用户在物理层之上的用户空间中实现协议模块。[
packet(7)]
其他套接字作用于网络层(OSI层3)或更高层。此时,您将直接与网络接口的驱动程序对话。
有关更多信息,请参见socket(2)、ip(7)、packet(7)、raw(7)、socket(7)和unix(7)。
https://unix.stackexchange.com/questions/466181
复制相似问题