Linux socket本地进程间通信之UDP
看了其他的很多是tcp方式,断开重连存在问题,个人感觉没这个方便,这里进行记录。
当套接字用于本地通信时,可以使用结构体struct sockaddr_un描述一个本地地址。
1 struct sockaddr_un{
2 unsigned short sun_family; /*协议类型*/
3 char sun_path[108]; /*套接字文件路径*/
4 };
在本地通信中,每个套接字文件代表一个本地地址。
UNIX域用户数据报套接字服务器端流程如下:
(1)创建UNIX域数据报套接字;socket(AF_LOCAL, SOCK_DGRAM, 0)
(2)填充本地信息结构体(服务器);struct sockaddr_un
(3)绑定本地地址(服务器的地址信息);bind( )
(4)接收客户端的数据;recvfrom( )
(5)发送数据给客户端;sendto( )
服务器端代码如下:
server.c
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
#include<sys/socket.h>
#include<arpa/inet.h>
#include<netinet/in.h>
#include<string.h>
#include<sys/un.h>
#include<stdlib.h>
#define N 64
int main(int argc, const char *argv[])
{
int sockfd;
struct sockaddr_un serveraddr, clientaddr;
char buf[N];
socklen_t len = sizeof(clientaddr);
sockfd = socket(AF_LOCAL, SOCK_DGRAM, 0);
if(sockfd < 0)
{
perror("fail to sockfd");
return -1;
}
serveraddr.sun_family = AF_LOCAL;
strcpy(serveraddr.sun_path, "mysocket");
unlink(serveraddr.sun_path);
if(bind(sockfd, (struct sockaddr*)&serveraddr, sizeof(serveraddr)) < 0)
{
perror("fail to bind");
return -1;
}
while(1)
{
if(recvfrom(sockfd, buf, N, 0, (struct sockaddr*)&clientaddr, &len) < 0)
{
perror("fail to recvfrom");
return -1;
}
if(strncmp(buf, "quit", 4) == 0)
{
break;
}
buf[strlen(buf) - 1] = '\0';
printf("buf:%s\n", buf);
strcat(buf, "++++----");
if(sendto(sockfd, buf, N, 0, (struct sockaddr*)&clientaddr, sizeof(clientaddr)) < 0)
{
perror("fail to sendto");
return -1;
}
}
close(sockfd);
return 0;
}
UNIX域用户数据报套接字客户端流程如下:
(1)创建UNIX域数据报套接字;socket(AF_LOCAL, SOCK_DGRAM, 0)
(2)填充本地信息结构体(服务器端和客户端);struct sockaddr_un
(3)绑定本地地址(客户端的地址信息);bind( )
(4)发送数据给服务器端;sendto( )
(5)接收服务器端的数据;recvfrom( )
客户端代码如下:
client.c
#include<stdio.h>
#include<stdlib.h>
#include<sys/types.h>
#include<unistd.h>
#include<sys/socket.h>
#include<arpa/inet.h>
#include<netinet/in.h>
#include<sys/un.h>
#include<string.h>
#define N 64
int main(int argc, const char *argv[])
{
int sockfd;
char buf[N];
struct sockaddr_un serveraddr, clientaddr;
sockfd = socket(AF_LOCAL, SOCK_DGRAM, 0);
if(sockfd < 0)
{
perror("fail to sockfd");
return -1;
}
serveraddr.sun_family = AF_LOCAL;
strcpy(serveraddr.sun_path, "mysocket");
clientaddr.sun_family = AF_LOCAL;
strcpy(clientaddr.sun_path, "socket");
unlink(clientaddr.sun_path);
if(bind(sockfd, (struct sockaddr*)&clientaddr, sizeof(clientaddr)) < 0)
{
perror("fail to bind");
return -1;
}
while(1)
{
printf("<client>");
fgets(buf, N, stdin);
if(sendto(sockfd, buf, N, 0, (struct sockaddr*)&serveraddr, sizeof(serveraddr)) < 0)
{
perror("fail to sendto");
return -1;
}
if(strncmp(buf, "quit", 4) == 0)
{
break;
}
if(recvfrom(sockfd, buf, N, 0, NULL, NULL) < 0)
{
perror("fail to recvfrom");
return -1;
}
printf("buf:%s\n", buf);
}
close(sockfd);
return 0;
}