Linux下进程间通信方式 进程间传递文件描述符——sockpair()函数

通过socketpair函数会生成两个类似于套接字的文件描述符,进程可以通过这两个文件描述符进行通信,

写入的一方可以通过msghdr结构体来进行文件描述符的发送,msghdr结构体其中有两个成员分别是iovec* iov和cmsghdr* cmsg,第一个成员无所谓,可以填充任意数据,就是要按照格式来填写,我们主要通过第二个成员来进行传递文件描述符,当结构体准备好了后就可以通过sendmsg函数发送

cpp 复制代码
int pipes[2];
socketpair(AF_LOCAL,SOCK_STREAM,0,pipes);

//写入方
msghdr msg;
iovec iov[2];
iov[0].iov_base = (char*)"edoyun";
iov[0].iov_len = 7;
iov[1].iov_base = (char*)"jueding";
iov[1].iov_len = 8;
msg.msg_iov = iov;
msg.msg_iovlen = 2;
//接下来才是真正要传递的数据
cmsghdr* cmsg = (cmsghdr*)calloc(1,CMSG_LEN(sizeof(int)));
if (cmsg == NULL)return -1;
cmsg->cmsg_len = CMSG_LEN(sizeof(int));
cmsg->cmsg_level = SOL_SOCKET;
cmsg->cmsg_type = SCM_RIGHTS;
*(int*)CMSG_DATA(cmsg) = fd;
msg.msg_control = cmsg;
msg.msg_controllen = cmsg->cmsg_len;
ssize_t ret = sendmsg(pipes[1], &msg, 0);
free(cmsg);

接受的一方是一样的,就是反着来进行解析就好了

cpp 复制代码
//接收方
msghdr msg;
iovec iov[2];
char buf[][10] = { "","" };
iov[0].iov_base = buf[0];
iov[0].iov_len = sizeof(buf[0]);
iov[1].iov_base = buf[1];
iov[1].iov_len = sizeof(buf[1]);
msg.msg_iov = iov;
msg.msg_iovlen = 2;

cmsghdr* cmsg = (cmsghdr*)calloc(1, CMSG_LEN(sizeof(int)));
if (cmsg == NULL)return -1;
cmsg->cmsg_len = CMSG_LEN(sizeof(int));
cmsg->cmsg_level = SOL_SOCKET;
cmsg->cmsg_type = SCM_RIGHTS;
msg.msg_control = cmsg;
msg.msg_controllen = CMSG_LEN(sizeof(int));
ssize_t ret = recvmsg(pipes[0], &msg, 0);
fd = *(int*)CMSG_DATA(cmsg);
相关推荐
剑神一笑1 小时前
Linux pgrep 命令详解:按名称查找进程 PID 的高效方法
linux·运维·chrome
Lumbrologist1 小时前
【零基础部署】Docker 部署 CrewAI 多 Agent 编排框架保姆级教程
运维·docker·容器
yyuuuzz1 小时前
独立站的技术基础与常见运维问题
大数据·运维·服务器·网络·数据库·aws
剑神一笑1 小时前
Linux killall 命令详解:按进程名批量终止进程的原理与实践
linux·运维·chrome
雅菲奥朗1 小时前
企业级 AI 自动化|OpenClaw 龙虾实战与认证
运维·人工智能·自动化·openclaw
江华森3 小时前
Ansible 自动化运维:从入门到实战
运维·自动化·ansible
宋浮檀s5 小时前
应急响应——Web漏洞:命令执行+SSRF+弱口令
运维·数据库·sql·网络安全·oracle·应急响应
日取其半万世不竭5 小时前
iftop、nethogs 和 nload:Linux 服务器网络流量实时监控工具介绍
linux·运维·服务器
mounter6255 小时前
Linux 内核资源管理:控制组(cgroup)的演进与“策略组”新提案
linux·运维·服务器·cgroup·kernel
bksczm5 小时前
文件在磁盘中的存储方式
linux·运维·服务器