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);
相关推荐
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐3 天前
Linux内存扩容指南
linux
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
用户805533698034 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297914 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
乘云数字DATABUFF4 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
Web3探索者6 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo6 天前
Linux系统中网线与USB网络共享冲突
linux
荣--6 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森6 天前
动手实战学 Docker — 从零到集群编排完全指南
运维