最新资讯

  • 领航Linux UDP:构建高效网络新纪元

领航Linux UDP:构建高效网络新纪元

2025-05-02 20:37:50 0 阅读

欢迎来到 破晓的历程的 博客

⛺️不负时光,不负己✈️

文章目录

    • 引言
    • Udp和Tcp的异同
      • 相同点
      • 不同点
      • 总结
    • 1.1、socket
    • 1.2、bind
    • 1.3、recvfrom
    • 1.4、sendto
    • 2.1、代码
    • 2.1、说明
    • 3.1、代码
    • 3.2、说明

引言

在前几篇博客中,我们学习了Linux网络编程中的一些概念。从本篇博客开始,我们就正式开始写代码。本篇博客我们将写udp服务器和客户端代码,并实现服务器和客户端通信。这些代码学习成本较高,建议大家多敲几遍。如任何问题,欢迎与我沟通。

Udp和Tcp的异同

UDP协议(User Datagram Protocol,用户数据报协议)和TCP协议(Transmission Control Protocol,传输控制协议)是计算机网络中两种常用的传输层协议,它们在多个方面存在显著的异同。以下是对两者异同点的详细比较:

相同点

  • 层次位置:两者都位于OSI模型的第四层——传输层,为上层应用提供数据传输服务。
  • 作用:都在网络通信中扮演着重要的角色,用于在网络中的不同设备之间传输数据。

不同点

UDP协议TCP协议
可靠性不提供可靠性保证,不保证数据包的顺序、完整性和不重复。提供可靠的数据传输,通过序列号、确认机制和重传机制确保数据的完整性和有序性。
连接性无连接协议,发送数据前不需要建立连接,直接发送数据。面向连接的协议,数据传输前需要建立连接,通过“三次握手”机制确认连接状态。
传输效率传输效率高,因为不需要建立连接和维持连接状态,开销小。传输效率相对较低,因为需要建立和维护连接,增加了额外的开销。
实时性实时性较好,适用于对实时性要求较高的应用,如在线游戏、视频通话等。实时性较差,因为需要等待连接建立和确认,以及处理重传等机制。
数据包大小数据包大小没有限制,但通常受限于网络MTU(最大传输单元)。将数据分割成较小的数据块进行传输,以适应不同的网络环境。
拥塞控制不使用拥塞控制,网络拥塞时不会降低发送速率。使用拥塞控制机制,根据网络状况调整发送速率,避免网络拥塞。
应用场景适用于对可靠性要求不高,但对实时性要求较高的场景,如流媒体传输、DNS查询等。适用于对可靠性要求较高的场景,如文件传输、网页浏览等。

总结

UDP协议和TCP协议在可靠性、连接性、传输效率、实时性、数据包大小和拥塞控制等方面存在显著的差异。选择哪种协议取决于具体的应用场景和需求。如果对数据传输的可靠性要求较高,应选择TCP协议;如果对实时性要求较高,且可以容忍一定的数据丢失,则可以选择UDP协议。在实际应用中,两种协议经常结合使用,以满足不同的网络需求。

不难发现,Udp代码较简单,写起来相对的简单一些,上手较容易。所以我们写使用Udp协议进行通信。

为了使大家更加容易理解。我们按照创建udp服务端的整个过程的先后顺序来进行讲解。最后写出完整的代码。

1.1、socket

网络通信必须要申请套接字。申请套接字对应的函数为socket。

       #include           /* See NOTES */
       #include 
       int socket(int domain, int type, int protocol);

参数
①domain

domain(协议域/协议族):决定了socket的地址类型。常用的协议族有AF_INET(IPv4)、AF_INET6(IPv6)、AF_LOCAL(或称AF_UNIX,Unix域socket)、AF_ROUTE等。在通信中,必须采用与协议族对应的地址。例如,AF_INET决定了要使用IPv4地址(32位)与端口号(16位)的组合。

②type


type(socket类型):指定了socket的类型。常用的socket类型有SOCK_STREAM(流式套接字,用于TCP)、SOCK_DGRAM(数据报套接字,用于UDP)、SOCK_RAW(原始套接字,允许对底层协议如IP或ICMP进行直接访问)等。
③protocol
protocol(协议):通常情况下,可以将其设置为0,让系统自动选择type类型对应的默认协议。
返回值

  • 当socket函数成功创建了一个套接字时,它返回一个有效的套接字描述符(socket descriptor)。这个描述符是一个非负整数,用于后续的网络操作,如绑定、监听、连接、发送和接收数据等。
  • 如果在创建套接字时发生错误,socket函数返回-1,并设置全局变量errno以指示错误原因。此时,可以调用errno变量或perror()函数来获取具体的错误信息。常见的错误码包括EACCES(权限不足)、EADDRINUSE(地址已经被占用)、EAFNOSUPPORT(地址族不支持)、EINVAL(参数无效)、EMFILE(达到进程允许打开的最大文件数目)、ENFILE(系统打开文件数目过多)、ENOBUFS/ENOMEM(内存不足)、EPROTONOSUPPORT(协议不支持)等。

1.2、bind

bind函数在网络编程中扮演着至关重要的角色,它主要用于将一个本地协议地址(包括IP地址和端口号)赋予一个套接字。以下是关于bind函数的详细解释:

       #include           /* See NOTES */
       #include 
       int bind(int sockfd, const struct sockaddr *addr,
                socklen_t addrlen);

