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);
相关推荐
zhilin_tang11 小时前
Linux IPC 为什么要这么架构
linux·c语言·架构
WIN赢12 小时前
【UI自动化相关】
运维·自动化
notion202514 小时前
Optuna 黑科技自动化超参数优化框架详解
运维·科技·其他·自动化
Wang's Blog15 小时前
Linux小课堂: 网络配置详解之DHCP动态分配与静态IP地址设置
linux·网络·tcp/ip
葛小白115 小时前
C#数据类型:string简单使用
服务器·数据库·c#
CS Beginner17 小时前
【Linux】Tomcat基本配置
linux·运维·tomcat
..Move...17 小时前
快速搭建Docker私有仓库指南
运维·docker·容器
小小的木头人18 小时前
Windows Docker desktop 部署
运维·kafka
黑翼杰克斯18 小时前
如何裁剪u-boot,保留其必要功能,使体积尽可能小
linux·1024程序员节
fat house cat_19 小时前
【netty】基于主从Reactor多线程模型|如何解决粘包拆包问题|零拷贝
java·服务器·网络·netty