第十七章 高级进程间通信

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,601评论 18 139
  • 一、进程间通信的概念 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间...
    TyiMan阅读 165,722评论 16 318
  • 进程间通信 进程间通信即IPC(InerProcess Communication)Unix ipc 已经是而且继...
    千里山南阅读 454评论 0 2
  • 必备的理论基础 1.操作系统作用: 隐藏丑陋复杂的硬件接口,提供良好的抽象接口。 管理调度进程,并将多个进程对硬件...
    drfung阅读 3,525评论 0 5
  • 本期的世界孤独大会果不其然,又只有一个人参加。 加西亚马尔克斯 没有观众,没有评委,没有媒体,没有颁奖嘉宾,没有获...
    吊燈下的幽灵馬阅读 207评论 0 2