参数
①sockfd:这是由socket()函数返回的文件描述符,代表已经创建的套接字。
②addr:这是一个指向特定协议地址结构的指针,如struct sockaddr_in或struct sockaddr_un,它包含了地址、端口和可能的IP地址信息。
③addrlen:这是地址结构的长度,通常以字节为单位。对于IPv4,通常使用sizeof(struct sockaddr_in);对于IPv6,使用sizeof(struct sockaddr_in6);对于Unix域套接字,使用sizeof(struct sockaddr_un)。
返回值:

  • 如果bind函数成功执行,它返回0。
  • 如果出现错误,返回-1,并设置全局变量errno以指示错误原因。常见的错误包括EACCES(权限不足)、EADDRINUSE(地址已经被使用)、EADDRNOTAVAIL(地址不可用)、EAFNOSUPPORT(地址族不支持该套接字类型)、EINVAL(套接字未打开)、ENOTSOCK(文件描述符不是套接字)等。

使用场景:

在TCP服务器程序中,bind函数通常用于指定服务器应监听的端口号。服务器在启动时捆绑其众所周知的端口,以便客户端可以连接到它。
对于UDP套接字,bind函数同样用于指定接收数据的端口号。
在Unix域套接字中,bind函数可以用来指定套接字在文件系统中的路径名。

注意事项:

  • 在调用bind函数之前,套接字必须处于未连接状态(对于面向连接的套接字如TCP)。
  • 如果addr参数中的地址或端口号为0,系统将为套接字自动选择一个可用的地址或端口号。
  • 在多线程环境中,应确保对bind函数的调用是线程安全的,避免竞态条件。
  • 绑定的本质:将用户态的sockaddr_in设置进内核变为系统态。
  • 对于端口号而言,如果用户没有调用bind函数进行显式绑定,那么系统在第一次发送消息时,会随机给套接字绑定一个端口号。

1.3、recvfrom

recvfrom函数是一个在POSIX兼容操作系统(如Linux)中用于接收数据的系统调用。它主要用于从指定的套接字接收数据,并适用于面向无连接的协议,如UDP(用户数据报协议)。

       #include 
       #include 
       ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,
       struct sockaddr *src_addr, socklen_t *addrlen);

参数
①sockfd:已经创建并绑定的套接字的文件描述符。
②buf:创建好的一块缓冲区的地址。用来承接从网络中读取到的数据。
③len:该块缓冲区的大小。
④flags:读取数据的方式。默认设为0——阻塞式读取。
⑤src_addr输出型参数,该结构体里面包含着数据发送方的信息,如port、ip等等。如果不需要这些信息,可以设为null。
⑥‘’addrlen:该结构体的大小。

返回值

  • 成功时,返回接收到的字符数(字节数)。
  • 如果没有可用数据或者连接已经关闭,返回0。
  • 如果出现错误,返回-1,并设置errno错误号。此时可以通过perror()函数来打印出错误信息。

注意事项

  • 在调用recvfrom函数之前,需要先使用bind函数将socket绑定到一个地址上。
  • 如果套接字是非阻塞的,recvfrom函数可能会在没有接收到任何数据时返回-1,并设置errno为EAGAIN或EWOULDBLOCK。
  • 如果接收到的数据比缓冲区还大,那么只会取缓冲区大小的数据,并将剩余的数据丢弃。

1.4、sendto

sendto函数是一个系统调用,用于将数据从指定的套接字发送到目标地址。它通常用于UDP(用户数据报协议)通信,因为UDP是无连接的,所以sendto函数允许你向一个特定的地址发送数据报,而不需要事先建立连接。

#include 
ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,
               const struct sockaddr *dest_addr, socklen_t addrlen);

参数

  • sockfd:已经创建好的socket文件描述符。
  • buf:指向要发送的数据的缓冲区。
  • len:要发送的数据长度。
  • flags:发送选项标志,可以是0或者像MSG_DONTWAIT这样的选项。MSG_DONTWAIT表示非阻塞发送,如果发送缓冲区满,则不等待直接返回。
  • dest_addr:目标地址的sockaddr结构体指针。对于IPv4,这通常是一个指向struct sockaddr_in的指针;对于IPv6,则是一个指向struct sockaddr_in6的指针。
  • addrlen:目标地址结构体的长度,例如sizeof(struct sockaddr_in)或sizeof(struct sockaddr_in6)。

返回值:

sendto函数的返回值是一个long类型的整数,表示发送的字节数。具体返回值有以下几种可能:

  • 如果返回值大于0,则表示数据已经成功发送到了目标地址。返回值代表实际发送的字节数。
  • 如果返回值等于0,表示发送的数据长度为0。这可能是因为buf指向的空间长度为0,或者在使用UDP协议时,sendto函数成功地发送了0字节的数据。
  • 如果返回值等于-1,表示发送过程中出现了错误。此时,可以通过检查errno的值来确定具体的错误原因。例如,如果errno为EINTR,表示sendto函数被一个信号中断了;如果errno为EAGAIN或EWOULDBLOCK,表示发送缓冲区已满,无法立即发送数据(这通常发生在使用了MSG_DONTWAIT标志的情况下)。

