最新资讯

  • 【linux 多进程并发】0302 Linux下多进程模型的网络服务器架构设计,实时响应多客户端请求

【linux 多进程并发】0302 Linux下多进程模型的网络服务器架构设计,实时响应多客户端请求

2025-05-01 11:01:04 2 阅读

0302 多进程网络服务器架构

专栏内容

  • postgresql使用入门基础
  • 手写数据库toadb
  • 并发编程

个人主页:我的主页
管理社区:开源数据库
座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.

✅ 🔥🔥🔥重大消息🔥🔥🔥 ❤️❤️❤️❤️ 关注公众号【开源无限】可免费领取《手写数据库内核toadb》源代码一份 ❤️❤️❤️❤️

一、概述


在大规模数据处理中,会有大量的客户端接入同一台服务器,每个客户端都需要长时间提供服务。

服务器采用中心化的部署,而客户端往往分散在不同机器上,服务器与客户端之间跨网络通信,一般采用C/S架构。

而服务端的架构需要能应对大量并发客户端,同时可以给每个客户端独占的服务,这就用到了多任务的网络模型架构,下面我们来看看用多进程如何实现。

二、多路复用的网络模型


C/S架构中,处理大量的网络请求,需要一套基于多路复用的网络处理模型。

  • 可以同时处理网络连接请求和网络数据传递;
  • 减少程序的阻塞时间,避免无效的CPU消耗;
  • 适应不同的并发规模;

以此为目标实现如下网络模型。

2.1 服务端网络监听

多路复用模型这里采用了epoll方式,如果自己的平台不支持,可以换为select或者poll的方式。

代码如下:

#include   
#include   
#include   
#include   
#include   
#include   
#include   
#include   
  
#define MAX_EVENTS 10  
#define BUFFER_SIZE 1024  
#define PORT 8080  
  
// 设置文件描述符为非阻塞模式  
int set_nonblocking(int fd) {  
    int flags, s;  
  
    flags = fcntl(fd, F_GETFL, 0);  
    if (flags == -1) {  
        perror("fcntl F_GETFL");  
        return -1;  
    }  
  
    flags |= O_NONBLOCK;  
    s = fcntl(fd, F_SETFL, flags);  
    if (s == -1) {  
        perror("fcntl F_SETFL");  
        return -1;  
    }  
  
    return 0;  
}  
  
