《APUE》读书笔记-第十七章高级进程间通信

 本章主要介绍了基于STREAM的管道和UNIX域套接字,这些IPC可以在进程间传送打开文件描述符。服务进程可以使用它们的打开文件描述符与指定的名字相关联,客户进程可以使用这些名字与服务器进程通信。

1、基于STREAMS的管道

  STREAMS pipe是一个双向(全双工)管道,单个STREAMS管道就能向父、子进程提供双向的数据流。如下图所示:


《APUE》读书笔记-第十七章高级进程间通信

1.2命名的STREAMS管道

  管道仅在相关进程之间使用,例如子进程集成父进程的管道。无关进程可以使用FIFO进行通信,但是这仅仅提供单向通信。STREAMS机制提供了一种有效的途径,使得进程可以给予管道一个文件系统的名字,避免了单向FIFO的问题。操作函数原型如下:

#include <stropts.h> 
int fattach(int fildes, const char *path);  //给STREAMS管道一个系统文件中的名字
int fdetach(const char *path); //撤销STREAMS管道文件与文件系统中名字的关联

2、UNIX域套接字

  UNIX域套接字用于在同一台机器上运行的进程之间的通信,UNIX域套接字仅仅复制数据,不执行协议处理,不需要添加或删除网络报头,无需计算校验和,不要产生顺序号,无需发送确认报文。UNIX域套接字是套接字和管道之间的结合物,提供流和数据报两种接口。

UINX域套接字的好处:

(1)在同一台主机上进行通信时,是不同主机间通信的两倍

(2)UINX域套接口可以在同一台主机上,不同进程之间传递套接字描述符

(3)UINX域套接字可以向服务器提供客户的凭证(用户id或者用户组id)

UINX域套接字使用的地址通常是文件系统中一个文件路径,这些文件不是不同的文件,只能作为域套接字通信,不能读写。创建函数如下:

#include <sys/socket.h>
int socketpair(int domain, int type, int protocolint " sv [2]);

2.1命令UNIX域套接字

  UNIX域套接字的地址有sockaddr_run结构表示。

  #define UNIX_PATH_MAX 108
  struct sockaddr_un {
    sa_family_t sun_family; /* AF_UNIX */
    char sun_path[UNIX_PATH_MAX]; /* pathname };

2.2唯一连接

  服务器进程可以使用标准bind、listen和accept函数为客户进程安排一个唯一的UNIX域连接,客户进程使用connect与服务器进程联系,服务器进程接受了connect请求后,在服务器进程和客户进程之间就存在了唯一的连接。