需要注意的是,sendto函数不保证数据的可靠传输。也就是说,发送的数据可能会丢失,或者接收方可能无法按照发送的顺序接收数据。如果需要可靠的数据传输,应该使用TCP协议而不是UDP。
此外,在使用sendto函数之前,需要确保已经通过socket函数创建了一个套接字,并且(对于面向连接的套接字类型)已经通过connect函数与目标地址建立了连接(尽管对于UDP,连接通常不是必需的,但也可以通过connect建立默认的目标地址)。同时,也需要确保目标地址是有效的,并且发送的数据缓冲区是正确设置的。

udp服务端

2.1、代码

#pragma once

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

namespace Server
{
    using namespace std;

    static const string defaultIp = "0.0.0.0"; //TODO
    static const int gnum = 1024;

    enum {USAGE_ERR = 1, SOCKET_ERR, BIND_ERR};

    typedef function<void (string,uint16_t,string)> func_t;

    class udpServer
    {
    public:
        udpServer(const func_t &cb, const uint16_t &port, const string &ip = defaultIp)
        :_callback(cb), _port(port), _ip(ip), _sockfd(-1)
        {}
        void initServer()
        {
            // 1. 创建socket
            _sockfd = socket(AF_INET, SOCK_DGRAM, 0);
            if(_sockfd == -1)
            {
                cerr << "socket error: " << errno << " : " << strerror(errno) << endl;
                exit(SOCKET_ERR);
            }
            cout << "socket success: " << " : " << _sockfd << endl;

            // 2. 绑定port,ip(TODO)
            // 未来服务器要明确的port,不能随意改变
            struct sockaddr_in local; // 定义了一个变量,栈,用户
            bzero(&local, sizeof(local));
            local.sin_family = AF_INET;
            local.sin_port = htons(_port); // 你如果要给别人发消息,你的port和ip要不要发送给对方
            local.sin_addr.s_addr = inet_addr(_ip.c_str());   // 1. string->uint32_t 2. htonl(); -> inet_addr
            //local.sin_addr.s_addr = htonl(INADDR_ANY); // 任意地址bind,服务器的真实写法
            int n = bind(_sockfd, (struct sockaddr*)&local, sizeof(local));
            if(n == -1)
            {
                cerr << "bind error: " << errno << " : " << strerror(errno) << endl;
                exit(BIND_ERR);
            }
            // UDP Server 的预备工作完成
        }
        void start()
        {
            // 服务器的本质其实就是一个死循环
            char buffer[gnum];
            for(;;)
            {
                // 读取数据
                struct sockaddr_in peer;
                socklen_t len = sizeof(peer); //必填
                ssize_t s = recvfrom(_sockfd, buffer, sizeof(buffer) - 1, 0, (struct sockaddr*)&peer, &len);
                // 1. 数据是什么 2. 谁发的?
                if(s > 0)
                {
                    buffer[s] = 0;
                    string clientip = inet_ntoa(peer.sin_addr); //1. 网络序列 2. int->点分十进制IP
                    uint16_t clientport = ntohs(peer.sin_port);
                    string message = buffer;

                    cout << clientip <<"[" << clientport << "]# " << message << endl;
                    // 我们只把数据读上来就完了吗?对数据做处理
                    _callback(clientip, clientport, message);
                }
            }
        }
        ~udpServer()
        {
        }
    private:
        uint16_t _port;
        string _ip; // 实际上,一款网络服务器,不建议指明一个IP
        int _sockfd;
        func_t _callback; //回调
    };
}

2.1、说明

  • 服务器一旦开始运行,就不会停止。所以服务器本质就是一个死循环。这种一直运行的进程叫做常驻进程。
  • 一般来说,服务器不会显式的绑定某一个ip。因为一个主机可能会有不同的ip。但是这台主机内的端口号是唯一的,客户端都是发送信息到特定的端口号上。所以服务器为了可以接收到所有发到这台主机上的信息(不会存在数据丢弃的情况),选择绑定0.0.0.0作为自己的ip。这样就可以接受到任何发送到这台主机指定端口的所有信息。

udp客户端

3.1、代码

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

namespace Client
{
    using namespace std;

    class udpClient
    {
    public:
        udpClient(const string &serverip, const uint16_t &serverport)
            : _serverip(serverip), _serverport(serverport), _sockfd(-1), _quit(false)
        {
        }
        void initClient()
        {
            // 创建socket
            _sockfd = socket(AF_INET, SOCK_DGRAM, 0);
            if (_sockfd == -1)
            {
                cerr << "socket error: " << errno << " : " << strerror(errno) << endl;
                exit(2);
            }
            cout << "socket success: "
                 << " : " << _sockfd << endl;

            // 2. client要不要bind[必须要的],client要不要显示的bind,需不需程序员自己bind?不需要!!!
            // 写服务器的是一家公司,写client是无数家公司 -- 由OS自动形成端口进行bind!-- OS在什么时候,如何bind
        }

        static void *readMessage(void *args)
        {
            int sockfd = *(static_cast<int *>(args));
            pthread_detach(pthread_self());
            while (true)
            {
                char buffer[1024];
                struct sockaddr_in temp;
                socklen_t temp_len = sizeof(temp);
                size_t n = recvfrom(sockfd, buffer, sizeof(buffer) - 1, 0, (struct sockaddr *)&temp, &temp_len);
                if (n >= 0)
                    buffer[n] = 0;
                cout << buffer << endl;
            }

            return nullptr;
        }

