• C++ 网络编程:打造多线程 TCP 服务器,同时服务多个客户机!

C++ 网络编程:打造多线程 TCP 服务器,同时服务多个客户机!

2025-04-26 09:17:33 1 阅读

C++ 网络编程:打造多线程 TCP 服务器,同时服务多个客户机!

  • 一、阻塞与并发
  • 二、std::thread 简介
  • 三、实现过程
  • 四、客户端连接
  • 五、多线程服务器模型的优缺点
  • 六、总结

一、阻塞与并发

几乎所有的程序员第一次接触到的网络编程都是从 listen()、send()、recv() 等接口开始的,这些接口都是阻塞型的。使用这些接口可以很方便的构建服务器/客户机的模型。

大部分的 socket 接口都是阻塞型的。所谓阻塞型接口是指系统调用(一般是 IO 接口)不返回调用结果并让当前线程一直阻塞,只有当该系统调用获得结果或者超时出错时才返回。

实际上,除非特别指定,几乎所有的 IO 接口 ( 包括 socket 接口 ) 都是阻塞型的。这给网络编程带来了一个很大的问题,如在调用 send()的同时,线程将被阻塞,在此期间,线程将无法执行任何运算或响应任何的网络请求。

一个简单的改进方案是在服务器端使用多线程(或多进程)。多线程(或多进程)的目的是让每个连接都拥有独立的线程(或进程),这样任何一个连接的阻塞都不会影响其他的连接。具体使用多进程还是多线程,并没有一个特定的模式。传统意义上,进程的开销要远远大于线程,所以如果需要同时为较多的客户机提供服务,则不推荐使用多进程;如果单个服务执行体需要消耗较多的 CPU 资源,譬如需要进行大规模或长时间的数据运算或文件访问,则进程较为安全。


主线程持续等待客户端的连接请求,如果有连接,则创建新线程,并在新线程中提供为前例同样的问答服务。

二、std::thread 简介

std::thread 是 C++11 标准引入的一个类,用于在 C++ 中创建和管理线程。它提供了一种简单且高效的方式来实现多线程编程,允许程序同时执行多个操作。

std::thread 构造函数的主要功能是接收可调用对象(如函数、lambda 表达式、绑定的成员函数等),并在新线程中执行。

构造函数原型:

template <class F, class... Args>
explicit thread(F&& f, Args&&... args);

F 是可调用对象的类型,可以是普通函数、成员函数、lambda 表达式或任何实现了 operator() 的对象。Args 是可变参数模板,表示传递给可调用对象的参数。

线程管理:

  • join():在主线程中调用 join() 可以等待线程完成,使主线程阻塞,直到新的线程执行完成。
  • detach():若不希望主线程等待线程完成,可以调用 detach(),这将使线程与主线程分离,成为一个独立运行的线程。

每个 std::thread 对象都有一个状态,可以通过调用 joinable() 方法来检查一个线程是否可以被 join。如果线程已经完成或被分离(detach),则不能再进行 join

三、实现过程

基本步骤:

  1. 创建一个 socket。
  2. 设置端口并绑定。
  3. 设置网络IO的阻塞模式还是非阻塞模式,默认是阻塞模式。
  4. 监听端口。
  5. 接受客户端连接,开启多线程。
  6. 设置客户端socket fd 的网络 IO 是阻塞模式还是非阻塞模式,默认是阻塞模式。
  7. 收发数据,数据处理。


完整代码:

#include 
#include 
#include 
#include 
#include 

#include 
#include 
#include 

#define PORT            8080
#define LINSTEN_BLOCK   20
#define BUFFER_LEN      4096
#define SET_NONBLOCK    0

bool setIoMode(int fd, int mode);
void routine(int clientfd);

int main(int argc, char**argv)
{
    // 1. Create socket
    int listenfd = socket(AF_INET, SOCK_STREAM, 0);
    if (listenfd == -1) {
        std::cout << "socket return " << errno << ", " << strerror(errno) << std::endl;
        return -1;
    }

    // 2. Set the port and bind it.
    sockaddr_in serverAddr;
    memset(&serverAddr, 0, sizeof(sockaddr_in));
    serverAddr.sin_family = AF_INET;
    serverAddr.sin_addr.s_addr = htons(INADDR_ANY); // bind ip address.
    serverAddr.sin_port = htons(PORT);  // bind port.
    if (bind(listenfd, (sockaddr*)&serverAddr, sizeof(serverAddr)) == -1) {
        std::cout << "bind return " << errno << ", " << strerror(errno) << std::endl;
        return -2;
    }

#if SET_NONBLOCK
    // set nonblock mode.
    setIoMode(listenfd, O_NONBLOCK);

#endif

    // 3. listening port.
    if (listen(listenfd, LINSTEN_BLOCK) == -1) {
        std::cout << "listen return " << errno << ", " << strerror(errno) << std::endl;
        return -3;
    }

    std::cout << "server listening port " << PORT << std::endl;
    while(1) {
        // 4. accept connect.
        sockaddr_in clientAddr;
        memset(&clientAddr, 0, sizeof(clientAddr));
        socklen_t clienLen = sizeof(clientAddr);
        int clientfd = accept(listenfd, (sockaddr *)&clientAddr, &clienLen);
        if (clientfd == -1) {
            std::cout << "accept return " << errno << ", " << strerror(errno) << std::endl;
            continue;
        }

        std::cout << "client fd " << clientfd << std::endl;
        std::thread thread(routine, clientfd);
        thread.detach();
    }
    close(listenfd);
    return 0;
}

