udp_socket

文章目录

    • UDP服务器封装
      • 系统调用socket
      • bind系统调用
      • bzero结构体清0
      • sin_family
      • 端口号
      • ip地址
      • inet_addr
      • recvfrom
      • sendto
    • 新指令 netstat -naup (-nlup)
    • 包装器 的两种类型重命名方式
      • 包装器使用统一可调用类型
    • 关键字 typedef 类型重命名
    • 系统调用popen
    • 关于inet_ntoa

UDP服务器封装

在这里插入图片描述

在这里插入图片描述

系统调用socket

创建套接字

在这里插入图片描述
返回值
在这里插入图片描述
socket返回依旧是一个文件,所以创建套接字的本质,底层就是打开一个文件,以前strcut file指向的是具体某一个磁盘上的设备,只不过我们的struct file指向的底层网卡设备,他就相当于一切皆文件。

有了对应的套接字之后未来就可以使用套接字来进行收发消息,但在进行各种收发之前,我们的服务器都必须得有一个参数socket的返回值,这个套接字创建之后呢,类比文件接口,把文件创建好得到了文件描述符,从此往后所有接口想对文件交互访问都得有fd,套接字的文件描述符同理。
在这里插入图片描述
问题
服务器绑定的端口 and IP地址是什么?

bind系统调用

在这里插入图片描述
要绑定就得用这个通用结构体,但是我们用的是sockaddr_in
每个字段都有细节
sin_zero 对应 填充 不管
在这里插入图片描述

在这里插入图片描述
通用类型结构体 头文件如图

bzero结构体清0

在这里插入图片描述
使用这个结构体需要先把他清空
然后我们就填中结构题字段就可以了

在这里插入图片描述

sin_family

sockaddr_in 里面有什么?我追进去怎么没看见sin_family字段?
利用了宏替换
在这里插入图片描述
sa_family_t 实际上是短整型,我们就填对应的16位地址类型,AF_INET
在这里插入图片描述

端口号

如果今天双方通信时,我给对方发消息,对方要发消息回我,他得知道我,我就得把端口号发给过他。
说明端口号的信息将来一定要能够发送给对方的,无论客户端还是服务器也罢。
协议一个字段都没学,但网络通信本质就是进程间通信,我要把我的端口号带上还有正常消息都给对方发过去,对方处理完也能拿着我的端口号响应给我。
结论就是端口号在网络里来回发送。
所以端口号填充到结构体里必须保证他是网络字节序,因为该端口号是要给对方发送的。
这个代码在你系统里面编译是小端,必须转大端。

在这里插入图片描述

ip地址

用户使用字符串IP传入也是字符串,而结构体中是要四字节的,字符串一个字符就是一字节明显不对应,所以需要转换
在这里插入图片描述
整数转字符串
字符串转整形 想告诉大家的是互相转难度不大

在这里插入图片描述
ip地址也要在网络当中发送,不然怎么回复与相应,客户端和服务器之间。
如果IP要被网络使用,ip出了转化成4字节ip,ip还必须是网络序列的。
赋值part1-part4都是在你本机进行的计算。
把IP地址转化成网络序列的话,无非就根据当前机器是大端小端,决定赋值的顺序,要么就是part1 = 100 or part1 = 192, part1是结构体中地址最小的,192是数值权重最高的,这样写就是大端,反过来就是小端。
所以只是决定part1 到part4赋值顺序,就可以更改我们当前IP报文形成四字节是网络序列还是主机序列。
在这里插入图片描述

  1. ip必须string转四字节Ip
  2. 四字节uint32_t 类型ip 还必须是网络序列的。
    上面图里这两个功能不用我们自己做

inet_addr

他做了两件工作 字符串转uint32_t + 转大端
在这里插入图片描述

至此这个结构体的信息只是在栈上,在用户空间而不是系统空间3-4G

在这里插入图片描述
所以还没有与套接字关联,设置进内核
在这里插入图片描述
UDP核心步骤,创建套接字+绑定
基本都是固定形式,UDP就这么多。
接下来做的工作仅仅是收发消息。

在这里插入图片描述
为什么是recvfrom 而不是 read or write ?
UDP不是面向字节流,是面向数据包,你就用不了read or write

recvfrom

在这里插入图片描述
recvfrom收到以后 读取返回值 确定收到多少个字节数据
在这里插入图片描述

sendto

在这里插入图片描述
flag 发送方式 设置为0

新指令 netstat -naup (-nlup)

n能显示数字,就显示数字
a all所有
u udp
p 显示pid
在这里插入图片描述
只要能用netstat 查到我们进程./udpserver就说明我们的服务器已经启动了。