        void run()
        {
            pthread_create(&_reader, nullptr, readMessage, (void *)&_sockfd);

            struct sockaddr_in server;
            memset(&server, 0, sizeof(server));
            server.sin_family = AF_INET;
            server.sin_addr.s_addr = inet_addr(_serverip.c_str());
            server.sin_port = htons(_serverport);

            string message;
            char cmdline[1024];
            while (!_quit)
            {
                //cerr << "# "; // ls -a -l
                // cin >> message;
                fprintf(stderr, "Enter# ");
                fflush(stderr);
                fgets(cmdline, sizeof(cmdline), stdin);
                cmdline[strlen(cmdline)-1] = 0;
                message = cmdline;
                sendto(_sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)&server, sizeof(server));
            }
        }
        ~udpClient()
        {
        }

    private:
        int _sockfd;
        string _serverip;
        uint16_t _serverport;
        bool _quit;

        pthread_t _reader;
    };
} // namespace Client

3.2、说明

客户端需要绑定端口号吗?客户端需要显式的绑定端口号吗?

端口号是需要绑定端口号的,但是不需要显式的绑定端口号的。绑定端口号的工作交给操作系统自主完成,这个工作由操作系统在客户端初次发送消息时完成。

相对于服务端来说,客户端必须绑定特定的端口号,但是端口号的数值对于客户端来说就显得不太重要。

服务端必须指定特定的端口号以供客户端根据该端口号来向服务端发送消息。但是客户端而言,如果显式指明端口号,必然会出现两个客户端竞争一个端口号的情况。所以在通信时就由操作系统随机分配一个端口号供客户端进行通信。

