首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux 域套接字抓包

一、基础概念

  1. Linux域套接字(Unix Domain Sockets)
    • 是一种在同一台主机上的进程间通信(IPC)机制。与网络套接字不同,它不需要经过网络协议栈,数据传输只在本地进行。
    • 它有自己的地址空间,通常以文件路径(在/tmp等目录下常见)或者抽象名称(以空字符开头)的形式表示地址。
  • 抓包概念
    • 抓包是指捕获网络或本地通信中的数据包以便进行分析。对于域套接字抓包,就是要获取在本地通过域套接字传输的数据内容。

二、相关优势

  1. 性能优势
    • 由于不需要经过网络协议栈的处理,数据传输速度更快,延迟更低。例如,在同一服务器内的多个进程之间快速交换大量数据时,域套接字比网络套接字更高效。
  • 安全性优势
    • 数据只在本地传输,减少了网络暴露带来的安全风险。与通过网络套接字通信相比,不需要考虑网络防火墙、入侵检测等网络安全设备的干扰。

三、类型

  1. 流式域套接字(SOCK_STREAM)
    • 类似于TCP协议,提供可靠的、有序的、双向的字节流通信。适用于需要按顺序准确传输数据的场景,如文件传输或者数据库连接。
  • 数据报域套接字(SOCK_DGRAM)
    • 类似于UDP协议,提供无连接、不可靠的数据报通信。适用于对实时性要求较高但对数据准确性要求相对较低的场景,如实时日志收集(只要能收集到大部分日志即可)。

四、应用场景

  1. 本地服务间通信
    • 在一个大型的服务器应用中,不同的服务组件可能运行在不同的进程中,它们可以使用域套接字进行通信。例如,Web服务器和后台的任务调度进程之间通过域套接字传递任务请求和结果。
  • 系统内部工具交互
    • 像一些系统监控工具可能会使用域套接字与被监控的进程进行通信,获取系统资源使用情况等信息。

五、抓包工具及方法

  1. ss命令(socket statistics)
    • 可以用来查看Linux系统中的套接字统计信息,包括域套接字。例如,ss -x命令可以列出所有的域套接字连接情况。
    • 示例:
    • 示例:
    • 这个命令会显示本地域套接字的本地地址、远程地址(对于本地通信来说可能都是本地相关的标识)、状态等信息。
  • lsof命令(list open files)
    • 因为域套接字在Linux系统中也被视为一种特殊的文件,所以可以使用lsof命令来查看相关的域套接字文件。例如,lsof | grep sock可以筛选出与套接字相关的文件描述符信息,其中包含了域套接字的信息。
    • 示例:
    • 示例:
    • 如果要更精确地查找域套接字相关的信息,可以结合其他条件进一步筛选。

六、可能遇到的问题及解决方法

  1. 权限问题
    • 当尝试查看某些系统级进程使用的域套接字时,可能会遇到权限不足的情况。
    • 解决方法:使用sudo命令提升权限来执行抓包相关的命令,例如sudo ss -x
  • 信息解读困难
    • 域套接字的地址表示方式(如文件路径形式)可能比较复杂,而且抓包工具输出的信息可能包含很多专业术语。
    • 解决方法:深入学习Linux系统编程中关于域套接字的知识,参考相关的文档资料,如《UNIX网络编程》等书籍,以便更好地理解抓包工具输出的信息。
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

18.1 Socket 原生套接字抓包

原生套接字抓包的实现原理依赖于Windows系统中提供的ioctlsocket函数,该函数可将指定的网卡设置为混杂模式,网卡混杂模式(Promiscuous Mode)是常用于计算机网络抓包的一种模式,...启用混杂模式的主要用途之一是网络抓包分析,使用混杂模式可以捕获网络中所有的数据包,且不仅仅是它所连接的设备的通信数据包。...cmd: 操作代码,用于控制对套接字的特定操作。argp: 与特定请求代码相关联的参数指针。此参数的具体含义取决于请求代码。...要实现抓包前提是需要先选中绑定到那个网卡,如下InitAndSelectNetworkRawSocket函数则是实现绑定套接字到特定网卡的实现流程,在代码中首先初始化并使用gethostname函数获取到当前主机的主机名...,当读者运行后会看到如下图所示的代码片段,此处笔者就选择三号网卡进行绑定操作,当绑定后此时套接字ID对应的则是特定的网卡,后续的操作均可针对此套接字ID进行,如下图所示;图片当读者有了设置混杂模式的功能则下一步就是抓包了

