- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
sendmsg() 允许将辅助数据发送到另一个套接字,我想知道它是如何工作的。
1) 辅助数据是否与正常消息一起打包?
2) 如果是这样,远程接收套接字如何知道如何解析它?
3) 远程接收客户端如何检索这些辅助数据?
谢谢。
最佳答案
辅助数据不会在线发送 - 永远不会。对于 Unix 域套接字,辅助数据用于在进程之间发送或接收文件描述符以共享或负载平衡任务。注意:Unix 域套接字在同一台机器上运行的进程之间传输信息,而不是在不同机器上运行的进程之间传输信息。
同样,如果进程在不同的机器上运行:你的数据包不使用任何辅助概念将与在发送机器(或接收机器)上应用辅助概念时的数据包完全相同。因此,辅助数据不是随您的数据包一起提供的。
辅助数据用于接收从内核到用户空间应用程序的EXTRA数据包相关服务/信息,否则不可用。例如,假设机器 B 通过网络接收到一些数据包,您想知道数据包来自哪个入口接口(interface)?你怎么会知道这个?辅助数据来拯救。
辅助数据是在辅助控制缓冲区中设置的一种标志,并在调用 sendmsg()/recvmsg() 时传递给内核,它告诉内核当数据包发送或到达时,要提供哪些额外的服务/信息调用调用的应用程序。
辅助数据是内核和用户空间应用程序之间或同一台机器上的进程之间在 UNIX 套接字的情况下进行通信的方式。这不是电线上的数据包所具有的东西。
供您引用,下载代码示例here它在我的 ubuntu 机器上运行完美。辅助数据概念在 src/igmp_pkt_reciever.c
中演示。
关于linux - sendmsg() 中的辅助数据如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14128345/
我正在尝试在 Linux 中实现自己的传输层协议(protocol)以进行实验。我将使用套接字接口(interface)并使用 sock_register 添加我的协议(protocol)。对于 pr
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎偏离主题,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或 include a mini
我想知道内核如何使用这个 sendmsg() 函数填充 ip header 。 sendmsg() 函数用于在较少的连接中发送消息通过套接字。我们向该函数传递 3 个参数。它们是,文件描述符,msgh
首先是一些上下文:有一个主程序(一个网络服务器),它派生了一堆工作人员,并等待传入的连接。当它接受一个时,它通过 sendmsg() 原语将套接字描述符发送给其中一个工作人员。 这是应该发送描述符
我不是 C 编程专家,但我正在尝试使用 sendmsg() 和 recvmsg() 编写一个相当简单的程序来在客户端和服务器(两者都在同一台机器上,所以基本上我是在向本地主机发送消息)。 在初始化所需
如您所知,sendmsg 有这样的声明: int sendmsg(int s, const struct msghdr *msg, int flags); 和msghdr结构有这种形式: struct
sendmsg() 允许将辅助数据发送到另一个套接字,我想知道它是如何工作的。 1) 辅助数据是否与正常消息一起打包? 2) 如果是这样,远程接收套接字如何知道如何解析它? 3) 远程接收客户端如何检
我正在将项目从 Delphi 2006 升级到 Delphi XE2,并且遇到了编译错误没有可以使用这些参数调用的“SendMsg”的重载版本。这是问题所在的代码。 procedure TMessag
我使用linux 3.x和现代glibc(2.19)。 我想发送几个以太网帧,而无需从内核/用户空间来回切换。 我有MTU = 1500,我想发送800 KB。 我这样初始化接收者地址: struct
我正在使用 unix 域套接字在不同进程之间发送打开的文件描述符。 Unix 域套接字工作正常,但是当我使用 sendmsg 发送文件描述符时,发生了一些奇怪的事情。该函数在 sendmsg 之后返回
我正在编写一个程序,使用 sendmsg 在两个进程之间传递文件描述符和 recvmsg通过域套接字。对于发送文件描述符,附加数据包含在 msghdr.msg_iov 中和 msghdr.msg_io
在 Linux 中运行 ldapsearch 实用程序时,“sendmsg”函数失败并出现错误代码 9。错误代码 9 代表什么?手册页未提供有关错误代码的信息。 最佳答案 您可以在此页面中找到所有错误
在 IPv4 的情况下,我看到 sendmsg 有以下行为: 假设10.1.2.3是客户端IP。10.1.2.10配置在客户端的其中一个接口(interface)上。 在UDP报文中,在数据包中加入如
我正在尝试使用 C 通过 sendmsg 发送原始以太网数据包。此代码成功打开原始数据包套接字,尝试用单个字节数组 (char message[]) 填充 struct iovec,然后用目标地址、地
我拥有的是进程 ID 和来自该进程的文件描述符。除了 sendmsg 之外,还有什么方法可以复制(或重新打开)该进程的文件描述符以供 Linux 中的另一个进程使用? Windows 有用于此目的的
如果为 in_pktinfo.ipi_ifindex 设置了值,则使用 sendmsg() 可以指定从哪个接口(interface)发送数据报。 如果数据包是对使用 recvmsg() 接收到的数据报
我建立了一个简单的客户端和服务器程序,使用 TCP 套接字进行通信。服务器等待客户端连接,并回复是否收到客户端的消息。以下是代码在服务器和客户端中的实现方式: 服务端代码: listen(sockf
我使用 cmsg 在 linux socket tx 上激活时间戳。 ssize_t sendWithOptions (int sd, std::vector &payload, uint32_t d
我在 UDP 套接字编程中遇到了一些问题。我想使用 sendmsg() 和 recvmsg() API 以便能够在客户端和服务器之间进行通信。客户端代码返回错误号 105 {ENOBUFS}。我不知道
我正在编写自己的 DNS 黑洞来阻止我家庭网络上的广告和恶意软件。我意识到这种类型的程序已经存在,但我想学习这个过程并编写自己的程序。从 Linux 文档来看,似乎可以告诉 sendmsg() 使用不
我是一名优秀的程序员,十分优秀!