美文网首页
第十七章 高级进程间通信

第十七章 高级进程间通信

作者: laidian | 来源:发表于2018-10-07 13:50 被阅读19次

UNIX域套接字

UNIX 域套接字用于在同一台计算机上运行的进程之间的通信

虽然因特网域套接字可用于 同一目的,但 UNIX 域套接字的效率更高

UNIX 域套接字提供流和数据报两种接口

UNIX 域套接字就像是套接字和管道的混合

可以使用它们面向网络的域套接 字接口或者使用 socketpair 函数来创建一对无命名的、相互连接的 UNIX 域套接字

#include <sys/sock.h>
int socketpair(int domain,int type,int protocol,int sockfd[2]);
sockpair(AF_UNIX,SOCK_DGRAM,0,fd)

fd_pipe

借助 UNIX 域套接字轮询 XSI 消息队列

XSI 消息队列的使用存在一个问题,即不能将它们和 poll 或者 select 一起使用,这是因为它们不能关联到文件描述符

套接字是和文件描述符相关联的,消息到达时,可以用套接字来通知

  1. 创建了一些消息队列和 UNIX 域套接字,并 为每个消息队列开启了一个新线程
  2. 然后它在一个无限循环中用 poll 来轮询选择一个套接字端点
  3. 当某个套接字可读时,程序可以从套接字中读取数据

命名UNIX域套接字

.sock文件

将地址绑定到 UNIX 域套接字,系统会用该路径名创建一个 S_IFSOCK 类型的文件

UNIX 域套接字的地址由 sockaddr_un 结构 表示

#include "apue.h"
#include <sys/socket.h>
#include <sys/un.h>

int main(void)
{
    int fd, size;
    struct sockaddr_un un;

    un.sun_family = AF_UNIX;
    strcpy(un.sun_path, "foo.socket");
    if ((fd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0)
        err_sys("socket failed");
    //确定绑定地址长度
    //先计算 sun_path 成员在 sockaddr_un 结构中的偏移量
    //然后将结果与路径名长度(不包括终止 null 字符)相加
    size = offsetof(struct sockaddr_un, sun_path) + strlen(un.sun_path);
    if (bind(fd, (struct sockaddr *)&un, size) < 0)
        err_sys("bind failed");
    printf("UNIX domain socket bound\n");
    exit(0);
}

唯一连接

apue种开发的三个函数

#include “apue.h"
int serv_listen(const char *name);
int serv_accept(int listenfd,uid_t *uidptr);
int cil_conn(const char *name);

传送文件描述符

在技术上,我们是将指向一个打开文件表项的指针从一个进程发送到另外一个进程。该指针 被分配存放在接收进程的第一个可用描述符项中

#include "apue.h"
int send_fd(int fd,int fd_to_send);
int send_err(int fd,int status,const char *errmsg);
int recv_fd(int fd,ssize_t (*userfunc)(int ,const void *,size_t));

open服务器进程v1

open服务器进程v2

相关文章

  • 第十七章 高级进程间通信

    UNIX域套接字 UNIX 域套接字用于在同一台计算机上运行的进程之间的通信 虽然因特网域套接字可用于 同一目的,...

  • linux进程间通信(1)

    一、进程通信概述 1、什么是进程间通信?什么是线程间通信? 进程间通信: 进程间通信就指的是用户空间中进程A与进程...

  • 操作系统拾遗--进程同步、互斥

    进程通信 进程通信--进程之间的信息交换,如同步、互斥。 进程通信分为: 低级通信方式:同步与互斥 高级通信方式:...

  • 第二十三章 进程间通信介绍(一)

    本章目标: 进程同步与进程互斥 进程间通信目的 进程间通信发展 进程间通信分类 进程间共享信息的三种方式 IPC对...

  • 进程间的通信

    进程间的通信主要分为本机器进程间的通信和不同机器间进程的通信。本文主要描述本机进程间的通信。 一、传统Linux的...

  • DBUS基础知识

    进程间使用D-Bus通信 D-Bus是一种高级的进程间通信机制,它由freedesktop.org项目提供,使用G...

  • 进程间通信

    进程间通信 进程空间相对独立,资源无法相互获取,此时在不同进程间通信需要专门方法 进程间通信就是在不同的进程间进行...

  • 进程间通信,线程间通信

    进程间通信 进程间通信又称IPC(Inter-Process Communication),指多个进程之间相互通信...

  • Android IPC机制

    IPC 即Inter-Process-Communication,含义是进程间通信/跨进程通信。是指多个进程间通信...

  • 进程管理(五)进程间通信、死锁

    (一)进程间通信 除了同步和互斥外,进程间还有其他的通信手段。 进程间的通信 --> IPC (InterProc...

网友评论

      本文标题:第十七章 高级进程间通信

      本文链接:https://www.haomeiwen.com/subject/asjlaftx.html