关于UDP服务器客户端编程流程介绍

目录
  • UDP编程流程
  • UDP服务端代码实现
  • UDP客户端代码实现
  • UDP服务端客户端代码详解

UDP编程流程

UDP提供的是无连接、不可靠的、数据报服务

UDP是尽最大能力进行传输,但是并不能保证可靠性,TCP的可靠性是因为一系列的机制保证可靠性,UDP丢包并不会重发,两种协议并没有优略之分,要区分不同的场景来区分,比如:进行文件传输,不能有数据丢失,TCP协议就更合

适,而进行实时视频通话,UDP会根据恒定的速率进行发送,这样的情况容许部分数据的丢失去追求更好的实时性,所以UDP更合适

流程:首先服务端与客户端都需要套接字的创建socket()(UDP并没有严格意义上的服务端与客户端),然后服务端需要确定ip与端口bind(),等待接收接收数据recvfrom()(会记录对方的ip和端口),在这里我们并没有跟某个客户端进行连接,只是接收发送过来的数据,客户端发送数据sendto()(需要指定ip与端口),因为UDP并不像TCP建立连接,通过文件描述符来识别客户端,只能通过发送与接收时识别ip与端口的方式来区分不同的数据,收发结束关闭套接字close()

UDP服务端代码实现

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>

int main()
{
	//创建套接字
	//参数:
	//AF_INET ipv4
	//SOCK_DGRAM UDP使用的数据报服务类型 (SOCK_STREAM 流式套接字TCP使用的服务类型
	//标志位 一般给 0
	int sockfd = socket(AF_INET,SOCK_DGRAM,0);
	assert(sockfd != -1);

	//创建套接字地址结构
	struct sockaddr_in saddr,caddr;
	memset(&saddr,0,sizeof(saddr));
	saddr.sin_family = AF_INET;
	saddr.sin_port = htons(6000);
	saddr.sin_addr.s_addr = inet_addr("127.0.0.1");

	//命名套接字
	int res = bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));
	assert(res != -1);

	while(1)
	{
		int len = sizeof(caddr);//这里专门存放在len中,是因为在recvfrom的时候接收一个指针
		char buff[128] = {0};

		//接受数据
		//参数:
		//服务端套接字
		//存放数据
		//存放大小
		//标志位 一般给0
		//存放客户端地址信息(ip与端口)
		//caddr的大小
		recvfrom(sockfd,buff,127,0,(struct sockaddr*)&caddr,&len);
		printf("buff=%s\n",buff);

		//发送数据
		//参数:
		//服务端套接字
		//发送的数据
		//发送数据大小
		//标志位 一般给0
		//发送目标的地址信息
		//地址信息的大小
		sendto(sockfd,"ok",2,0,(struct sockaddr*)&caddr,sizeof(caddr));
	}
	//关闭套接字
	close(sockfd);
}

UDP客户端代码实现

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>

int main()
{
	int sockfd = socket(AF_INET,SOCK_DGRAM,0);
	assert(sockfd != -1);

	//只需要指定服务器的ip与端口,客户端自己的ip与端口由系统自动指定
	struct sockaddr_in saddr;
	memset(&saddr,0,sizeof(saddr));
	saddr.sin_family = AF_INET;
	saddr.sin_port = htons(6000);
	saddr.sin_addr.s_addr = inet_addr("127.0.0.1");

	while(1)
	{
		char buff[128] = {0};
		printf("input:\n");
		fgets(buff,128,stdin);

		if(strncmp(buff,"end",3) == 0)
		{
			break;
		}

		sendto(sockfd,buff,strlen(buff),0,(struct sockaddr*)&saddr,sizeof(saddr));
		memset(buff,0,128);
		int len = sizeof(saddr);
		recvfrom(sockfd,buff,127,0,(struct sockaddr*)&saddr,&len);
		//占用了saddr存放获取对方的ip与端口,实际上并没有改变都是一样的
		printf("buff=%s\n",buff);
	}
	close(sockfd);
}

UDP服务端客户端代码详解

执行服务端与客户端的代码

当我们打开多个窗口,启动多个客户端向服务端发送数据

UDP服务端的接收只是根据是否有数据发送过来,只要有发送过来的数据就进行接收,并不进行连接,即使将服务端关闭重新开启,使用原本的客户端依旧可以进行发送数据,因为他们本身之间并不存在相互的连接

假如将,服务端进行关闭不重启,客户端发送依旧发送出去sendto()不阻塞,但是会阻塞在recvfrom()这一步,简单的说就是服务器只管接收数据或者向发送方发送数据,无论是谁都可以向其发送数据且无需任何连接

如果我们将服务端代码进行修改

我们再通过客户端向服务端发送数据

使用UDP协议的时候,当数据传输过来我们将数据包拆开只读取设定大小的数据,其余就会丢掉,继而丢失

每次发送都是一个独立的数据包,因为每次的发送可能目的地址都不相同,对于TCP是可以将多次的数据合并进行发送的,因为在同一描述符同一连接内发送对象只有连接的另一方