今天虽然启动了,但仅仅是巧合,这里面有坑,我们得点出来。

一个关于IP
你查到本地地址 绑定的IP是0.0.0.0,那你服务期的公网IP不是0.0.0.0啊,如果我们今天绑定服务器公网IP,你就会得到如下错误

云服务器禁止直接绑定公网ip,因为它做了虚拟化
bind(IP:0.0.0.0),凡是发给我这台主机的数据,我们都要根据端口号向上交付 — 任意地址bind
因为服务器可能有两张网卡,两个Ip,你只绑定一个,另一个ip客户端的信息你就拿不上来
在这里插入图片描述
“0.0.0.0”字符串 转 uin32_t 本来就是0
所以结构体 的另一种写法
在这里插入图片描述
从今往后虚拟机可以用公网ip,但是云服务器就端口,ip就0就行
在这里插入图片描述

一个关于port
在这里插入图片描述

端口号 16位 范围0~65535
我们一般绑定8000+往上不会有问题,你非要绑系统内定就sudo 去绑,我们不建议

就想说ip绑0,端口号8000以上的,就完了。


客户端

client 需要socket创建套接字,socket创建的网络文件描述符不用就close 关掉
在这里插入图片描述

那client需要bind吗?
客户端一定要绑定,要有自己的ip和端口,这是套接字通信,客户端也要唯一性标识。
所以要!
只不过不需要用户显示的bind! 一般由os自由随机选择。

服务器的IP和端口不要一直变,不能随机绑定,让客户端找不到,他只能由程序员来绑是确定的。

而客户端的ip和端口是多少,其实不重要,只要保证主机上的唯一性就可以。
全是由客户端给服务器发信息,服务器就能知道客户端是谁,ip port如何如何

所以系统什么时候给我bind呢?
首次发送数据的时候!

那客户端怎么知道他要发给谁,请求那个服务器的ip port
这个工作由我们来做,通过命令行参数让用户输入请求的ip port
在这里插入图片描述
怎么发
1.发什么数据 – 输入字符串
2.给谁发
我们可不止需要ip+port,同样需要构建struct sockaddr_in结构体

在这里插入图片描述
今天客户端有可能从不同的服务器收发消息吗?
客户端一气发给好几个服务器ip 的sendto,所以有可能
有可能,但今天我们就一个

在这里插入图片描述
最后客户端发什么字符串,服务器就给我返回什么字符串
就这样一来一回
在这里插入图片描述

域名其实就是ip地址
服务器一般做推广自己的域名ip,服务器的端口号约定好
今天我们客户端是利用命令行参数来进行直接绑定,服务器裸露自己的Ip和端口号

在这里插入图片描述

包装器 的两种类型重命名方式

你可以把包装器当成函数指针
在这里插入图片描述

包装器使用统一可调用类型

在这里插入图片描述

在这里插入图片描述

关键字 typedef 类型重命名

一般是重命名在默认类型 后面 ,函数指针是中间
在这里插入图片描述

把收发数据 和 处理数据 做解耦
让main函数中调用Run方法时传入一个func_t类型的可调用类型方法,处理完数据再把结果发回去
在这里插入图片描述

在这里插入图片描述

服务器收到消息把消息传递给我传进来的这个回调函数func,回调函数会把数据回调式的处理,处理完成之后把结果返回。

这样做的本质是对代码进行分层。
就是不要把字符串的处理放在我们的代码当中
在这里插入图片描述
直接使用我们传进来的方法,在上层不关心网络通信了,消息是什么样的做加工处理就行。你可以返回echo 服务期简单的处理,也可以传入不同的回调方法处理命令返回结果。
在这里插入图片描述

没人规定网络udp只能发送字符串,我们也可以认为发送的是命令啊,在服务器上创建进程再把命令执行的结果返回
在这里插入图片描述
这样写费时间,我们可以利用popen

系统调用popen

在这里插入图片描述

封装起来的管道,和子进程执行命令的应用,,popen作用是把执行命令以字符串的形式给我,popen底层我会帮你fork,我会让父子进程建立管道,让子进程把结果通过管道返回给调用方,调用方如果想得到command运行结果,你可以通过文件指针方式读取,type如果是r相当于读方式打开文件。
在这里插入图片描述
UDP应用场景

  1. ExcuteCommand
  2. 简单聊天室
    Udp 的socket是全双工的,允许被同时读写的
    我们可以创建两个线程,一个线程不断的收消息,把用户加进来,另一个线程就不管的把消息广播出去。这就势必要有一个交换信息的区域,所以要加锁。

