最新资讯

  • 【IO多路转接】IO 多路复用之 select:从接口解析到服务器实战

【IO多路转接】IO 多路复用之 select:从接口解析到服务器实战

2026-01-30 18:40:51 栏目:最新资讯 1 阅读



半桔:个人主页

 🔥 个人专栏: 《IO多路转接》《手撕面试算法》《C++从入门到入土》

🔖当你一无所有,你没有什么可以失去。《泰坦尼克号》

文章目录

  • 前言
  • 一. 五种IO模型
  • 二. select实现多路转接
    • 2.1 select接口
    • 2.2 select服务器实现
      • 2.2.1 对网络套接字进行封装
      • 2.2.2 构建出服务器类
      • 2.2.3 进行初始化
      • 2.2.4 获取要进行等待的fd_set对象
      • 2.2.5 对读写事件就绪的文件进行处理
      • 2.2.6 服务器主循环
  • 三. select 的优缺点

前言

在网络编程领域,IO 模型是支撑高效通信的核心基础之一。当需要让单个进程或线程同时处理多个网络连接的 IO 事件时,“IO 多路复用(多路转接)” 技术成为了关键解法 —— 它能让程序通过少量进程 / 线程,高效监控并处理多个 IO 事件,极大提升系统对 IO 资源的利用效率。

select作为 IO 多路复用模型中经典且具有代表性的实现,是开发者接触 “多路转接” 的重要入门点。尽管随着技术演进,它逐渐显现出一些局限性,但深入理解select的工作机制、使用逻辑及其优缺点,不仅能帮助我们掌握 “单进程管理多连接” 的核心思路,更是学习更先进多路复用技术(如pollepoll)的重要前提。

本文将围绕 “select 实现多路转接” 展开,从select接口的基本定义入手,逐步讲解基于select的多路转接服务器实现(包含套接字封装、初始化流程、fd_set对象操作及服务器主循环设计等),最后剖析select自身的优势与不足。希望通过对这些内容的梳理,能让读者清晰把握select在多路 IO 转接中的核心作用,为后续 IO 模型学习与网络编程实践筑牢基础。

在介绍select这三种多路转接的IO模型之前,有必要先介绍以下5中IO模型分别是哪几种。

一. 五种IO模型

我们在操作系统中直接调用,read && write将数据读取上来,其本质就是将数据从用户层拷贝到操作系统中/从操作系统中拷贝到用户层——就是“拷贝”;

  • 虽然我们通过拷贝来发送/获取数据,但是我们必须要明确一个概念:IO = 等数据 + 拷贝,而不仅仅是对数据进行拷贝;
  • 对于写于要等发送缓冲区中有位置,对于读取要等接收缓冲区中有数据。

因此在进行拷贝之前,必须先判断条件是否成立,也就是读写事件是否就绪

我们通常定义高效IO指的是:单位时间内,IO过程中,等的比重越小,效率越高。

下面介绍五种IO模型:

  1. 阻塞性:直到 “等待数据就绪” 和 “数据拷贝” 两个阶段完全完成,IO 调用才返回;
  2. 非阻塞性:等待数据就绪阶段不阻塞(内核会立即返回结果),即若数据未就绪,内核会返回 EAGAINEWOULDBLOCK 错误;
  3. 信号驱动型:用一个线程监控多个 IO,避免进程在单个未就绪 IO 上阻塞
  4. 多路复用/多路转接型:让内核在 IO 数据就绪时主动发送SIGIO信号通知进程来拿取数据;
  5. 异步IO型:应用进程发起异步 IO 调用后,两个阶段(等待就绪、数据拷贝)均由内核完成,全程不阻塞进程。内核在完成所有操作后,通过 “信号” 或 “回调函数” 通知进程,进程直接使用已拷贝到用户缓冲区的数据。
  • 对于阻塞IO和非阻塞IO在效率上并没有什么区别,只不过非阻塞IO在不等待期间可以做其他事情,因此我们通常说它的效率更高一些。

下面介绍实现多路转接IO的3中方式。

二. select实现多路转接

关于select实现多路转接,此处将分为两部分进行介绍:

  1. 介绍select的接口;
  2. 使用select实现一个简单的ech服务器。

2.1 select接口

select可以一次等待多个文件,当有一个文件就绪了就返回,这样可以一次性等待多个文件,提高了等待的效率。

int select(int nfds , fd_set *readfds , fd_set *writefds , fd_set *expectfds , struct timeval *timeout*);

该就接口就是select的等待接口:

  1. 参数一nfds:标识等待的文件描述符中最大的 + 1;

