unix domain IPC 进程间通信简析
Linux系统有多种进程间通信方式,如信号、消息队列、管道等,socket是其中一种,socket使用unix domain 模式进行进程间通信
//服务端代码
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <unistd.h>
#define UNIX_SERV "/tmp/unix_serv" //文件路径名
int main(void)
{
int sock_fd;
struct sockaddr_un serv;
struct sockaddr_un cli;
int ret;
socklen_t serv_len;
sock_fd = socket(AF_UNIX, SOCK_DGRAM, 0); //采用数据报协议
if(sock_fd < 0)
{
perror("fail to socket");
}
unlink(UNIX_SERV); //若文件 存在,则删除
memset(&serv, 0, sizeof(serv));
serv.sun_family = AF_UNIX; //Unix
strncpy(serv.sun_path, UNIX_SERV, sizeof(serv.sun_path)-1); //拷贝文件名
serv_len = sizeof(serv);
ret = bind(sock_fd, (struct sockaddr *)&serv, serv_len); //服务器需要绑定
if(ret == -1)
{
perror("fail to bind");
}
int recv_size;
char buf[1024];
socklen_t cli_len;
memset(&cli, 0, sizeof(cli));
cli_len = sizeof(cli);
while(1)
{
recv_size = recvfrom(sock_fd, buf, sizeof(buf), 0,
(struct sockaddr *)&cli, &cli_len);
if(recv_size > 0)
{
if(strncmp(buf, "exit", strlen("exit") ) == 0)
{
printf("client exit\n");
break;
}
buf[recv_size-1] = '\0';
printf("recv buf:%s from client\n", buf);
}
}
close(sock_fd);
unlink(UNIX_SERV);
return 0;
}
//客户端代码
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <unistd.h>
#define UNIX_SERV "/tmp/unix_serv" //服务端文件名
//注:客户端代码可以不绑定地址,如不绑定,则不需要客户端文件名;绑定客户端会生成客户端文件
#define UNIX_CLI "/tmp/unix_cli" //客户端文件名
int main(void)
{
int sock_fd;
struct sockaddr_un serv;
struct sockaddr_un cli;
int ret;
socklen_t serv_len;
socklen_t cli_len;
sock_fd = socket(AF_UNIX, SOCK_DGRAM, 0);
if(sock_fd < 0)
{
perror("fail to socket");
}
unlink(UNIX_CLI);
memset(&cli, 0, sizeof(cli));
memset(&serv, 0, sizeof(serv));
cli_len = sizeof(cli);
cli.sun_family = AF_UNIX;
strncpy(cli.sun_path, UNIX_CLI, sizeof(cli.sun_path)-1);
serv_len = sizeof(serv);
serv.sun_family = AF_UNIX;
strncpy(serv.sun_path, UNIX_SERV, sizeof(serv.sun_path)-1);
ret = bind(sock_fd, (struct sockaddr *)&cli, cli_len);
if(ret == -1)
{
perror("fail to bind");
}
int read_size;
int send_size;
char buf[1024];
while(1)
{
read_size = read(STDIN_FILENO, buf, sizeof(buf));
if(read_size > 0)
{
send_size = sendto(sock_fd, buf, read_size, 0,
(struct sockaddr *)&serv, serv_len);
if(serv_len > 0)
{
if(strncmp(buf, "exit", 4) == 0)
{
printf("client exit\n");
break;
}
buf[read_size-1] = '\0';
printf("send buf: %s\n", buf);
}
}
}
close(sock_fd);
unlink(UNIX_CLI);
return 0;
}
unix domain IPC 进程间通信简析的更多相关文章
- PHP 调用 Go 服务的正确方式 - Unix Domain Sockets
* { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...
- Unix domain socket IPC
UNIX Domain socket 虽然网络socket也可用于同一台主机的进程间通讯(通过lo地址127.0.0.1),但是unix domain socket用于IPC更有效率:不需要经过网络协 ...
- 【Unix编程】进程间通信(IPC)
进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息.IPC的方式通常有管道(包括无名管道和命名管道).消息队列.信号量.共享存储.Socket. ...
- Linux下的IPC-UNIX Domain Socket【转】
本文转载自:http://blog.csdn.net/guxch/article/details/7041052 一. 概述 UNIX Domain Socket是在socket架构上发展起来的用于同 ...
- 由一个简单需求到Linux环境下的syslog、unix domain socket
本文记录了因为一个简单的日志需求,继而对linux环境下syslog.rsyslog.unix domain socket的学习.本文关注使用层面,并不涉及rsyslog的实现原理,感兴趣的读者可以参 ...
- Unix domain socket 简介
Unix domain socket 又叫 IPC(inter-process communication 进程间通信) socket,用于实现同一主机上的进程间通信.socket 原本是为网络通讯设 ...
- Unix domain socket
转载:http://www.cnblogs.com/chekliang/p/3222950.html socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是 ...
- 【转】PHP实现系统编程(四)--- 本地套接字(Unix Domain Socket)
原文:http://blog.csdn.net/zhang197093/article/details/78143687?locationNum=6&fps=1 --------------- ...
- Envoy 基础教程:使用 Unix Domain Socket(UDS) 与上游集群通信
Envoy Proxy 在大多数情况下都是作为 Sidecar 与应用部署在同一网络环境中,每个应用只需要与 Envoy(localhost)交互,不需要知道其他服务的地址.然而这并不是 Envoy ...
随机推荐
- css中的@inport 与link
在html 代码中我们常常用分离的思想引入外部的css文件,常用的方法有2种,@import 语法: <style type="text/css" media="s ...
- list,map的疑问
代码: package com.wyl; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator ...
- html5 学习笔记
一.ie8及以下对html5相关语义标签的支持 <!-[if lt IE9]> <script src="html5.js"></script> ...
- From Ontology to Semantic Web
Ontology(本体论)用于描述事物的本质(Gruber,1995).这个词在人工智能.计算机语言以及数据库理论中扮演者越来越重要的作用.在实现上,本体论是概念化的详细说明,一个ontology往往 ...
- Android的BUG(四) - Android app的卡死问题
做android,免不了要去运行一些跑分程序,常用的跑分程序有quadrant(象限),nbench,安兔兔等.作为系统工程师,对这些跑分 程序都非常的不屑,这个只能是一个不客观的参考,但客户都喜欢拿 ...
- 关于std::string
主要注意的一个问题是:std::string 实际是类似一个 vector<char>的结构. 它里面是可以存放 ascii为0 的字符不算结尾 (否则 unicode方式的编码存放就有问 ...
- BZOJ 3685: 普通van Emde Boas树( 线段树 )
建颗权值线段树就行了...连离散化都不用... 没加读入优化就TLE, 加了就A掉了...而且还快了接近1/4.... ---------------------------------------- ...
- 快捷键accesskey
<!DOCTYPE html> <html> <body> <a href="http://www.w3school.com.cn/html/&qu ...
- ant 具体命令行展示代码
C:\Users\xutianhao>ant -hant [options] [target [target2 [target3] ...]]Options: -help, -h print t ...
- [转]CentOS_yum的详细使用方法
yum 是什么yum = Yellow dog Updater, Modified主要功能是更方便的添加/删除/更新RPM包.它能自动解决包的倚赖性问题.它能便于管理大量系统的更新问题 yum特点可以 ...