客户端一开始就不停的让我getline,让我输入消息,我只有输入消息才能收到消息?
getline这里直接就阻塞住了
在这里插入图片描述

我们也没有讲怎么把接口设为非阻塞,到多路复用再说

所以客户端 把整个代码多线程化
一个线程不断的输入,一个线程显示
未来我不输入,我也要能看到消息
在这里插入图片描述
在这里插入图片描述
那线程安全吗?
无论TCP还是UDp都有自己独立的接收和发送缓冲区,所以不影响。

解决客户端输入输出的显示都混在一起的问题
在这里插入图片描述
我们可以利用不同的shell终端文件来分开打印
在这里插入图片描述
测试代码,让本地应该向显示器文件打印重定向到终端文件中
此时就能做到与不同终端显示输出分离了
在这里插入图片描述
在这里插入图片描述
也就是我自己写的程序可以直接向另一个终端打印。

多线程文件描述符是共享的
因为收发都有cout向显示器输出,所以不能全都重定向到终端文件中,我们让收的往标准错误打,再把标准错误重定向到终端文件就可以了。
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

  1. windows端的客户端访问Linux服务期

在这里插入图片描述

关于inet_ntoa

问题,你把字符串char* 起始地址给我了,关键是这字符串的空间在哪啊?
在函数内部把空间开辟好,把空间地址返回
手册说是放到了静态区,所以不用手动释放
如果你多次调用静态缓冲区会被覆盖
如果多线程重复调用次函数,就会出现;临界资源问题
书里说他不是线程安全问题,可能内部加了锁
我们建议可以用,但是后面用尽量不要用这个接口而改用inet_ntop
在这里插入图片描述
学习方法
30分钟 究竟说了啥,你自己用最简单的话总结出来
总结能力
你不要让老师总结,你自己总结出来,核心
重点有那几点
1
2
3
总结出来

记不住东西
艾宾浩斯遗忘曲线
在这里插入图片描述
应该是在6天以内,一周,就重新复盘,多次重复
没复习一次就能得到20%,无限重复 才能 趋近100%
只有经过重复东西才真正是我们的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/478122.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【LLM训练系列02】如何找到一个大模型Lora的target_modules

方法1:观察attention中的线性层 import numpy as np import pandas as pd from peft import PeftModel import torch import torch.nn.functional as F from torch import Tensor from transformers import AutoTokenizer, AutoModel, BitsAndBytesConfig from typ…

解!决!vscode!Path Intellisense 失效!不起作用问题!!