46740

18.1 Socket 原生套接字抓包

原生套接字抓包的实现原理依赖于Windows系统中提供的ioctlsocket函数,该函数可将指定的网卡设置为混杂模式,网卡混杂模式(Promiscuous Mode)是常用于计算机网络抓包的一种模式,...启用混杂模式的主要用途之一是网络抓包分析,使用混杂模式可以捕获网络中所有的数据包,且不仅仅是它所连接的设备的通信数据包。...cmd: 操作代码,用于控制对套接字的特定操作。 argp: 与特定请求代码相关联的参数指针。此参数的具体含义取决于请求代码。...要实现抓包前提是需要先选中绑定到那个网卡,如下InitAndSelectNetworkRawSocket函数则是实现绑定套接字到特定网卡的实现流程,在代码中首先初始化并使用gethostname函数获取到当前主机的主机名...,当读者运行后会看到如下图所示的代码片段,此处笔者就选择三号网卡进行绑定操作,当绑定后此时套接字ID对应的则是特定的网卡,后续的操作均可针对此套接字ID进行,如下图所示; 当读者有了设置混杂模式的功能则下一步就是抓包了

42720
  • UNIX域协议(命名套接字)

    这里主要介绍命名UNIX域套接字 1.什么是UNIX域套接字 Unix域协议并不是一个实际的协议族,而是在单个主机上执行客户/服务通信的一种方式。是进程间通信(IPC)的一种方式。...它提供了两类套接字:字节流套接字(有点像TCP)和数据报套接字(有点像UDP) UNIX域数据报服务是可靠的,不会丢失消息,也不会传递出错。...2.UNIX域协议特点 1)UNIX域套接字域TCP套接字相比,在同一台主机的传输速度前者是后者的两倍。...UNIX域套接字仅仅复制数据,并不执行协议处理,不需要添加或删除网络报头,无需计算校验和,不产生顺序号,也不需要发送确认报文 2)UNIX域套接字可以在同一台主机上各进程之间传递文件描述符 3)UNIX...域套接字域传统套接字的区别是用路径名表示协议族的描述 3.UNIX域地址结构 #define UNIX_PATH_MAX 128 struct sockaddr_un{ sa_family_t sun_family

    3.2K100

    UNIX域协议(无名套接字)

    关于什么是UNIX域套接字可以参考:https://cloud.tencent.com/developer/article/1018893 这里主要介绍非命名的UNIX域套接字的用法。...功能:创建一个全双工的流管道 参数: domain:协议家族,为AF_LOCAL或AF_UNIX type:套接字类型。可以是SOCK_STREAM或者SOCK_DGRAM。...为0 sv:返回套接字对,这个是输出参数。返回的两个描述符都是可读可写的。 返回值:成功返回0,失败返回-1....注意:由于创建的每个套接字都是没有名字的,这就意味着无关进程不能使用它们。 2.一个简单的例子: 父进程给子进程发送一个数据给子进程,子进程收到数据后最数据进行加一操作,再发回给父进程。...2)普通的TCP UDP套接字是不能传递文件描述符的

    78670

    linux抓本来端口包,Linux抓包

    1、如果要抓eth0的包,命令格式如下: tcpdump -i eth0 -w /tmp/eth0.cap 2、如果要抓192.168.1.20的包,命令格式如下: tcpdump -i etho host...192.168.1.20 -w /tmp/temp.cap 3、如果要抓192.168.1.20的ICMP包,命令格式如下: tcpdump -i etho host 192.168.1.20 and...port 10002 -w /tmp/port.cap 5、假如要抓vlan 1的包,命令格式如下: tcpdump -i eth0 port 80 and vlan 1 -w /tmp/vlan.cap...6、假如要抓pppoe的密码,命令格式如下: tcpdump -i eht0 pppoes -w /tmp/pppoe.cap 7、假如要抓eth0的包,抓到10000个包后退出,命令格式如下: tcpdump...-i eth0 -c 10000 -w /tmp/temp.cap 8、在后台抓eth0在80端口的包,命令格式如下: nohup tcpdump -i eth0 port 80 -w /tmp/temp.cap

    5.8K40

    Linux网络套接字(二)

    返回值:返回一个新的套接字描述符。...首先是写出服务器的代码,代码的思路是这样的: ①首先为服务器创建套接字,因为这个是TCP协议,TCP是面向连接的,因此服务器是需要进入监听状态才能让客户端连接,所以使用socket接口创建出来的套接字是属于监听套接字...②创建完监听套接字后,开始绑定IP和端口号。先创建出服务器的sockaddr_in结构(因为使用AF_INET协议),然后填充结构体,填充的是使用何种协议域,IP和端口号。...=2) { Usage(argv[0]); return 1; } //tcp_server //1.创建套接字,此套接字为监听套接字,用于绑定和监听 int listen_sock...=2) { Usage(argv[0]); return 1; } //tcp_server //1.创建套接字,此套接字为监听套接字,用于绑定和监听 int listen_sock

    2K30

    Linux网络-套接字编程基础

    Linux网络编程套接字 零、前言 一、网络基础知识 1、源IP地址和目的IP地址 2、源MAC地址和目的MAC地址 3、认识端口号 4、PORT VS PID 5、TCP和UDP协议 6、网络字节序...二、socket编程接口 1、sockaddr结构 2、socket 常见API 零、前言 本章就Linux网络编程进行概念及接口学习,下一篇则是简单的进行上手网络套接字编程 一、网络基础知识 1...位的长整数从主机字节序转换为网络字节序 如果主机是小端字节序,这些函数将参数做相应的大小端转换然后返回;如果主机是大端字节序,这些函数不做转换,将参数原封不动地返回 二、socket编程接口 1、sockaddr结构 套接字不仅支持跨网络的进程间通信...,还支持本地的进程间通信(域间套接字) 因此套接字提供了sockaddr_in结构体和sockaddr_un结构体,其中sockaddr_in结构体是用于跨网络通信的,而sockaddr_un结构体是用于本地通信的...为了让套接字的网络通信和本地通信能够使用同一套函数接口,于是就出现了sockeaddr结构体,该结构体与sockaddr_in和sockaddr_un的结构都不相同,但这三个结构体头部的16个比特位都是一样的

    1.5K20

    Linux网络-TCPUDP套接字编程

    零、前言 本章主要是对套接字网络编程的一个学习,目标是能够基本的进行套接字编程 一、UDP套接字 1、创建套接字 无论是服务端还是客户端,进行网络编程需要做的第一件事就是创建套接字 socket...函数函数原型: int socket(int domain, int type, int protocol); 解释: domain:创建套接字的域或者叫做协议家族,也就是创建套接字的类型。...相比于UDP套接字来说,TCP套接字与之在一些地方是相同的,但是TCP的特点是面向链接的流式套接字,所以还是有很大的区别的 1、创建套接字 同样的tcp的服务端和客户端首先第一件事是创建套接字文件...这是一个输入输出型参数 返回值:获取连接成功返回接收到的套接字的文件描述符,获取连接失败返回-1,同时错误码会被设置 套接字文件之间的区别: socket函数创建的套接字文件:用于不断获取客户端发来的连接请求...,同文件的读写是一样是流式的,那么对于TCP来说,使用文件读写的方式进行读写套接字文件同样可以达到数据发送和接收的目的 读取套接字文件数据,即为接收对应套接字建立链接的远端发送来的消息;向套接字文件进行写入数据

    3.7K10

    Linux:网络编程套接字及UDP

    套接字的种类: 1、域间套接字(同一个机器内) struct sockaddr_un 2、原始套接字(网络工具)  原始套接字一般不关心传输层的东西,他一般是绕过传输层去考虑网络层和链路层,所以他一般被用来封装一些网络工具...1、首先要创建套接字 第一个参数  是套接字的域,AF_LOCAL是本地的,AF_INET是网络ipv4的 第二个参数  是套接字的类型  SOCK_STREAM是面向字节流的(TCP),SOCK_DGRAM...类型 (1)我们先创建出来之后,然后可以用bzero(有点像C语言的memset)将指针内容先清空然后再填充 (2)local.sin_family  表明这个通用类型是属于网络套接字还是域间套接字 (...全部代码: void Init()//创建服务器 { //1、首先第一步是创建套接字 第一个是套接字的域 第二个是面向数据段 第三个是协议类型 _sockfd...sizeof(local)); //将类型都清空 然后我们再填 local.sin_family=AF_INET;//family是用来表明这个类型是网络套接字还是域间套接字 local.sin_port

    11310

    linux网络编程之socket(十五):UNIX域套接字编程和socketpair 函数

    UNIX域套接字与TCP套接字相比较,在同一台主机的传输速度前者是后者的两倍。这是因为,IPC机制本质上是可靠的通讯,而网络协议是为不可靠的通讯设计的。...三、UNIX域套接字编程注意点 1、bind成功将会创建一个文件,权限为0777 & ~umask 2、sun_path最好用一个绝对路径 3、UNIX域协议支持流式套接口与报式套接口 4、UNIX...域流式套接字connect发现监听队列满时,会立刻返回一个ECONNREFUSED,这和TCP不同,如果监听队列满,会忽略到来的SYN,这导致对方重传SYN。...protocol: 协议类型 sv: 返回套接字对 返回值:成功返回0;失败返回-1 实际上socketpair 函数跟pipe 函数是类似的,也只能在同个主机上具有亲缘关系的进程间通信,但...即父进程持有sockfds[0] 套接字进行读写,而子进程持有sockfds[1] 套接字进行读写。 参考: 《Linux C 编程一站式学习》 《TCP/IP详解 卷一》 《UNP》

    3.6K00

    Linux实验八:流式套接字编程

    一、实验目的 1、深入理解 TCP/IP 模型相关概念; 2、掌握流式套接字 socket 相关的数据结构,如 sokkaddr,sockaddr_in 等; 3、掌握流式套接字通讯时常用的函数,如...在这个过程中,我们需要完成以下关键步骤: 创建套接字:利用socket()函数创建一个TCP套接字。 设置服务器地址:配置服务器的IP地址和端口号。...关闭套接字:在通信结束后,关闭套接字释放资源。...定义了监听套接字listen_fd和客户端套接字client_fd,以及服务器地址server_addr和客户端地址client_addr结构体。...六、实验结果 运行结果如下: 七、实验总结   在本次实验中,我们深入学习了如何在Linux环境下使用流式套接字(TCP套接字)来进行客户端-服务器通信。

    10310

    linux 进程抓包命令,linux抓包命令之tcpdump详解

    DenNqvX ] [ -c count ] [ -F file ] [ -i interface ] [ -r file ] [-s snaplen ] [ -w file ] [ expression ] 抓包选项...注意,是最终要获取这么多个包。例如,指定”-c 10″将获取10个包,但可能已经处理了100个包,只不过只有10个包是满足条件的包。-i interface:指定tcpdump需要监听的接口。...-s len:设置tcpdump的数据包抓取长度为len,如果不设置默认将会是65535字节。...其他功能性选项:-D:列出可用于抓包的接口。将会列出接口的数值编号和接口名,它们都可以用于”-i”后。-F:从文件中读取抓包的表达式。若使用该选项,则命令行中给定的其他表达式都将失效。...-w:将抓包数据输出到文件中而不是标准输出。可以同时配合”-G time”选项使得输出文件每time秒就自动切换到另一个文件。可通过”-r”选项载入这些文件以进行分析和打印。

    4.9K20

    linux如何抓包是什么,linux抓包命令是什么

    linux抓包命令是“tcpdump”,可以抓取流动在网卡上的数据包,可以将网络中传送的数据包的“头”完全截获下来提供分析;它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息...本教程操作环境:Red Hat Enterprise Linux 6.1系统、Dell G3电脑。 tcpdump命令是基于unix系统的命令行的数据报嗅探工具,可以抓取流动在网卡上的数据包。...-s len:设置tcpdump的数据包抓取长度为len,如果不设置默认将会是65535字节。...其他功能性选项: -D:列出可用于抓包的接口。将会列出接口的数值编号和接口名,它们都可以用于”-i”后。 -F:从文件中读取抓包的表达式。若使用该选项,则命令行中给定的其他表达式都将失效。...-w:将抓包数据输出到文件中而不是标准输出。可以同时配合”-G time”选项使得输出文件每time秒就自动切换到另一个文件。可通过”-r”选项载入这些文件以进行分析和打印。

    10.7K20

    面向对象之套接字(socket)和黏包

    一丶套接字(socket)   tcp是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端   基于UDP协议的socket   server端: import socket udp_sk =...socket.socket(type=socket.SOCK_DGRAM) #创建一个服务器的套接字 udp_sk.bind(('127.0.0.1',9000)) #绑定服务器套接字...udp_sk.sendto(b'hi',addr) # 对话(接收与发送) udp_sk.close() # 关闭服务器套接字...那粘包的成因是什么呢? 当发送端缓冲区的长度大于网卡的MTU时,tcp会将这次发送的数据拆成几个数据包发送出去。 MTU是Maximum Transmission Unit的缩写。...如果本机的MTU比网关的MTU大,大的数据包就会被拆开来传送,这样会产生很多数据包碎片,增加丢包率,降低网络速度。   那我们如何解决粘包呢?

    57020
    领券