int main() {  
    int listen_fd, conn_fd, nfds, epoll_fd;  
    struct sockaddr_in server_addr;  
    struct epoll_event ev, events[MAX_EVENTS];  
    char buffer[BUFFER_SIZE];  
    ssize_t count;  
  
    // 创建监听socket  
    listen_fd = socket(AF_INET, SOCK_STREAM, 0);  
    if (listen_fd == -1) {  
        perror("socket");  
        exit(EXIT_FAILURE);  
    }  
  
    // 设置非阻塞模式  
    if (set_nonblocking(listen_fd) == -1) {  
        close(listen_fd);  
        exit(EXIT_FAILURE);  
    }  
  
    // 绑定地址和端口  
    server_addr.sin_family = AF_INET;  
    server_addr.sin_addr.s_addr = INADDR_ANY;  
    server_addr.sin_port = htons(PORT);  
    if (bind(listen_fd, (struct sockaddr*)&server_addr, sizeof(server_addr)) == -1) {  
        perror("bind");  
        close(listen_fd);  
        exit(EXIT_FAILURE);  
    }  
  
    // 开始监听  
    if (listen(listen_fd, SOMAXCONN) == -1) {  
        perror("listen");  
        close(listen_fd);  
        exit(EXIT_FAILURE);  
    }  
  
    // 创建epoll实例  
    epoll_fd = epoll_create1(0);  
    if (epoll_fd == -1) {  
        perror("epoll_create1");  
        close(listen_fd);  
        exit(EXIT_FAILURE);  
    }  
  
    // 添加监听socket到epoll实例  
    ev.events = EPOLLIN;  
    ev.data.fd = listen_fd;  
    if (epoll_ctl(epoll_fd, EPOLL_CTL_ADD, listen_fd, &ev) == -1) {  
        perror("epoll_ctl: listen_fd");  
        close(listen_fd);  
        close(epoll_fd);  
        exit(EXIT_FAILURE);  
    }  
  
    // 主循环  
    while (1) {  
        nfds = epoll_wait(epoll_fd, events, MAX_EVENTS, -1);  
        if (nfds == -1) {  
            perror("epoll_wait");  
            exit(EXIT_FAILURE);  
        }  
  
        for (int n = 0; n < nfds; ++n) {  
            if (events[n].data.fd == listen_fd) {  
                // 新的连接  
                conn_fd = accept(listen_fd, NULL, NULL);  
                if (conn_fd == -1) {  
                    perror("accept");  
                    continue;  
                }  
  
                // 设置非阻塞模式  
                if (set_nonblocking(conn_fd) == -1) {  
                    close(conn_fd);  
                    continue;  
                }  
  
                // 添加新的连接socket到epoll实例  
                ev.events = EPOLLIN | EPOLLET;  
                ev.data.fd = conn_fd;  
                if (epoll_ctl(epoll_fd, EPOLL_CTL_ADD, conn_fd, &ev) == -1) {  
                    perror("epoll_ctl: conn_fd");  
                    close(conn_fd);  
                }  
            } else {  
                // 处理读事件  
                conn_fd = events[n].data.fd;  
                while ((count = read(conn_fd, buffer, BUFFER_SIZE)) > 0) {  
                    // 处理接收到的数据(这里简单回显)  
                    write(conn_fd, buffer, count);  
                }  
  
                if (count == -1 && errno != EAGAIN) {  
                    // 出现错误或连接关闭  
                    close(conn_fd);  
                } else if (count == 0) {  
                    // 连接关闭  
                    close(conn_fd);  
                }  
  
                // 从epoll实例中移除已关闭的socket  
                if (count <= 0 && errno != EAGAIN) {  
                    ev.events = 0;  
                    epoll_ctl(epoll_fd, EPOLL_CTL_DEL, conn_fd, &ev);  
                }
            }  
        }  
    }  
  
    close(listen_fd);  
    close(epoll_fd);  
    return 0;  
}

说明

  • TCP服务端的基本步骤创建socket,设置为非阻塞模式,绑定IP与端口,开启监听;
  • 这里服务端的socket需要设置为非阻塞模式,因为我们是在单进程中处理多个连接,每个连接不能阻塞等待;
  • 然后加入到epoll监听池中,开始epoll事件的等待;这里只处理接收事件;
  • 如果有服务端socket的接收事件,那么说明有客户端连接消息,进行accep,创建客户端连接的socket;
  • 同样将客户端连接的socket设置为非阻塞,理由同上;加入epoll临听池中,同样也只处理接收事件;
  • 如果有客户端连接的socket上的接收事件,那么说明客户端正在给服务端发消息;
  • 收到客户端消息后,这里只是简单处理,原样再发给客户端;
  • 如果客户端关闭或出错,将客户端连接关闭,并从epoll临听池中移除;

2.2 客户端测试

现在我们来编写一个简单的客户端模拟程序,测试一下多路复用的网络框架。

/*
 * ex020302_client.c
 */

#include   
#include   
#include   
#include   
#include   
  
#define SERVER_IP "127.0.0.1"  
#define SERVER_PORT 4808  
#define BUFFER_SIZE 1024  

#define CLIENT_SEND_CNT 20

