C/S架构学习之基于UDP的本地通信(服务器)

  • 基于UDP的本地通信(服务器):
  • 创建流程:
  • 一、创建数据报式套接字(socket函数):
c 复制代码
		int sock_fd = socket(AF_UNIX,SOCK_DGRAM,0);
	    if(-1 == sock_fd)
	    {
	        perror("socket error");
	        exit(-1);
	    }
  • 二、创建服务器和客户机的本地网络信息结构体并填充服务器本地网络信息结构体 (struct sockaddr_un):
  • 本地网络信息结构体:
c 复制代码
	#include <sys/un.h>
	struct sockaddr_un {
	    sa_family_t sun_family;               //AF_UNIX
	    char        sun_path[108];            //pathname
	};
c 复制代码
		struct sockaddr_un serveraddr,clientaddr;
	    socklen_t serveraddr_len = sizeof(serveraddr);
	    socklen_t clientaddr_len = sizeof(clientaddr);
	
	    memset(&serveraddr,0,serveraddr_len);
	    memset(&clientaddr,0,clientaddr_len);
	
	    serveraddr.sun_family = AF_UNIX;
	    strcpy(serveraddr.sun_path,"./udpserver");
  • 三、绑定数据报式套接字(bind函数):
c 复制代码
		if(-1 == bind(sock_fd,(struct sockaddr *)&serveraddr,serveraddr_len))
	    {
	        perror("bind error");
	        exit(-1);
	    }
  • 四、服务器端收发数据(recvfrom函数、sendto函数):
c 复制代码
            memset(buf,0,sizeof(buf));
	
	        int ret1 = recvfrom(sock_fd,buf,sizeof(buf),0,(struct sockaddr*)&clientaddr,&clientaddr_len);
	        if(-1 == ret1)
	        {
	            perror("recvfrom error");
	            exit(-1);
	        }
	        printf("客户端[%s]发来消息[%s]\n",clientaddr.sun_path,buf);
	
	        //发送应答消息
	        strcat(buf,"---------k");
	
	        int ret2 = sendto(sock_fd,buf,sizeof(buf),0,(struct sockaddr *)&clientaddr,clientaddr_len);
	        if(-1 == ret2)
	        {
	            perror("sendto error");
	            exit(-1);
	        }
	
  • 五、关闭套接字(close函数):
c 复制代码
	close(sock_fd);
  • 示例代码:
c 复制代码
	#include <stdio.h>
	#include <string.h>
	#include <stdlib.h>
	
	#include <sys/socket.h>
	#include <sys/types.h>
	
	#include <unistd.h>
	#include <stdbool.h>
	#include <sys/un.h>
	
	#include <arpa/inet.h>
	#include <netinet/ip.h>
	
	int main(int argc, char const *argv[])
	{
	    //创建套接字
	    int sock_fd = socket(AF_UNIX,SOCK_DGRAM,0);
	    if(-1 == sock_fd)
	    {
	        perror("socket error");
	        exit(-1);
	    }
	    //填充网络信息结构体
	
	    struct sockaddr_un serveraddr,clientaddr;
	    socklen_t serveraddr_len = sizeof(serveraddr);
	    socklen_t clientaddr_len = sizeof(clientaddr);
	
	    memset(&serveraddr,0,serveraddr_len);
	    memset(&clientaddr,0,clientaddr_len);
	
	    serveraddr.sun_family = AF_UNIX;
	    strcpy(serveraddr.sun_path,"./udpserver");
	
	
	    //绑定套接字
	    if(-1 == bind(sock_fd,(struct sockaddr *)&serveraddr,serveraddr_len))
	    {
	        perror("bind error");
	        exit(-1);
	    }
	
	    printf("基于UDP的本地通信服务器启动!!!\n");
	
	    char buf[128] = {0};
	    //收发数据
	    while(true)
	    {
	        memset(buf,0,sizeof(buf));
	
	        int ret1 = recvfrom(sock_fd,buf,sizeof(buf),0,(struct sockaddr*)&clientaddr,&clientaddr_len);
	        if(-1 == ret1)
	        {
	            perror("recvfrom error");
	            exit(-1);
	        }
	        printf("客户端[%s]发来消息[%s]\n",clientaddr.sun_path,buf);
	
	        //发送应答消息
	        strcat(buf,"---------k");
	
	        int ret2 = sendto(sock_fd,buf,sizeof(buf),0,(struct sockaddr *)&clientaddr,clientaddr_len);
	        if(-1 == ret2)
	        {
	            perror("sendto error");
	            exit(-1);
	        }
	
	
	    }
	    //关闭套接字
	    close(sock_fd);
	
	    return 0;
	}
  • 运行结果:
c 复制代码
	基于UDP的本地通信服务器启动!!!
	客户端[./udpclient]发来消息[hello]
	客户端[./udpclient]发来消息[I Love China!!!]
	客户端[./udpclient]发来消息[miss U]
  • 特别注意:
  • strcpy(serveraddr.sun_path,"./udpserver");udpserver文件套接字文件
  • 如下所示:
c 复制代码
	srwxrwxr-x 1 linux linux     0 11月 11 01:18 udpserver
相关推荐
Lei活在当下9 小时前
【业务场景架构实战】4. 支付状态分层流转的设计和实现
架构·android jetpack·响应式设计
架构师沉默12 小时前
设计多租户 SaaS 系统,如何做到数据隔离 & 资源配额?
java·后端·架构
kfyty72516 小时前
不依赖第三方,不销毁重建,loveqq 框架如何原生实现动态线程池?
java·架构
刘立军17 小时前
本地大模型编程实战(33)用SSE实现大模型的流式输出
架构·langchain·全栈
一直_在路上18 小时前
Go 语言微服务演进路径:从小型项目到企业级架构
架构·go
christine-rr20 小时前
linux常用命令(4)——压缩命令
linux·服务器·redis
東雪蓮☆21 小时前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
2303_Alpha21 小时前
SpringBoot
笔记·学习
乌萨奇也要立志学C++21 小时前
【Linux】进程概念(二):进程查看与 fork 初探
linux·运维·服务器
智能化咨询21 小时前
Kafka架构:构建高吞吐量分布式消息系统的艺术——进阶优化与行业实践
分布式·架构·kafka