本文地址:https://www.vps345.com/7319.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 javascript 前端 chrome edge llama 算法 opencv 自然语言处理 神经网络 语言模型 ssh harmonyos 华为 开发语言 typescript 计算机网络 ubuntu 阿里云 网络 网络安全 网络协议 数据库 centos oracle 关系型 安全 分布式 deepseek Ollama 模型联网 API CherryStudio RTSP xop RTP RTSPServer 推流 视频 科技 ai java 人工智能 个人开发 进程 操作系统 进程控制 Ubuntu python MCP HarmonyOS Next pip conda numpy YOLO efficientVIT YOLOv8替换主干网络 TOLOv8 ui 华为云 华为od 运维开发 云原生 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn asm debian PVE macos adb EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 android 鸿蒙 物联网 tcp/ip mcu iot 信息与通信 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 面试 性能优化 jdk intellij-idea 架构 嵌入式 linux驱动开发 arm开发 嵌入式硬件 ssl fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 rust http 智能路由器 外网访问 内网穿透 端口映射 rust腐蚀 Qwen2.5-coder 离线部署 ollama 大模型 mac WSL win11 无法解析服务器的名称或地址 计算机外设 电脑 软件需求 sqlserver Dify 目标检测 pycharm ide .netcore 机器学习 c++ kubernetes 容器 学习方法 经验分享 程序人生 vSphere vCenter 软件定义数据中心 sddc golang 后端 AI 爬虫 数据集 微信 微信分享 Image wxopensdk docker windows DeepSeek-R1 API接口 vscode 编辑器 笔记 并查集 leetcode 前端框架 live555 rtsp rtp WSL2 数据结构 学习 c语言 git elasticsearch Hyper-V WinRM TrustedHosts websocket 开源 jmeter 软件测试 gpu算力 命名管道 客户端与服务端通信 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 vue3 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 mysql 源码剖析 rtsp实现步骤 流媒体开发 tomcat 低代码 大数据 数据挖掘 网络用户购物行为分析可视化平台 大数据毕业设计 1024程序员节 c# 深度学习 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 github 创意 社区 unix cpu 内存 实时 使用 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 ipython flutter C 环境变量 进程地址空间 json java-ee react.js 前端面试题 node.js 持续部署 YOLOv8 NPU Atlas800 A300I pro asi_bench flask spring boot AI编程 AIGC protobuf 序列化和反序列化 安装 jenkins 统信UOS 麒麟 bonding 链路聚合 政务 分布式系统 监控运维 Prometheus Grafana ddos qt stm32项目 单片机 stm32 僵尸进程 Windsurf .net tcpdump vim word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 Agent zotero WebDAV 同步失败 代理模式 C# MQTTS 双向认证 emqx VMware安装mocOS VMware macOS系统安装 jar gradle udp unity dell服务器 go ESP32 camera Arduino 电子信息 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 计算机视觉 YOLOv12 sql KingBase 产品经理 agi microsoft uni-app oceanbase rc.local 开机自启 systemd 智能手机 NAS Termux Samba Linux chatgpt llama3 Chatglm 开源大模型 php Dell R750XS postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 rag ragflow ragflow 源码启动 pytorch cuda cudnn anaconda 微服务 springcloud DevEco Studio MacOS录屏软件 迁移指南 ffmpeg 音视频 向日葵 豆瓣 追剧助手 迅雷 nas 银河麒麟 kylin v10 麒麟 v10 温湿度数据上传到服务器 Arduino HTTP aws googlecloud LDAP rpc k8s 自动化 HCIE 数通 maven intellij idea 客户端 ESXi nginx dubbo gateway Clion Nova ResharperC++引擎 Centos7 远程开发 鸿蒙系统 pillow html5 firefox ue5 vr 国产操作系统 ukui 麒麟kylinos openeuler 远程桌面 https CPU 主板 电源 网卡 统信 虚拟机安装 框架搭建 spring 5G 3GPP 卫星通信 换源 镜像源 国内源 Debian threejs 3D Java Applet URL操作 服务器建立 Socket编程 网络文件读取 mq rabbitmq rocketmq kafka AI大模型 大模型入门 Deepseek 大模型教程 remote-ssh SenseVoice r语言 数据可视化 ip命令 新增网卡 新增IP 启动网卡 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 bash selenium 测试工具 其他 远程工作 微信小程序 系统架构 RustDesk自建服务器 rustdesk服务器 docker rustdesk django web3.py wsl2 wsl 虚拟化 半虚拟化 硬件虚拟化 Hypervisor 云服务器 VPS pyqt trae eureka WebRTC gpt 恒源云 多层架构 解耦 ux 多线程 RTMP 应用层 jupyter Docker Hub docker pull daemon.json 机器人 飞书 apache 孤岛惊魂4 devops ci/cd 游戏服务器 TrinityCore 魔兽世界 LLM 大模型面经 职场和发展 大模型学习 AnythingLLM AnythingLLM安装 MQTT 消息队列 缓存 adobe 传统数据库升级 银行 大语言模型 LLMs outlook Python 网络编程 聊天服务器 套接字 TCP Socket webrtc IPMITOOL BMC 硬件管理 opcua opcda KEPServer安装 zabbix oneapi DeepSeek 分析解读 rime W5500 OLED u8g2 TCP服务器 pdf web安全 中间件 iis 多线程服务器 Linux网络编程 云服务 可信计算技术 密码学 springsecurity6 oauth2 授权服务器 token sas FTP 服务器 负载均衡 小艺 Pura X excel rsyslog 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 shell visualstudio prometheus kylin 银河麒麟操作系统 国产化 Trae IDE AI 原生集成开发环境 Trae AI jellyfin 监控k8s集群 集群内prometheus 驱动开发 硬件工程 嵌入式实习 VMware安装Ubuntu Ubuntu安装k8s OD机试真题 华为OD机试真题 服务器能耗统计 信号处理 网络药理学 生信 生物信息学 gromacs 分子动力学模拟 MD 动力学模拟 Kylin-Server 服务器安装 k8s集群资源管理 云原生开发 openvpn server openvpn配置教程 centos安装openvpn hadoop EasyConnect RAGFLOW Cline Kali Linux 黑客 渗透测试 信息收集 监控 ecmascript nextjs react reactjs vmware 卡死 自动化编程 黑客技术 redhat openwrt 流式接口 智能音箱 智能家居 llm 本地部署 api ssh漏洞 ssh9.9p2 CVE-2025-23419 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 网络结构图 ros2 moveit 机器人运动 express 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors 压测 ECS dba ssrf 失效的访问控制 远程 命令 执行 sshpass 操作 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 开发环境 SSL证书 n8n dity make okhttp wireshark 显示过滤器 ICMP Wireshark安装 list pygame 交换机 telnet 远程登录 xrdp 远程连接 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm arkUI NFS 群晖 文件分享 odoo 服务器动作 Server action NPS 雨云服务器 雨云 gitee yum 能力提升 面试宝典 技术 IT信息化 环境迁移 实战案例 ArcTS 登录 ArcUI GridItem 交叉编译 visual studio code 直播推流 毕设 华为认证 网络工程师 拓扑图 远程控制 远程看看 远程协助 服务器主板 AI芯片 gitea 媒体 微信公众平台 android studio 交互 linux上传下载 C语言 无人机 程序员 svn TRAE 三级等保 服务器审计日志备份 P2P HDLC 思科 状态管理的 UDP 服务器 Arduino RTOS Google pay Apple pay webstorm 小游戏 五子棋 dify matlab bootstrap html redis 代码调试 ipdb RAID RAID技术 磁盘 存储 css Invalid Host allowedHosts vue docker compose nvidia mybatis postgresql VMware创建虚拟机 AI代码编辑器 强制清理 强制删除 mac废纸篓 软件工程 压力测试 游戏程序 ios 实时音视频 实时互动 自动驾驶 视觉检测 xml gpt-3 文心一言 设计模式 混合开发 环境安装 JDK 腾讯云 Ark-TS语言 安全架构 网络攻击模型 课程设计 mysql离线安装 ubuntu22.04 mysql8.0 transformer spring cloud 源码 毕业设计 etcd 数据安全 RBAC thingsboard 串口服务器 企业微信 Linux24.04 deepin centos-root /dev/mapper yum clean all df -h / du -sh 宝塔面板 部署 mamba 金融 京东云 命令行 基础入门 编程 腾讯云大模型知识引擎 cmos 硬件 hive Hive环境搭建 hive3环境 Hive远程模式 Java IIS .net core Hosting Bundle .NET Framework vs2022 重启 排查 系统重启 日志 原因 测试用例 功能测试 产测工具框架 IMX6ULL 管理框架 磁盘监控 线程 服务器配置 硬件架构 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 报错 开发 gitlab springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 Reactor C++ KylinV10 麒麟操作系统 虚拟机 Vmware openEuler JAVA rdp 实验 fpga开发 飞牛NAS 飞牛OS MacBook Pro 王者荣耀 Wi-Fi DNS Ubuntu Server Ubuntu 22.04.5 系统开发 binder 车载系统 framework 源码环境 iBMC UltraISO lio-sam SLAM uv Node-Red 编程工具 流编程 云电竞 云电脑 todesk wps 安卓 设备 GPU PCI-Express Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 Linux PID UOS 统信操作系统 多进程 SSH 工作流 workflow linux安装配置 firewalld 办公自动化 自动化生成 pdf教程 KVM ping++ 深度优先 图论 并集查找 换根法 树上倍增 arcgis gaussdb ruoyi DeepSeek行业应用 Heroku 网站部署 CentOS Stream CentOS Cookie 游戏机 iftop 网络流量监控 SWAT 配置文件 服务管理 网络共享 nuxt3 开机自启动 ShenTong mariadb Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer virtualenv IIS服务器 IIS性能 日志监控 next.js 部署next.js ue4 着色器 虚幻 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 蓝桥杯 pyautogui ocr mongodb micropython esp32 mqtt 数据分析 Vmamba QQ bot Docker 算力 ansible 银河麒麟服务器操作系统 系统激活 Redis Desktop windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 OpenManus 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 hibernate 进程信号 CLion 系统安全 rclone AList webdav fnOS 漏洞 kind CH340 串口驱动 CH341 uart 485 同步 备份 建站 图像处理 安全威胁分析 grafana IPMI 医疗APP开发 app开发 bug matplotlib 弹性计算 裸金属服务器 弹性裸金属服务器 Open WebUI p2p 跨域 unity3d asp.net大文件上传 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 网络穿透 Xterminal ollama下载加速 服务器繁忙 springboot safari Mac 系统 矩阵 致远OA OA服务器 服务器磁盘扩容 服务器管理 配置教程 网站管理 playbook 剧本 linux 命令 sed 命令 CORS RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 dns npm 博客 kali 共享文件夹 WebUI DeepSeek V3 工业4.0 arm 大模型微调 权限 mosquitto 微信开放平台 微信公众号配置 log4j yum源切换 更换国内yum源 sqlite AI写作 prompt MS Materials openssl 自动化运维 minicom 串口调试工具 fd 文件描述符 蓝耘科技 元生代平台工作流 ComfyUI code-server echarts 信息可视化 网页设计 灵办AI kvm 模拟实现 AISphereButler 单元测试 集成测试 kamailio sip VoIP 大数据平台 edge浏览器 免费域名 域名解析 minio docker命令大全 图形化界面 毕昇JDK 回显服务器 UDP的API使用 cocoapods xcode DocFlow 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 做raid 装系统 armbian u-boot ubuntu24 vivado24 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 版本 GCC crosstool-ng gcc yolov8 边缘计算 Linux的权限 Kali 渗透 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 ftp web 升级 CVE-2024-7347 tensorflow 田俊楠 uniapp web3 健康医疗 tcp elk vscode1.86 1.86版本 ssh远程连接 open Euler dde Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 big data pgpool opensearch helm langchain deep learning 监控k8s 监控kubernetes 端口测试 实习 Ubuntu22.04 开发人员主页 trea idea c 单一职责原则 open webui 3d IMM Claude CrewAI spark HistoryServer Spark YARN jobhistory qemu libvirt asp.net大文件上传下载 VSCode 信号 移动云 反向代理 cnn DenseNet Jellyfin GoogLeNet zookeeper 搜索引擎 nfs 服务器部署ai模型 SSL 域名 Anolis nginx安装 linux插件下载 rustdesk 沙盒 键盘 can 线程池 金仓数据库 2025 征文 数据库平替用金仓 MacMini 迷你主机 mini Apple 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR 宠物 免费学习 宠物领养 宠物平台 GIS 遥感 WebGIS 代理服务器 Docker Compose USB网络共享 鲲鹏 昇腾 npu ssh远程登录 大大通 第三代半导体 碳化硅 游戏引擎 虚幻引擎 Windows ai工具 v10 软件 ldap 嵌入式系统开发 多个客户端访问 IO多路复用 TCP相关API VR手套 数据手套 动捕手套 动捕数据手套 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 h.264 docker run 数据卷挂载 交互模式 URL 北亚数据恢复 oracle数据恢复 程序员创富 输入法 selete 高级IO 数学建模 conda配置 conda镜像源 SSE 技能大赛 XCC Lenovo LLM Web APP Streamlit 网卡的名称修改 eth0 ens33 繁忙 解决办法 替代网站 汇总推荐 AI推理 网工 av1 电视盒子 机顶盒ROM 魔百盒刷机 远程服务 MI300x sonoma 自动更新 SRS 流媒体 直播 xshell termius iterm2 环境配置 neo4j 数据仓库 数据库开发 数据库架构 database Deepseek-R1 私有化部署 推理模型 skynet eNSP 网络规划 VLAN 企业网络 稳定性 看门狗 IM即时通讯 剪切板对通 HTML FORMAT vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 jvm linux环境变量 大模型部署 keepalived embedding PPI String Cytoscape CytoHubba 视频编解码 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 Ubuntu 24.04.1 轻量级服务器 人工智能生成内容 dash 正则表达式 DBeaver kerberos chrome devtools chromedriver 自动化测试 性能测试 阿里云ECS 常用命令 文本命令 目录命令 崖山数据库 YashanDB python3.11 LORA NLP searxng 远程过程调用 Windows环境 es openstack Xen 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 相差8小时 UTC 时间 Cursor docker-compose netty nac 802.1 portal QT 5.12.12 QT开发环境 Ubuntu18.04 无桌面 risc-v 互联网医院 less swoole Playwright FTP服务器 HarmonyOS OpenHarmony 真机调试 黑苹果 sdkman sequoiaDB ROS 聚类 软考 程序 性能分析 计算机 图形渲染 联想开天P90Z装win10 ceph prometheus数据采集 prometheus数据模型 prometheus特点 宕机切换 服务器宕机 相机 强化学习 tidb GLIBC 执法记录仪 智能安全帽 smarteye yaml Ultralytics 可视化 alias unalias 别名 互信 ecm bpm 虚拟局域网 深度求索 私域 知识库 Minecraft 信创 信创终端 中科方德 DOIT 四博智联 centos 7 sqlite3 显卡驱动 单例模式 大模型应用 MCP server C/S windows日志 SSH 密钥生成 SSH 公钥 私钥 生成 本地化部署 jina 匿名管道 考研 H3C iDRAC R720xd frp seatunnel freebsd 虚拟显示器 wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 序列化反序列化 ros 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 composer XFS xfs文件系统损坏 I_O error iperf3 带宽测试 ruby seleium flash-attention Linux的基础指令 前后端分离 私有化 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 双系统 GRUB引导 Linux技巧 Ubuntu共享文件夹 共享目录 Linux共享文件夹 FunASR ASR file server http server web server 云桌面 微软 AD域控 证书服务器 个人博客 X11 Xming 集成学习 RAGFlow MySql glibc 英语 邮件APP 免费软件 aarch64 编译安装 HPC 数据管理 数据治理 数据编织 数据虚拟化 我的世界 我的世界联机 数码 知识图谱 idm LInux 树莓派 VNC 阻塞队列 生产者消费者模型 服务器崩坏原因 域名服务 DHCP 符号链接 配置 jetty undertow ubuntu24.04.1 grub 版本升级 扩容 软负载 本地部署AI大模型 HiCar CarLife+ CarPlay QT RK3588 ISO镜像作为本地源 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 Erlang OTP gen_server 热代码交换 事务语义 链表 MNN Qwen rnn ip 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 deepseek r1 音乐服务器 Navidrome 音流 fast make命令 makefile文件 dns是什么 如何设置电脑dns dns应该如何设置 银河麒麟桌面操作系统 Kylin OS MQTT协议 消息服务器 代码 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 iphone pppoe radius hugo Netty 即时通信 NIO 思科模拟器 Cisco saltstack 运维监控 vasp安装 镜像 AI作画 聊天室 技术共享 目标跟踪 OpenVINO 推理应用 epoll AI agent Radius 文件系统 路径解析 qt项目 qt项目实战 qt教程 muduo 代理 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP SysBench 基准测试 cd 目录切换 物联网开发 Attention 社交电子 宝塔 EMQX 通信协议 计算虚拟化 弹性裸金属 SEO chfs ubuntu 16.04 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? 显示管理器 lightdm gdm AI-native Docker Desktop Dell HPE 联想 浪潮 指令 vscode 1.86 x64 SIGSEGV xmm0 RAG 检索增强生成 文档解析 大模型垂直应用 直流充电桩 充电桩 策略模式 miniapp 调试 debug 断点 网络API请求调试方法 sublime text bcompare Beyond Compare 模拟器 教程 xpath定位元素 火绒安全 curl wget Nuxt.js 内网服务器 内网代理 内网通信 HTTP 服务器控制 ESP32 DeepSeek 设置代理 实用教程 备选 网站 调用 示例 AD域 历史版本 下载 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 etl cursor 自动化任务管理 UOS1070e easyui nlp AutoDL EMUI 回退 降级 gnu SSH 服务 SSH Server OpenSSH Server c/c++ 串口 小智AI服务端 xiaozhi TTS 业界资讯 AD 域管理 模拟退火算法 飞牛nas fnos 网站搭建 serv00 推荐算法 apt 银河麒麟高级服务器 外接硬盘 Kylin 华为机试 用户缓冲区 数据库系统 支付 微信支付 开放平台 ArkTs ArkUI 自定义客户端 SAS Xinference Mac内存不够用怎么办 元服务 应用上架 进程优先级 调度队列 进程切换 我的世界服务器搭建 minecraft 李心怡 AzureDataStudio 项目部署到linux服务器 项目部署过程 perl fonts-noto-cjk kernel Python基础 Python教程 Python技巧 NLP模型 autodl WLAN maxkb ARG deekseek 影刀 #影刀RPA# Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 sysctl.conf vm.nr_hugepages 软链接 硬链接 su sudo Headless Linux TrueLicense figma WebVM 飞牛 基础环境 流水线 脚本式流水线 ubuntu20.04 开机黑屏 存储维护 NetApp存储 EMC存储 GameFramework HybridCLR Unity编辑器扩展 自动化工具 超融合 僵尸世界大战 游戏服务器搭建 java-rocketmq 语音识别 内网环境 架构与原理 banner opengl 浏览器开发 AI浏览器 本地知识库部署 DeepSeek R1 模型 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 热榜 7z cpp-httplib CDN 烟花代码 烟花 元旦 perf linux内核 powerpoint 防火墙 NAT转发 NAT Server Unity Dedicated Server Host Client 无头主机 安卓模拟器 网络建设与运维 网络搭建 神州数码 神州数码云平台 云平台 Typore 磁盘清理 服务网格 istio ArtTS 本地环回 bind axure 富文本编辑器 sentinel 多路转接 firewall 区块链 midjourney cfssl TCP协议 抗锯齿 Mermaid 可视化图表 代码托管服务 css3 word Linux环境 鸿蒙开发 移动开发 Logstash 日志采集 佛山戴尔服务器维修 佛山三水服务器维修 语法 milvus Zoertier 内网组网 加解密 Yakit yaklang 项目部署 干货分享 黑客工具 密码爆破 捆绑 链接 谷歌浏览器 youtube google gmail MVS 海康威视相机 db virtualbox 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 dock 加速 tailscale derp derper 中转 triton 模型分析 线性代数 电商平台 服务器时间 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 regedit 开机启动 搭建个人相关服务器 hosts OpenSSH webgl IPv4 子网掩码 公网IP 私有IP 主从复制 rancher 安防软件 onlyoffice 在线office 软件构建 玩机技巧 软件分享 软件图标 iventoy VmWare OpenEuler IDEA HarmonyOS NEXT 原生鸿蒙 计算生物学 生物信息 基因组 移动魔百盒 USB转串口 harmonyOS面试题 nftables Spring Security rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK lua IO模型 游戏开发 带外管理 大模型技术 本地部署大模型 自学笔记 小米 澎湃OS Android 音乐库 deployment daemonset statefulset cronjob react native 读写锁 AI Agent 字节智能运维 大模型推理 端口 查看 ss xss g++ g++13 DIFY lb 协议 Qwen2.5-VL vllm 分布式训练 IMX317 MIPI H265 VCU SVN Server tortoise svn yolov5 eclipse navicat 根服务器 clickhouse HAProxy DeepSeek r1 K8S k8s管理系统 junit 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 虚拟现实 llama.cpp win服务器架设 windows server laravel 需求分析 规格说明书 bat 状态模式 docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 离线部署dify docker部署Python 企业网络规划 华为eNSP VS Code 查询数据库服务IP地址 SQL Server 嵌入式Linux IPC 中兴光猫 换光猫 网络桥接 自己换光猫 vpn wpf 多端开发 智慧分发 应用生态 鸿蒙OS 智能电视 WSL2 上安装 Ubuntu EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 k8s二次开发 集群管理 flink PX4 kotlin ELF加载 端口聚合 windows11 ardunio BLE WebServer System V共享内存 进程通信 cmake qt5 客户端开发 CosyVoice AI员工 ros1 Noetic 20.04 apt 安装 华为证书 HarmonyOS认证 华为证书考试 docker desktop image MAVROS 四旋翼无人机 ABAP yum换源 fork wait waitpid exit 服务器扩容没有扩容成功 风扇控制软件 网络爬虫 视频平台 录像 视频转发 视频流 授时服务 北斗授时 工具 python2 ubuntu24.04 服务器部署 本地拉取打包 nosql csrutil mac恢复模式进入方法 恢复模式 内核 问题解决 显示器 极限编程 论文阅读 安装MySQL 通信工程 毕业 Web服务器 多线程下载工具 PYTHON 多产物 浪潮信息 AI服务器 proxy模式 Reactor反应堆 性能调优 安全代理 iNode Macos 网络文件系统 Web应用服务器 windows 服务器安装 查看显卡进程 fuser lvm 磁盘挂载 磁盘分区 Helm k8s集群 vnc ebpf uprobe 合成模型 扩散模型 图像生成 zip unzip nvm whistle Carla 智能驾驶 Linux 维护模式 ROS2 scapy 电视剧收视率分析与可视化平台 ranger MySQL8.0 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 samba 流量运营 Mac软件 java-rabbitmq shell脚本免交互 expect linux免交互 宝塔面板无法访问 大屏端 Sealos 软件卸载 系统清理 mcp服务器 client close scikit-learn burp suite 抓包 容器技术 stable diffusion copilot docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 代码规范 网页服务器 web服务器 Nginx Unity插件 浏览器自动化 达梦 DM8 ip协议 对比 meld DiffMerge export import save load 迁移镜像 fstab top Linux top top命令详解 top命令重点 top常用参数 欧标 OCPP UDP 输入系统 visual studio IO ubuntu 18.04 vu大文件秒传跨域报错cors 粘包问题 Apache Beam 批流统一 案例展示 数据分区 容错机制 rpa 机柜 1U 2U notepad Linux find grep 钉钉 netlink libnl3 隐藏文件 隐藏目录 管理器 通配符 抓包工具 React Next.js 开源框架 云耀服务器 tar 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 智慧农业 开源鸿蒙 团队开发 跨平台 联机 僵尸毁灭工程 游戏联机 开服 mysql安装报错 windows拒绝安装 powerbi 生活 Linux权限 权限命令 特殊权限 MDK 嵌入式开发工具 论文笔记 Alexnet CPU 使用率 系统监控工具 linux 命令 MAC SecureCRT 开源软件 图片增强 增强数据 话题通信 服务通信 UEFI Legacy MBR GPT U盘安装操作系统 hexo wsgiref Web 服务器网关接口 国产数据库 瀚高数据库 数据迁移 下载安装 oracle fusion oracle中间件 cron crontab日志 MacOS 硅基流动 ChatBox Docker快速入门 服务器正确解析请求体 接口优化 DevOps 软件交付 数据驱动 西门子PLC 通讯 VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 MobaXterm 文件传输 卷积神经网络 弹性服务器 js xfce 零售 联网 easyconnect WINCC 服务器ssl异常解决 macOS Chatbox 蓝牙 搜狗输入法 中文输入法 ubuntu安装 linux入门小白 zerotier NFC 近场通讯 智能门锁 解决方案 工具分享 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 数字证书 签署证书 镜像下载