fd_set是内核提供的一种数据结构,其本质是一张位图,记录着要关心的文件描述符。
2. 参数二readfds:是一个结构体,记录要关心读事件就绪的文件描述符;
3. 参数三writefds:记录要关心写事件就绪的文件描述符;
4. 参数四expectfds:记录要关心异常事件的文件描述符;

struct timeval也是内核提供的一种结构体,用于记录select要进行等待的事件:

struct timeval {
    time_t      tv_sec;     /* seconds */
    suseconds_t tv_usec;    /* microseconds */
};

当时间到达/有文件读写时间就绪就会进行返回。

  1. 参数五timeval:标识select等待的时间,如果等待时间到了,还没有一个文件读写时间就绪select也会进行返回,传nullptr标识阻塞式的等待;
  2. 返回值:一个整形,标识就绪的文件描述符的个数。

上面的fd_set是操作系统提供给我们的数据结构,我们不能直接对该数据结构进行操作,而应该使用操作系统提供的接口来进行操作:

  • void FD_ZERO(fd_set *set):将位图全部请零,用于初始化;
  • void FD_SET(int fd , fd_set *set):将fd文件描述符添加到位图中;
  • void FD_CLR(int fd , fd_set *set):将fd文件描述符从位图中移除;
  • void FD_ISSET(int fd , fd_set *set):检查fd文件描述符是否在位图中。

如果有文件描述符就绪,操作系统怎么告诉我们是那些文件就绪了???

为了让操作系统能够通知我们,select接口的后4个参数被设计为输入输出型参数

  1. readfds输出来告诉,那些文件描述符的读事件已经就绪;
  2. writefdsexpectfds也一样;
  3. timeval告诉我们,距离规定的返回时间还剩余多久。

select使用的是内核提供的现成的数据结构fd_set,因此这也就意味着其可以监视的文件描述符的数量是有限的,可以通过sizeof(fd_set)*8来计算出来。

2.2 select服务器实现

为了方便理解,我们实现一个简单的服务器,将用户发送过来的数据在前面添加一个server got a message后直接进行返回。

2.2.1 对网络套接字进行封装

首先我们先对网络套接字的接口进行封装:创建套接字,绑定,监听;关于这方面的知识可以查看之前的TCP相关内容,此时就直接贴实现方法:

const std::string defaultip_ = "0.0.0.0";

enum SockErr
{
    SOCKET_Err,
    BIND_Err,
};