第一步:找到path Intellisense插件 点击设置 第二步:打开settings.json文件: 第三步:配置settings.json文件内容: "path-intellisense.mappings": {"": "${workspaceRoot}/src",&qu…

力扣 LeetCode 110. 平衡二叉树(Day8:二叉树)

解题思路: 等于 -1 时,直接 return -1 class Solution {public boolean isBalanced(TreeNode root) {return getHeight(root) ! -1;}public int getHeight(TreeNode root) {if (root null) return 0;int leftDepth getHeight(root.left);if (leftDep…

ros2学习日记_241124_ros相关链接

前言 提醒: 文章内容为方便作者自己后日复习与查阅而进行的书写与发布,其中引用内容都会使用链接表明出处(如有侵权问题,请及时联系)。 其中内容多为一次书写,缺少检查与订正,如有问题或其他拓展…

【TEST】Apache JMeter + Influxdb + Grafana

介绍 使用Jmeter发起测试,测试结果存入Influxdb,Grafana展示你的测试结果。 环境 windows 10docker desktopJDK17 安装 Apache JMeter 访问官网(Apache JMeter - Apache JMeter™)下载JMeter(目前最新版本5.6.3&a…

【隐私计算大模型】联邦深度学习之拆分学习Split learning原理及安全风险、应对措施以及在大模型联合训练中的应用案例

Tips:在两方场景下,设计的安全算法,如果存在信息不对等性,那么信息获得更多的一方可以有概率对另一方实施安全性攻击。 1. 拆分学习原理 本文介绍了一种适用于隐私计算场景的深度学习实现方案——拆分学习,又称分割…

汽车HiL测试:利用TS-GNSS模拟器掌握硬件性能的仿真艺术

一、汽车HiL测试的概念 硬件在环(Hardware-in-the-Loop,简称HiL)仿真测试,是模型基于设计(Model-Based Design,简称MBD)验证流程中的一个关键环节。该步骤至关重要,因为它整合了实际…

Vue——响应式数据,v-on,v-bind,v-if,v-for(内含项目实战)

目录 响应式数据 ref reactive 事件绑定指令 v-on v-on 鼠标监听事件 v-on 键盘监听事件 v-on 简写形式 属性动态化指令 v-bind iuput标签动态属性绑定 img标签动态属性绑定 b标签动态属性绑定 v-bind 简写形式 条件渲染指令 v-if 遍历指令 v-for 遍历对象的值 遍历…

Redis 常用数据类型插入性能对比:循环插入 vs. 批量插入

Redis 是一款高性能的键值数据库,其支持多种数据类型(String、Hash、List、Set、ZSet、Geo)。在开发中,经常会遇到需要插入大量数据的场景。如果逐条插入,性能会显得较低,而采用 Pipeline 批量插入 能大幅提…

开源动态表单form-create-designer 扩展个性化配置的最佳实践教程

在开源低代码表单设计器 form-create-designer 的右侧配置面板里,field 映射规则为开发者提供了强大的工具去自定义和增强组件及表单配置的显示方式。通过这些规则,你可以简单而高效地调整配置项的展示,提升用户体验。 源码地址: Github | G…

Java语言编程,通过阿里云mongo数据库监控实现数据库的连接池优化

一、背景 线上程序连接mongos超时,mongo监控显示连接数已使用100%。 java程序报错信息: org.mongodb.driver.connection: Closed connection [connectionId{localValue:1480}] to 192.168.10.16:3717 because there was a socket exception raised by…

深入浅出分布式缓存:原理与应用

文章目录 概述缓存分片算法1. Hash算法2. 一致性Hash算法3. 应用场景Redis集群方案1. Redis 集群方案原理2. Redis 集群方案的优势3. Java 代码示例:Redis 集群数据定位Redis 集群中的节点通信机制:Gossip 协议Redis 集群的节点通信:Gossip 协议Redis 集群的节点通信流程Red…

Loom篇之java虚拟线程那些事儿

我们在之前的文章中提到了java推出纤程的背景和原因。在近三十年来,Java 开发人员一直依赖线程作为并发服务器应用程序的构建块。每个方法中的每个语句都在线程内执行,并且由于 Java 是多线程的,因此多个执行线程会同时发生。线程是 Java 的并…

自然语言处理: RAG优化之Embedding模型选型重要依据:mteb/leaderboard榜

本人项目地址大全:Victor94-king/NLP__ManVictor: CSDN of ManVictor git地址:https://github.com/opendatalab/MinerU 写在前面: 笔者更新不易,希望走过路过点个关注和赞,笔芯!!! 写在前面: 笔者更新不易,希望走过路…

如何选择服务器

如何选择服务器 选择服务器时应考虑以下几个关键因素: 性能需求。根据网站的预期流量和负载情况,选择合适的处理器、内存和存储容量。考虑网站是否需要处理大量动态内容或高分辨率媒体文件。 可扩展性。选择一个可以轻松扩展的服务器架构,以便…

Spring 框架七大模块(Java EE 学习笔记03)

​ ​核心容器模块(Core Container) 核心容器模块在Spring的功能体系中起着支撑性作用,是其他模块的基石。核心容器层主要由Beans模块、Core模块、Contex模块和SpEL模块组成。 (1)Beans模块。它提供了BeanFactory类&…

2025-2026财年美国CISA国际战略规划(下)

文章目录 前言四、加强综合网络防御(一)与合作伙伴共同实施网络防御,降低集体风险推动措施有效性衡量 (二)大规模推动标准和安全,以提高网络安全推动措施有效性衡量 (三)提高主要合作…

【大数据技术与开发实训】携程景点在线评论分析

景点在线评论分析 题目要求实验目标技术实现数据采集获取所有相关景点页面的 URL获取所有相关景点对应的 poiId 及其他有用信息通过 poiId 获取所有景点的全部评论数据采集结果 数据预处理景点信息的数据预处理查看数据基本信息缺失值处理 用户评论的数据处理缺失值处理分词、去…

《第十部分》1.STM32之通信接口《精讲》之IIC通信---介绍

经过近一周的USART学习,我深刻体会到通信对单片机的重要性。它就像人类的手脚和大脑,只有掌握了通信技术,单片机才能与外界交互,展现出丰富多彩的功能,变得更加强大和实用。 单片机最基础的“语言”是二进制。可惜&am…

ES 基本使用与二次封装

概述 基本了解 Elasticsearch 是一个开源的分布式搜索和分析引擎,基于 Apache Lucene 构建。它提供了对海量数据的快速全文搜索、结构化搜索和分析功能,是目前流行的大数据处理工具之一。主要特点即高效搜索、分布式存储、拓展性强 核心功能 全文搜索:…