域套接字-多客户端实现
我们在linux 应用开发中,如果需要实现进程间通信的多客户端接口,就需要引入select 和epoll 相关机制了,本文介绍下epoll的功能的实现。
多客户端使用场景,比如我们需要开发一个库接口,提供给客户调用,那么使用域套接字实现进程间通信,就必须在service端引入多路复用,否则库功能就只能被一个进程使用了。
代码实现:
注意事项:
socket service 地址被占用,bind urc service unix udp socket failure: Address already in use 报这个解决方法
- 删除 原地址文件
- 配置setsockopt(sockfd,SOL_SOCKET,SO_REUSEADDR,&on,sizeof(on)
service端
#include<stdio.h>
#include<stdlib.h>
#include<sys/socket.h>
#include<sys/types.h>
#include<unistd.h>
#include<string.h>
#include<sys/un.h>
#include<sys/epoll.h>
#define dbg_printf(...) printf("[%s.%d]",__func__,__LINE__);printf(__VA_ARGS__)
#define UNIX_SOCKET_FILE "/home/linux/test/socket/temp.file"
static int sockfd = 0;
static struct sockaddr_un servaddr,cliaddr;
int main(int argc, const char *argv[])
{
int ret = 0;
int connfd = 0;
sockfd = socket(AF_UNIX,SOCK_STREAM,0);
if(sockfd < 0 )
{
dbg_printf("socket error \n");
return -1;
}
if(access(UNIX_SOCKET_FILE,F_OK) == 0)
{
dbg_printf("remove unix socket file \n");
remove(UNIX_SOCKET_FILE);
}
memset(&servaddr,0,sizeof