class Sock
{
public:
    Sock(uint16_t port)
        : port_(port),
          listensockfd_(-1)
    {
    }
    void Socket()
    {
        listensockfd_ = socket(AF_INET, SOCK_STREAM, 0);
        if (listensockfd_ < 0)
        {
            Log(Fatal) << "socket fail";
            exit(SOCKET_Err);
        }
        Log(Info) << "socket sucess";
    }
    void Bind()
    {
        struct sockaddr_in server;
        server.sin_family = AF_INET;
        server.sin_port = htons(port_);
        inet_pton(AF_INET, defaultip_.c_str(), &server.sin_addr);
        if (bind(listensockfd_, (struct sockaddr *)&server, sizeof(server)) < 0)
        {
            Log(Fatal) << "bind fail";
            exit(BIND_Err);
        }
        Log(Info) << "bind sucess";
    }
    void Listen()
    {
        if (listen(listensockfd_, 10) < 0)
        {
            Log(Warning) << "listen fail";
        }
        Log(Info) << "listen sucess";
    }
    int Accept()
    {
        struct sockaddr_in client;
        socklen_t len = sizeof(client);
        int fd = accept(listensockfd_ , (sockaddr*)&client , &len);
        if(fd < 0)
        {
            Log(Warning) << "accept fail";
        }
        return fd;
    }
    int Accept(std::string& ip , uint16_t& port)
    {
        struct sockaddr_in client;
        socklen_t len = sizeof(client);
        int fd = accept(listensockfd_ , (sockaddr*)&client , &len);
        if(fd < 0)
        {
            Log(Warning) << "accept fail";
        }

        port = ntohs(client.sin_port);
        char bufferip[64];
        inet_ntop(AF_INET , &client.sin_addr , bufferip , sizeof(bufferip) - 1);
        ip = bufferip;

        return fd;
    }
    int Get_fd()
    {
        return listensockfd_;
    }
    ~Sock()
    {
        close(listensockfd_);
    }

private:
    uint16_t port_;
    int listensockfd_;
};```

下面就来实现selectserver服务器:

2.2.2 构建出服务器类

首先就是构造出Selectserver类来对服务器进行管理:

  1. 首先需要一个Sock对象,进行TCP通信;
  2. 接着我们需要使用一个容器来存储所有要进行等待读写事件就绪的容器,此处为了简单我们直接使用一个数组来实现,该数组的大小就是fd_set能够等待的文件个数;
  3. 此处我们假设TCP接收到的就是完整报文,因此就不设置writefds的位图了,理论上是要进行设置的,大家可以自行实现以下;
const int fds_num_max = sizeof(fd_set) * 8;
const int defaultfd = -1;

class Selectserver
{
public:
    Selectserver(uint16_t port)
        : _sock_ptr(new Sock(port))
    {
        for (int i = 0; i < fds_num_max; i++)
        {
            _fds_array[i] = defaultfd;
        }
    }

private:
    std::shared_ptr<Sock> _sock_ptr;
    int _fds_array[fds_num_max]; // 该数组用来存储select要进行等待的文件描述符,初始值为-1
};

下一步就是进行初始化:

2.2.3 进行初始化

初始化一共就分为4个步骤:

  1. 创建套接字;
  2. 进行绑定;
  3. 设置监听模式;
  4. 将套接字添加到_fd_array数组中。

对于前三个步骤在前面我们已经进行封装过来,因此,此处可以直接进行调用。

  • 对于第四个步骤来说:我们在与客户端建立连接的时候,不知道什么时候客户端来进行连接,因此也需要进行等待,而这一等待工作本质上是在等待Sock指向的套接字文件,因此也应该使用select进行等待。

以下是具体实现:

    void AddToArray(int fd)
    {
        int pos = 0;
        for(; pos < fds_num_max && _fds_array[pos] != defaultfd ; pos++)
        ;

        if(pos == fds_num_max)
        {
            // select已经到达监听极限了,不能再添加要进行监听的文件了

            // 1. 关闭文件
            // 2. 打印日志

            close(fd);
            Log(Warning) << "select is full";
        }
        else
        {
            // 1. 有位置直接进行添加
            _fds_array[pos] = fd;
            Log(Info) << "add a new fd : " << fd;
        }
    }

    void Init()
    {
        // 1. 创建套接字
        // 2. 绑定
        // 3. 设置监听
        // 4. 将套接字描述符加入到_fds_array数组中

        _sock_ptr->Socket();
        _sock_ptr->Bind();
        _sock_ptr->Listen();
        AddToArray(_sock_ptr->Get_fd());
    }

2.2.4 获取要进行等待的fd_set对象

我们此处设计的select接口并不考虑writefdsexpectfds,因此我们只需要实现初始化传入的readfds接口即可,我们需要有一个已经设置好了的fd_set,以及一个其中最大的文件描述符,因此此处使用一个pair作为返回值。

    std::pair<fd_set , int> Get_readfds()
    {
        // 1. 对位图进行初始化
        // 2. 循环遍历_fds_array数组,将要进行等待的文件描述符添加到位图中

        int max_num = 0;
        fd_set readfds;
        FD_ZERO(&readfds);
        for (int i = 0; i < fds_num_max; i++)
        {
            if (_fds_array[i] == -1)
                continue;
            FD_SET(_fds_array[i], &readfds);
            max_num = std::max(max_num , _fds_array[i]);
        }
        return std::make_pair(readfds , max_num);
    }

2.2.5 对读写事件就绪的文件进行处理

select等待后,存在文件描述符就绪,就需要将这些文件描述符对应的数据拿上来。
而文件描述符又分为两种:

  1. 是Sock套接字文件描述符,要将已经建立好连接的文件描述符拿上来;
  2. 普通文件描述符,直接将输入缓冲区中的数据拿上来。
    // 是套接字就绪
    void Sockfd_Ready()
    {
        // 1. 将套接字中建立好的连接拿上来
        // 2. 将拿上来的文件描述符加入到_fds_array中,等到客户端发送消息过来

        int fd = _sock_ptr->Accept();
        AddToArray(fd);
    }

    // fd表示文件描述符 , i表示在数组中的位置
    void Normalfd_Ready(int fd , int i)
    {
        // 1. 读取文件描述符中的数据
        // 2. 将数据简单处理后,进行返回(此处假设TCP接收的报文是完整的)

        char inbuffer[1024];
        int n = read(fd , inbuffer , sizeof(inbuffer) - 1);
        if(n > 0)
        {
            inbuffer[n] = 0;
            std::string ret = "server got a message : ";
            ret += inbuffer;

            write(fd , ret.c_str() , ret.size());
        }
        else  if(n == 0)
        {
            // 对方已经关闭文件

            // 1. 将在_fds_array中的对应位置设为-1表示已经被移除了,不需要再进行等待
            // 2. 关闭文件描述符
            _fds_array[i] = defaultfd;
            close(fd);
        }
        else
        {
            // 出错了
            Log(Error) << "read fail";
        }
    }

2.2.6 服务器主循环

  1. 进行select等待;
  2. 有文件描述符就绪,识别对应的文件描述符,将任务进行派发,看交给哪一个函数进行完成。
    void Dispather(fd_set* fdreads)
    {
        int listensock = _sock_ptr->Get_fd();
        for(int i = 0 ; i < fds_num_max ; i++)
        {
            if(_fds_array[i] == defaultfd || !FD_ISSET(_fds_array[i] , fdreads)) continue;
            
            if(_fds_array[i] == listensock) 
            {
                Sockfd_Ready();
            }
            else
            {
                Normalfd_Ready(_fds_array[i] , i);
            }
        }
    }

    void Run()
    {
        while (true)
        {
            auto [fdreads , max_num] = Get_readfds();
            int n = select(max_num + 1 , &fdreads , nullptr , nullptr , nullptr);
            if(n > 0)
            {
                // 有事件就绪, 进行任务的派发
                Dispather(&fdreads);
            }
            else if(n == 0)
            {
                Log(Info) << "no file";
            }
            else
            {
                Log(Error) << "select fail";
            }
        }
    }

以上就是整个selectserver类的实现了。

三. select 的优缺点

优点:

  1. 所有的等待交给select来做,只要有读事件就绪就通知上层来将数据取走;
  2. 多路转接,在单进程的情况下能够处理多个用户的请求;

缺点:

  1. 使用的是内核提供的数据结构fd_set,等待的文件描述符的数量是有限的;
  2. 输入输出型参数使用起来麻烦,并且每次进行select的时候都要进行重新设置;
  3. 要将fd_set从用户层拷贝到内核中,又要拷贝回来,拷贝数据频繁;
  4. 使用第三方数组对用户的fd进行管理,用户称需要进行多次遍历,内核在进行检测的时候也要进行多次遍历。

后续文章中我们将讲解select的替代方案:pollepoll.

本文地址:https://www.yitenyun.com/3485.html

搜索文章

Tags

#ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 #服务器 #python #pip #conda #远程工作 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #fastapi #html #css #进程控制 #低代码 #爬虫 #音视频 #cpolar #docker #后端 #数据库 #Trae #IDE #AI 原生集成开发环境 #Trae AI #内网穿透 #网络 #开发语言 #云原生 #iventoy #VmWare #OpenEuler #人工智能 #node.js #Conda # 私有索引 # 包管理 #开源 #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #MobaXterm #ubuntu #vscode #mobaxterm #深度学习 #计算机视觉 #android #腾讯云 #c# #kylin #物联网 #websocket #tcp/ip #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #学习 #算法 #大数据 #web安全 #安全 #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #nginx #claude #华为 #ModelEngine #架构 #mvp #个人开发 #设计模式 #java #github #git #金融 #大模型 #mcp #金融投资Agent #Agent #我的世界 #n8n #本地部署 #windows #hadoop #hbase #hive #zookeeper #spark #kafka #flink #ssh #qt #C++ #云计算 #我的世界服务器搭建 #minecraft #udp #c++ #c语言 #网络协议 #jar #面试 #http #cpp #项目 #高并发 #NPU #CANN #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #vue.js #前端 #vue #阿里云 #screen 命令 #stm32 #macos #JumpServer #堡垒机 #振镜 #振镜焊接 #ide #AI编程 #单元测试 #集成测试 #pycharm #gpu算力 #DisM++ # GLM-4.6V # 系统维护 #京东云 #性能优化 #SRS #流媒体 #直播 #守护进程 #复用 #screen #YOLOFuse # Base64编码 # 多模态检测 #unity3d #游戏 #服务器框架 #Fantasy #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #缓存 #mamba #Android #Bluedroid #智能手机 #压力测试 #MCP #科技 #自然语言处理 #神经网络 #libosinfo #todesk #jenkins #unity #游戏引擎 #需求分析 #scala #测试用例 #测试工具 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #MCP服务器 #flask #spring boot #部署 #GPU服务器 #8U #硬件架构 #fiddler #智能路由器 #5G #centos #C2000 #TI #实时控制MCU #AI服务器电源 #运维开发 #mysql #东方仙盟 #银河麒麟 #系统升级 #信创 #国产化 #1024程序员节 #嵌入式硬件 #SAP #ebs #metaerp #oracle ebs #编辑器 #DeepSeek #蓝耘智算 #910B #昇腾 #AIGC #ida #ai #搜索引擎 #Anaconda配置云虚拟环境 #pytorch #密码学 #可信计算技术 #华为云 #测评 #CCE #Dify-LLM #Flexus #Nacos #web #微服务 #cursor #elasticsearch #django #web3.py #RustDesk #IndexTTS 2.0 #本地化部署 #麒麟OS #信息与通信 #信号处理 #tcpdump #ms-swift # 大模型 # 模型训练 #毕业设计 #车辆排放 #oracle #PyTorch # Triton # 高并发部署 #transformer #javascript #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #AI #工具集 #epoll #sqlite #php #java-ee #电气工程 #C# #PLC #单片机 #golang #rdp #sql #Dify #ARM架构 #鲲鹏 #jmeter #功能测试 #软件测试 #自动化测试 #职场和发展 #SSH反向隧道 # Miniconda # Jupyter远程访问 #EMC存储 #存储维护 #NetApp存储 #自动化 #maven #gitlab #课程设计 #yum #chatgpt #codex #NAS #Termux #Samba #Linux #三维 #3D #三维重建 #万悟 #联通元景 #智能体 #镜像 #微信小程序 #小程序 #微信 #健身房预约系统 #健身房管理系统 #健身管理系统 #react.js #debian #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #apache #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #risc-v #deepseek #SSH公钥认证 # PyTorch # 安全加固 #练习 #基础练习 #数组 #循环 #九九乘法表 #计算机实现 #经验分享 #dynadot #域名 #esb接口 #走处理类报异常 #bug菌问答团队 #vllm #YOLO #ffmpeg #数据分析 #数据挖掘 #CUDA #Triton #交互 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #语言模型 #昇腾300I DUO #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #intellij-idea #idea #intellij idea #dify #ui #microsoft #opencv #Qwen3-14B # 大模型部署 # 私有化AI #vnstat #监控 #redis #文心一言 #AI智能体 #vp9 #攻防演练 #Java web #漏洞 #红队 #leetcode #ssl #AI 推理 #NV #fpga开发 #LVDS #高速ADC #DDR #API限流 # 频率限制 # 令牌桶算法 #驱动开发 #chrome #处理器 #iBMC #UltraISO #黑群晖 #虚拟机 #无U盘 #纯小白 #支付 #数据结构 #SSH跳板机 # Python3.11 #排序算法 #Gunicorn #WSGI #Flask #并发模型 #容器化 #Python #性能调优 #蓝湖 #Axure原型发布 #gitea #screen命令 #jvm #门禁 #梯控 #智能一卡通 #门禁一卡通 #消费一卡通 #智能梯控 #一卡通 #源代码管理 #超时设置 #客户端/服务器 #网络编程 # 目标检测 #管道Pipe #system V #ai编程 #网络安全 #机器人 #llama #muduo库 #uv #uvx #uv pip #npx #Ruff #pytest #YOLO26 #目标检测 #操作系统 #国产化OS #milvus #springboot #知识库 #语音识别 #react native #web server #请求处理流程 #SSH # 批量管理 #ASR #SenseVoice #星图GPU #中间件 #MQTT协议 #交通物流 #C语言 #vivado license #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #html5 #asp.net #rocketmq #selenium #prometheus #grafana #svn #证书 #scrapy #fabric #postgresql #openHiTLS #TLCP #DTLCP #商用密码算法 #ONLYOFFICE #MCP 服务器 #laravel #tomcat # 双因素认证 # TensorFlow #毕设 #服务器繁忙 #蓝牙 #LE Audio #BAP #serverless #RAID #RAID技术 #磁盘 #存储 #嵌入式编译 #ccache #distcc #puppeteer #adb #连接数据库报错 #链表 #硬件工程 #智能家居 #动态规划 #负载均衡 #pyqt #进程 #进程创建与终止 #shell #xlwings #Excel #DNS #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 #安全威胁分析 #仙盟创梦IDE #C #ollama #llm #spring cloud #spring #Spring AI #STDIO传输 #SSE传输 #WebMVC #WebFlux #bootstrap #nfs #iscsi #企业微信 #SPA #单页应用 #visual studio code #prompt #大模型学习 #文件管理 #文件服务器 #swagger #树莓派4b安装系统 #mariadb #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #wsl #电脑 #LangGraph #CLI #JavaScript #langgraph.json #paddleocr #分布式 #KMS激活 #计算机网络 #jdk #排序 #ddos #系统架构 #CSDN #数据仓库 #numpy #wordpress #雨云 #LobeChat #vLLM #GPU加速 #人脸识别sdk #视频编解码 #人脸识别 #海外服务器安装宝塔面板 #翻译 #开源工具 #ansible #创业创新 #业界资讯 #openlayers #bmap #tile #server #langchain #大模型开发 #程序员 #大模型部署 #mindie #大模型推理 #CosyVoice3 # 语音合成 #机器学习 #Puppet # IndexTTS2 # TTS #TCP #客户端 #嵌入式 #DIY机器人工房 #x86_64 #数字人系统 #windows11 #系统修复 #说话人验证 #声纹识别 #CAM++ #rtsp #转发 #unix #信令服务器 #Janus #MediaSoup #其他 #SQL注入主机 #json #rust #CVE-2025-61686 #路径遍历高危漏洞 #大模型教程 #AI大模型 #结构体 #制造 #webrtc #idm #ping通服务器 #读不了内网数据库 #戴尔服务器 #戴尔730 #装系统 #渗透测试 #黑客技术 #计算机 #文件上传漏洞 #mcu #ThingsBoard MCP # GPU租赁 # 自建服务器 #推荐算法 #devops #HeyGem # 服务器IP访问 # 端口映射 #A2A #GenAI #遛狗 #SSE # AI翻译机 # 实时翻译 #bug #sqlserver #聊天小程序 #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #数据安全 #注入漏洞 # 一锤定音 # 大模型微调 #nodejs #https #SSH密钥 # CUDA #dba # ControlMaster #ETL管道 #RAG #向量存储 #数据预处理 #DocumentReader #硬件 #Fun-ASR # 语音识别 # WebUI #harmonyos #HarmonyOS APP #密码 #firefox #safari #LoRA # RTX 3090 # lora-scripts #Docker #具身智能 #spring ai #oauth2 #数据可视化 #nmodbus4类库使用教程 #docker-compose #目标跟踪 #rtmp #PowerBI #企业 #windbg分析蓝屏教程 #jupyter #AI电商客服 #arm开发 #le audio #低功耗音频 #通信 #连接 #ROS # 局域网访问 # 批量处理 #内存治理 #cosmic #googlecloud #串口服务器 #Modbus #IFix #VibeVoice # 高温监控 #c++20 # 远程连接 #fs7TF #Streamlit #Qwen #AI聊天机器人 #Buck #NVIDIA #算力 #交错并联 #DGX #Miniconda # 环境迁移 #大剑师 #nodejs面试题 #matplotlib #AutoDL #安全架构 #Llama-Factory # 树莓派 # ARM架构 #uni-app #H5 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #gerrit #opc ua #opc #npu #WT-2026-0001 #QVD-2026-4572 #smartermail #游戏机 # GLM-TTS # 数据安全 #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #xshell #host key #UDP的API使用 #TTS私有化 # IndexTTS # 音色克隆 #ESP32 # OTA升级 # 黄山派 #内网 # 网络延迟 #指针 #anaconda #虚拟环境 #GB28181 #SIP信令 #SpringBoot #视频监控 #远程软件 # Connection refused #系统管理 #服务 #teamviewer #Emby #视频 #代理服务器 #rsync # 数据同步 #ip #bash #Modbus-TCP #blender #设计师 #图像处理 #游戏美术 #技术美术 # ARM服务器 # 大模型推理 #claudeCode #content7 #跳槽 #工作 #挖矿 #Linux病毒 #turn #sql注入 #网安应急响应 #odoo #LLM #chat #微PE # GLM # 服务连通性 #azure #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #大语言模型 #ceph #ambari #arm #多线程 # 高并发 #appche #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #Ubuntu #aws #muduo #TcpServer #accept #高并发服务器 #哈希算法 #远程开发 #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #框架搭建 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #状态模式 #AI-native #LangFlow # 轻量化镜像 # 边缘计算 #Tokio #华为od #华为机试 #Java #OpenHarmony #版本控制 #Git入门 #开发工具 #代码托管 #SSH跳转 #TTS #openEuler #go # GPU集群 #Gateway #认证服务器集成详解 #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #ftp #sftp #samba #RSO #机器人操作系统 #个人博客 #glibc #媒体 #远程连接 #能源 #汽车 #cpu #Socket #套接字 #I/O多路复用 #字节序 #weston #x11 #x11显示服务器 #研发管理 #禅道 #禅道云端部署 #WinSCP 下载安装教程 #SFTP #FTP工具 #服务器文件传输 #计算几何 #斜率 #方向归一化 #叉积 #Ansible # CosyVoice3 # 批量部署 #集成学习 #AI写作 #winscp #AI部署 # ms-swift #PN 结 #后端框架 #服务器线程 # SSL通信 # 动态结构体 #RWK35xx #语音流 #实时传输 #node #超算中心 #PBS #lsf #excel #报表制作 #职场 #信息可视化 #用数据讲故事 #zabbix #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #深度优先 #DFS #语音生成 #lvs # 数字人系统 # 远程部署 #STUN # TURN # NAT穿透 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #前端框架 #.net #JNI #CPU #pxe #free #vmstat #sar #KMS #slmgr #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #rustdesk #p2p #可再生能源 #绿色算力 #风电 #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 #express #cherry studio #Node.js # child_process #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #网络攻击模型 #Discord机器人 #云部署 #程序那些事 #AI应用编程 # 自动化运维 #r语言 #mybatis #spine #若依 #TRO #TRO侵权 #TRO和解 #运维工具 #ipmitool #BMC # 黑屏模式 # TTS服务器 #前端开发 #EN4FE #领域驱动 #自由表达演说平台 #演说 #程序员创富 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #3d #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #系统安全 #embedding #IndexTTS2 # 阿里云安骑士 # 木马查杀 #范式 #入侵 #日志排查 #kmeans #聚类 #Karalon #AI Test #YOLOv8 # Docker镜像 #文件IO #输入输出流 #流程图 #论文阅读 #论文笔记 #图论 #国产开源制品管理工具 #Hadess #一文上手 #jetty #蓝桥杯 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #okhttp #代理模式 #Spring AOP #程序人生 #健康医疗 #人大金仓 #Kingbase #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #小艺 #鸿蒙 #搜索 #word #pdf #Smokeping #工程实践 #策略模式 #pve #GPU #租显卡 #训练推理 #时序数据库 #AI应用 #图像识别 #多进程 #python技巧 #高考 #企业级存储 #网络设备 #iot #软件工程 #生信 #国产操作系统 #麒麟 #V11 #kylinos #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #raid #raid阵列 #gpt #API #taro #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #wps #Linux多线程 #bigtop #hdp #hue #kerberos #pencil #pencil.dev #设计 #zotero #WebDAV #同步失败 #轻量化 #低配服务器 #Beidou #北斗 #SSR #Anything-LLM #IDC服务器 #私有化部署 #simulink #matlab #journalctl #aiohttp #asyncio #异步 #信息安全 #信息收集 #Langchain-Chatchat # 国产化服务器 # 信创 #软件 #本地生活 #电商系统 #商城 #高级IO #poll #PyCharm # 远程调试 # YOLOFuse #Playbook #AI服务器 #欧拉 #儿童AI #图像生成 #pjsip # 模型微调 #openresty #lua #智能体来了 #传统行业 #AI赋能 #Syslog #系统日志 #日志分析 #日志监控 #生产服务器问题查询 #日志过滤 #Autodl私有云 #深度服务器配置 # 水冷服务器 # 风冷服务器 #.netcore #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #SSH保活 # GLM-4.6V-Flash-WEB # AI部署 #everything #材料工程 #数码相机 #智能电视 #VMware创建虚拟机 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #AI生成 # outputs目录 # 自动化 #挖漏洞 #攻击溯源 #编程 #stl #漏洞修复 #IIS Crypto #warp #n8n解惑 #编程助手 #net core #kestrel #web-server #asp.net-core #elk #rabbitmq #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Prometheus #esp32 arduino #决策树 #Zabbix #语音合成 #HistoryServer #Spark #YARN #jobhistory #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #DooTask #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #Clawdbot #ComfyUI # 推理服务器 #防毒面罩 #防尘面罩 #postman #内存接口 # 澜起科技 # 服务器主板 #eBPF # 显卡驱动备份 #模拟退火算法 #计算机毕业设计 #程序定制 #毕设代做 #课设 #源码 #VMware #简单数论 #埃氏筛法 #Hadoop #wireshark #广播 #组播 #并发服务器 #nacos #银河麒麟aarch64 #MC #MC群组服务器 #uvicorn #uvloop #asgi #event # 服务器迁移 # 回滚方案 #大模型入门 #flutter #select #homelab #Lattepanda #Jellyfin #Plex #Kodi #yolov12 #研究生life #开关电源 #热敏电阻 #PTC热敏电阻 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #身体实验室 #健康认知重构 #系统思维 #微行动 #NEAT效应 #亚健康自救 #ICT人 #eureka #云服务器 #个人电脑 #KMS 激活 #mongodb #漏洞挖掘 #TensorRT # 推理优化 #SSH别名 #CS2 #debian13 #BoringSSL #企业存储 #RustFS #对象存储 #高可用 #notepad++ #es安装 #远程控制 #云计算运维 #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #asp.net上传大文件 #gpu #nvcc #cuda #nvidia #PTP_1588 #gPTP #群晖 #音乐 # 鲲鹏 #IntelliJ IDEA #Spring Boot #neo4j #NoSQL #SQL #http头信息 #Coturn #TURN #ci/cd #k8s #log4j #Jetty # 嵌入式服务器 #Windows #模块 #ICE #信创国产化 #达梦数据库 #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 # 服务器IP # 端口7860 #建筑缺陷 #红外 #数据集 #TCP服务器 #开发实战 #SMARC #ARM #全文检索 #银河麒麟服务器系统 #远程桌面 # 代理转发 # 跳板机 #echarts #鸿蒙PC ##租显卡 #树莓派 #温湿度监控 #WhatsApp通知 #IoT #MySQL #无人机 #junit #新人首发 #web服务器 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman # 公钥认证 #Reactor #Kylin-Server #服务器安装 #Android16 #音频性能实战 #音频进阶 #短剧 #短剧小程序 #短剧系统 #微剧 # 智能运维 # 性能瓶颈分析 #空间计算 #原型模式 #hibernate #nosql # 云服务器 #数据访问 #CTF #VMWare Tool #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #clickhouse #代理 #CNAS #CMA #程序文件 #SSH复用 # 远程开发 #Deepoc #具身模型 #开发板 #未来 #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #自动化运维 #IO #插件 #开源软件 #DHCP #网络安全大赛 #C++ UA Server #SDK #跨平台开发 #agent #ai大模型 #FHSS #eclipse #servlet #arm64 #outlook #错误代码2603 #无网络连接 #2603 #mssql #wpf #实时检测 #卷积神经网络 #MOXA #GATT服务器 #蓝牙低功耗 #lucene #DAG #云服务器选购 #Saas #线程 #散列表 #机器视觉 #6D位姿 #UOS #海光K100 #统信 #NFC #智能公交 #服务器计费 #FP-增长 #Proxmox VE #虚拟化 #改行学it #b树 #memory mcp #Cursor #网路编程 #百万并发 #smtp #smtp服务器 #PHP #声源定位 #MUSIC #tensorflow # 远程访问 #ServBay #memcache #飞牛nas #fnos #ansys #ansys问题解决办法 #ranger #MySQL8.0 #智能体对传统行业冲击 #行业转型 #分布式数据库 #集中式数据库 #业务需求 #选型误 #Socket网络编程 #HarmonyOS #雨云服务器 #Minecraft服务器 #教程 #MCSM面板 # 服务器配置 # GPU # 串口服务器 # NPort5630 #Python办公自动化 #Python办公 #copilot #硬盘克隆 #DiskGenius # 键鼠锁定 #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #opc模拟服务器 #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #量子计算 #反向代理 #政务 #adobe #数据迁移 #powerbi #个人助理 #数字员工 #参数估计 #矩估计 #概率论 #gmssh #宝塔 #1panel #Exchange #sentinel #系统安装 #MinIO #IPv6 #POC #问答 #交付 #scikit-learn #随机森林 #闲置物品交易系统 #静脉曲张 #腿部健康 #运动 #Minecraft #PaperMC #我的世界服务器 #AI Agent #开发者工具 #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #计算机外设 #边缘AI # Kontron # SMARC-sAMX8 #scanf #printf #getchar #putchar #cin #cout #ET模式 #非阻塞 #凤希AI伴侣 #remote-ssh #产品经理 #就业 #CMake #Make #C/C++ #OpenAI #故障 #优化 #多模态 #微调 #超参 #LLamafactory #vps #docker安装seata #database #AI论文写作工具 #学术写作辅助 #论文创作效率提升 #AI写论文实测 # IndexTTS 2.0 #全链路优化 #实战教程 #数字化转型 #实体经济 #商业模式 #软件开发 #数智红包 #商业变革 #创业干货 #AB包 #Go并发 #高并发架构 #Goroutine #系统设计 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #FASTMCP #sglang #UEFI #BIOS #Legacy BIOS #产品运营 #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #交换机 #三层交换机 #SSH Agent Forwarding # 容器化 #高斯溅射 #Harbor #AI智能棋盘 #Rock Pi S #边缘计算 #云开发 #性能 #RAM #c++高并发 #FTP服务器 #uip # 权限修复 # HiChatBox # 离线AI #进程等待 #wait #waitpid #SMTP # 内容安全 # Qwen3Guard #X11转发 #平板 #零售 #智能硬件 #vncdotool #链接VNC服务器 #如何隐藏光标 #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #gateway #Comate #MinIO服务器启动与配置详解 #算力建设 #tdengine #涛思数据 #服务器解析漏洞