到此这篇关于关于UDP服务器客户端编程流程介绍的文章就介绍到这了,更多相关UDP客户端编程程流内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 关于UDP服务器客户端编程流程介绍

    目录 UDP编程流程 UDP服务端代码实现 UDP客户端代码实现 UDP服务端客户端代码详解 UDP编程流程 UDP提供的是无连接.不可靠的.数据报服务 UDP是尽最大能力进行传输,但是并不能保证可靠性,TCP的可靠性是因为一系列的机制保证可靠性,UDP丢包并不会重发,两种协议并没有优略之分,要区分不同的场景来区分,比如:进行文件传输,不能有数据丢失,TCP协议就更合 适,而进行实时视频通话,UDP会根据恒定的速率进行发送,这样的情况容许部分数据的丢失去追求更好的实时性,所以UDP更合适 流程:

  • Linux之UDP协议及其编程全流程

    目录 UDP协议的特点 UDP的编程流程 UDP接口原型 UDP服务器端 UDP客户端 UDP的报头结构 UDP的优势 UDP的数据报服务 总结 UDP协议的特点 UDP 不提供可靠性的传输,它只是把应用程序传给 IP 层的数据报发送出去,但是并不能保证它们能到达目的地. 由于 UDP 在传输数据报前不用在客户和服务器之间建立一个连接,且没有超时重发等机制,故而传输速度很快. 无连接 不可靠 数据报服务 UDP发出的数据包不经过确认,可以继续发送.发送成功与否都不管,尽最大能力去发送,丢包也不负

  • node.js基于dgram数据报模块创建UDP服务器和客户端操作示例

    本文实例讲述了node.js基于dgram数据报模块创建UDP服务器和客户端操作.分享给大家供大家参考,具体如下: node.js中 dgram 模块提供了udp数据包的socket实现,可以方便的创建udp服务器和客户端. 一.创建UDP服务器和客户端 服务端: const dgram = require('dgram'); //创建upd套接字 //参数一表示套接字类型,'udp4' 或 'udp6' //参数二表示事件监听函数,'message' 事件监听器 let server = dg

  • Linux系统创建TCP连接流程介绍

    目录 Linux创建TCP的步骤 服务端 客户端 TCP建立流程 示例代码 Linux创建TCP的步骤 TCP编程需要客户端和服务器两套编码,其创建TCP的流程也是不完全一致的 服务端 使用socket函数创建一个套接字 使用setsockopt函数设置套接字的属性 使用bind函数绑定IP地址.端口信息到套接字上使用listen函数监听指定端口 使用accept函数接收客户端的连接请求 使用send/recv和read/write函数进行数据的收发 使用close函数关闭网络连接和监听 客户端

  • Springboot整合Netty实现RPC服务器详解流程

    目录 一.什么是RPC? 二.实现RPC需要解决那些问题? 1. 约定通信协议格式 RPC请求 RPC响应 2. 序列化方式 3. TCP粘包.拆包 4. 网络通信框架的选择 三.RPC服务端 四.RPC客户端 总结 一.什么是RPC? RPC(Remote Procedure Call)远程过程调用,是一种进程间的通信方式,其可以做到像调用本地方法那样调用位于远程的计算机的服务.其实现的原理过程如下: 本地的进程通过接口进行本地方法调用. RPC客户端将调用的接口名.接口方法.方法参数等信息利

  • linux云服务搭建七日杀服务器的详细流程

    目录 准备工作 1.设置swap 2.安装screen 3.安装SteamCmd运行所需环境 4.创建一个用户 steamCMD与七日杀服务器端 1.下载并安装SteamCMD 2.登录steam账号 3.下载七日杀服务端 4.配置服务端 5.配置防火墙 6.启动服务器 补充 1.几个重要路径和文件 2.添加mod 3.管理服务器 准备工作 首先你需要拥有一个云服务器,内地的主流云服务平台有阿里云.腾讯云等,如果你在海外可以选择AWS.google云服务等.七日杀服务端的建议最低配置是2core

  • Flask表单与表单验证实现流程介绍

    目录 表单介绍 WTForms 和 Flask-WTF 创建表单 表单字段 验证器 表单介绍 说到表单,在HTML中表单的创建时通过<form>标签实现的,在<form>标签内部,字段通过使用<input>标签等定义.比如一个表单内部有用户名,密码框这些,都是通过<input>,<label>标签等实现的. 一个简单的表单: <form> First name:<br> <input type="text&

  • SpringCloud Feign客户端使用流程

    目录 一.HTTP客户端Feign 1.1RestTemplate方式调用存在的问题 1.2Feign的介绍 1.3Feign的使用 1.4自定义Feign的配置 1.5Feign性能优化 1.6Feign的最佳实践 一.HTTP客户端Feign 1.1RestTemplate方式调用存在的问题 以前我用使用RestTemplate发起远程调用的代码: String url = "http://userservice/user/" + order.getUserId(); User u

  • java UDP通信客户端与服务器端实例分析

    本文实例讲述了java UDP通信客户端与服务器端.分享给大家供大家参考,具体如下: 最初Udp是以字节为单位进行传输的,所以有很大的限制 服务器端: import java.net.*; public class TestUdpServer { public static void main(String[] args) throws Exception { byte[] buf = new byte[1024]; DatagramPacket dp = new DatagramPacket(

  • 阿里云ECS服务器入门使用流程(新手必看教程)

    一.阿里云根据个人需要选合适的云服务器,选好cpu.内存.带宽,地域,这四个是主要的.其他可以默认选择. 二.登陆控制台 输入账号密码,进去看到服务界面,新手可能不容易看懂.点击左侧菜单,点击云服务器,显示界面如图: 点击实例,在左上角选择区域(一定要选对地域才能看到服务器),这时看到服务器信息了,如图: 大家不要看这里这么多信息,对我们有用的其实只有几个而已,别的都不用看. 更多参阅云服务器配置帮助文档. 三.连接主机 1.通过控制台连接 阿里云服务器要用到两个密码,一个是远程登录密码,一个是

随机推荐