bool setIoMode(int fd, int mode)
{
    int flag = fcntl(fd, F_GETFL, 0);
    if (flag == -1) {
        std::cout << "fcntl get flags return " << errno << ", " << strerror(errno) << std::endl;
        return false;
    }
    flag |= O_NONBLOCK;
    if (fcntl(fd, F_SETFL, flag) == -1) {
        std::cout << "fcntl set flags return " << errno << ", " << strerror(errno) << std::endl;
        return false;
    }
    return true;
}

void routine(int clientfd)
{
    const char *msg = "Hello, Client!";
    while (1) {
        // 5. send message.
        if (send(clientfd, msg, strlen(msg), 0) == -1) {
            std::cout << "send buffer return " << errno << ", " << strerror(errno) << std::endl;
            continue;
        }

        // 6. recv message
        char buffer[BUFFER_LEN];
        int ret = recv(clientfd, buffer, BUFFER_LEN, 0);
        if (ret == 0) {
            std::cout << "client " << clientfd << " connection dropped" << std::endl;
            break;
        } else if (ret == -1) {
            std::cout << "recv buffer return " << errno << ", " << strerror(errno) << std::endl;
            break;
        }
        std::cout << "recv buffer from "<< clientfd << ": " << buffer << std::endl;
    }
    close(clientfd);
    std::cout << "End of client " << clientfd << std::endl;
}

上述代码的核心是:用一个循环一直循环等待客户端接入(7 * 24 H),客户端接入后开启一个线程专门为该客户端服务,线程内部建立一个循环用于服务器和客户端的交互。

四、客户端连接

Windows下可以使用NetAssist的网络助手工具:

也可以使用如下的代码实现一个客户端:

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

#define PORT            8080
#define BUFFER_LEN      4096

int main() {
    int sockfd = socket(AF_INET, SOCK_STREAM, 0);
    sockaddr_in serv_addr;
    
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(PORT);
    inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr);

    if (-1 == connect(sockfd, (struct sockaddr*)&serv_addr, sizeof(serv_addr))) {
        std::cout << "Connect failed!" << std::endl;
        return -1;
    }

    for (int i = 0; i < 10; ++i) {
        char buffer[BUFFER_LEN] = {0};
        if (recv(sockfd, buffer, sizeof(buffer), 0) <= 0) {
            break;
        }
        std::cout << "Message from server: " << buffer << std::endl;

        const char *msg = "Hello, Client!";
        if (send(sockfd, msg, strlen(msg), 0) == -1) {
            std::cout << "send buffer return " << errno << ", " << strerror(errno) << std::endl;
            break;
        }
        sleep(1);
    }

    close(sockfd);
    return 0;
}

五、多线程服务器模型的优缺点

优点:

  1. 多线程服务器模型的设计理念是每个线程专门为一个客户端提供服务。这种一对一的模式使得程序逻辑简单,代码结构易于理解,易于维护和调试。

  2. 每个线程的执行和资源使用是相互独立的。一个线程的崩溃或阻塞不会直接影响到其他线程,进而提高了程序的稳定性。

  3. 自然地利用多核处理器

  4. 在每个线程中,可以保持特定于客户的状态(即可在每个线程中维护客户端上下文),避免了对跨线程共享状态的复杂同步问题。

缺点:

  1. 资源消耗大:每个线程的创建和管理都会占用一定的系统资源(例如堆栈内存、线程控制块等)。对于高并发场景,这种资源消耗可能会显著增加,影响服务器的性能。

  2. 在高并发情况下,如果线程数目过多,上下文切换的开销会导致性能显著下降。

  3. 并发限制:每个系统对线程的数量是有限制的,通常一个服务器不能创建超过一万(具体限制视操作系统而定)个线程,这会对支持高并发服务构成瓶颈。

多线程服务器模型能够提供简单有效的解决方案,适合资源相对富余、对并发性能要求较低的应用。

六、总结

上述多线程的 服务器模型(一请求一线程) 似乎完美的解决了为多个客户机提供问答服务的要求,但其实并不尽然。很多年之前(2010年前后)这个方法确实非常有效,但如果要同时响应成百上千路的连接请求,则无论多线程还是多进程都会严重占据系统资源,降低系统对外界响应效率,而线程与进程本身也更容易进入假死状态。

多线程模型可以方便高效的解决小规模的服务请求,但面对大规模的服务请求,多线程模型也会遇到瓶颈,可以用非阻塞接口来尝试解决这个问题。

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

搜索文章

Tags

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