计算机操作系统基础 (十七)--- 进程同步之 Unix 域套接字
引言
本篇为第十七篇,进程同步之Unix域套接字。上一篇介绍了通过共享内存处理进程同步的问题,本文是实现进程同步的另一个方法---Unix域套接字
Unix域套接字
域套接字是一种高级的进程间通信的方法
Unix域套接字可以用于同一机器进程间通信
套接字(socket)原是网络通信中使用的术语
Unix系统提供的域套接字提供了网络套接字类似的功能
在前边了解到,共享内存需要额外的同步机制,来同步多个进程间的通信。Unix域套接字就不需要额外的机制来保证多个进程间通信的问题(其实我们在部署Nginx的时候,就会使用到unix域套接字)
Unix域套接字使用方法
左边为服务端,右边为客户端
下边是代码示例,客户端和服务端通过域套接字进行连接
服务端(server.cpp)
客户端(client.cpp)
运行server.cpp
运行cliet.cpp并发送消息
服务端接收到消息
域套接字提供的是一种可靠的信息传递,它相比共享内存,不需要维护多个进程去读取内存空间的机制。也就是说域套接字相比共享内存,它多了一些可靠性。从代码中可以看到client和server通信时,不需要额外的标记去管理同步的机制,使用上要简单一些
总结
提供了单机简单可靠的进程通信同步服务
只能在单机使用,不能跨机器使用(跨机器需要使用网络套接字)
在快速变化的技术中寻找不变,才是一个技术人的核心竞争力。知行合一,理论结合实践
版权声明: 本文为 InfoQ 作者【书旅】的原创文章。
原文链接:【http://xie.infoq.cn/article/bbfbb94630fb39404c1a9a16a】。文章转载请联系作者。
评论