int main() 
{  
    int sockfd;  
    struct sockaddr_in server_addr;  
    char buffer[BUFFER_SIZE] = {0};  
    const char *message = "Hello, Server!";  
  
    // 创建套接字  
    if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0) 
    {  
        perror("socket creation failed");  
        exit(EXIT_FAILURE);  
    }  
  
    // 配置服务器地址信息  
    server_addr.sin_family = AF_INET;  
    server_addr.sin_port = htons(SERVER_PORT);  
  
    // 将IP地址从字符串转换为二进制形式  
    if (inet_pton(AF_INET, SERVER_IP, &server_addr.sin_addr) <= 0) 
    {  
        perror("Invalid address/ Address not supported");  
        close(sockfd);  
        exit(EXIT_FAILURE);  
    }  
  
    // 连接到服务器  
    if (connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr)) < 0) 
    {  
        perror("Connection Failed");  
        close(sockfd);  
        exit(EXIT_FAILURE);  
    }  
  
    for(int i = 0; i < CLIENT_SEND_CNT; i++)
    {
        // 发送消息到服务器  
        send(sockfd, message, strlen(message), 0);  
        printf("Message sent: %s
", message);  
    
        // 接收服务器的响应  
        int bytes_received = recv(sockfd, buffer, BUFFER_SIZE - 1, 0);  
        if (bytes_received < 0) 
        {  
            perror("Error in receiving");  
        } 
        else if (bytes_received == 0) 
        {  
            printf("Server closed the connection
");  
        } 
        else 
        {  
            buffer[bytes_received] = ''; // 确保字符串以空字符结尾  
            printf("Message received from server: %s
", buffer);  
        }  

        sleep(1);
    }
  
    // 关闭套接字  
    close(sockfd);  
  
    return 0;  
}

说明

  • TCP客户端建立的基本步骤,创建socket,初始化服务端地址,连接服务器;
  • 然后向服务端发送相同的消息;
  • 每次发送完成后,等待接收消息;

2.3 客户端测试

可以看到,服务端处理客户端的请求时,都是按照接收到的顺序进行串行处理;

当客户端的数量达到成百上千时,对客户端的响应时间就会出现非常明显的延迟,

这种延迟会随着业务的复杂度而放大。

这时就需要充分利用多核CPU硬件资源,来进行并发任务的处理。

三、多进程服务处理


上面是在单个任务进程中处理了监听和大量任务连接的网络处理,各客户端连接的服务会相互影响,实际是串行化处理的。

要让大量的客户端能同时被响应,需要采用多任务的方式,那么在上面的网络模型基础上加入多进程,服务端为每个客户端连接准备一个独立的进程,这样就可以及时响应。

3.1 多进程架构

首先我们利用前面几个章节的介绍,来搭建一个多进程的代码架构,由主进程根据需要进行创建子进程,并且由主进程进行全局的控制。

/*
 * ex020302_netprocess.c
 */
#include   
#include   
#include   
#include   
#include   
#include   
#include   
#include   
  
#define MAX_EVENTS 10  
#define BUFFER_SIZE 1024  
#define PORT 4808  

void daemon_fork()
{
	int pid = -1;
	pid = fork();
	if(pid < 0)
	{
		printf("fork error[%s]
",strerror(errno));
		exit(-1);
	}
	else if(pid > 0)
	{
		// parent exit.
		exit(0);
	}
	else 
	{
		// child daemon
		return;
	}
}

void subprocess(int sock)
{
    int pid = -1;
	pid = fork();
	if(pid < 0)
	{
		printf("fork error[%s]
",strerror(errno));
		exit(-1);
	}
	else if(pid > 0)
	{
		// parent.
        close(sock);
		return;
	}
	else 
	{
		// child 
        close(listen_fd);
        processMsg(sock);
		exit(0);
	}
}

说明

  • daemon服务程序函数,这个前一章节已经介绍过了,服务端以后台进程的方式运行;
  • 子进程任务处理函数;这里创建的是任务子进程,并在子进程中调用消息处理函数;
  • 这里需要注意的是,在子进程中要关闭服务端的socket,同时在父进程中要关闭客户端连接的socket; 因为父子进程会复制内存空间,但是在各自的进程中,已经不再需要;

3.2 并发网络处理模型

现在就可以将上面的多路复用网络处理放入多进程架构中,处理逻辑进行如下切分:

  • 服务端监听socket初始化,多路复用器的初始化等,都放在主进程中,作为服务端网络初始化的一部分;
  • 每个客户端连接的socket,以及它的读写消息处理逻辑,放在子进程中;这样每个客户端连接对应一个后台服务子进程;
  • 创建子进程的时机,也就是在主进程中接收到新连接时,创建新连接成功后,就可以新建子进程进行处理;
  • 而子进程的退出时间,就是客户端断开连接,或者处理出错时;
void initializeServerNet()
{
    struct sockaddr_in server_addr;  
  
    // 创建监听socket  
    listen_fd = socket(AF_INET, SOCK_STREAM, 0);  
    if (listen_fd == -1) 
    {  
        perror("socket");  
        exit(EXIT_FAILURE);  
    }  
   
    // 绑定地址和端口  
    server_addr.sin_family = AF_INET;  
    server_addr.sin_addr.s_addr = INADDR_ANY;  
    server_addr.sin_port = htons(PORT);  
    if (bind(listen_fd, (struct sockaddr*)&server_addr, sizeof(server_addr)) == -1) 
    {  
        perror("bind");  
        close(listen_fd);  
        exit(EXIT_FAILURE);  
    }

    // 开始监听
    if (listen(listen_fd, SOMAXCONN) == -1)
    {
        perror("listen");
        close(listen_fd);
        exit(EXIT_FAILURE);
    }
}

void closeServerFd()
{
    close(listen_fd);  
}

void dispatchLoop()
{
    int conn_fd;  

    // 主循环  
    while (1) 
    {  
        // 新的连接  
        conn_fd = accept(listen_fd, NULL, NULL);  
        if (conn_fd == -1) 
        {  
            perror("accept");  
            sleep(1);
            continue;  
        }

        subprocess(conn_fd);
    }  
}

void processMsg(int sock)
{
    char buffer[BUFFER_SIZE];  
    ssize_t count;  

    printf("serv-process:%d start.
");

    while ((count = read(sock, buffer, BUFFER_SIZE)) > 0)
    {
        // 处理接收到的数据(这里简单回显)
        write(sock, buffer, count);
    }

    if (count == -1 && errno != EAGAIN)
    {
        // 出现错误或连接关闭
        close(sock);
    }
    else if (count == 0)
    {
        // 连接关闭
        close(sock);
    }

    printf("serv-process:%d exit.
");
}

那么主程序实现如下:

void daemon_fork();
void subprocess(int sock);
void processMsg(int sock);

void initializeServerNet();
void closeServerFd();
void dispatchLoop();

int listen_fd;

int main(int argc ,char *argv[])
{
	daemon_fork();

	initializeServerNet();
    
  dispatchLoop();

  closeServerFd();
	return 0;
}
  • 在主进程中先进程服务端初始化;
  • 然后就可以开始监听,并接收客户端的连接;
  • 当有客户端连接时,就创建客户端连接,并启动子进程与该客户端进行网络通信;
  • 子进程在客户端断开连接或出错时,就会退出;

2.3 客户端测试

可以看到将客户端发送次数调大后,开启的客户端越多,服务端启动的子进程也就会越多;

此时,可以看到服务端每个进程的CPU使用率并不是很高;

但是随着客户端数量越来越多,服务端进程数量超过CPU核数时,就会增加系统的负担;

四、总结


本文主要介绍了基于多进程架构的网络服务器的设计与实现,在多进程架构中每个客户端会有一个服务端的进程专门处理通信,增加了对客户端消息的响应效率,提升了并发处理能力。

结尾


非常感谢大家的支持,在浏览的同时别忘了留下您宝贵的评论,如果觉得值得鼓励,请点赞,收藏,我会更加努力!

作者邮箱:study@senllang.onaliyun.com
如有错误或者疏漏欢迎指出,互相学习。

注:未经同意,不得转载!

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

搜索文章

Tags

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