最新资讯

  • Linux 中的管道:进程间数据传输的利器

Linux 中的管道:进程间数据传输的利器

2025-04-30 18:01:55 1 阅读

个人主页:chian-ocean

文章专栏-Linux

前言

**进程间通信(Inter-Process Communication, IPC)**是指在操作系统中,不同进程之间交换数据或信息的方式。由于每个进程都有自己的地址空间,直接访问另一个进程的数据是不被允许的,因此需要使用IPC机制来实现进程间的通信

进程间通信

进程间通信的目的

进程间通信(IPC)的主要目的是让不同进程能够交换数据、协作工作和同步执行。由于每个进程有独立的内存空间,IPC提供了一种安全的方式让进程之间共享信息和资源。它的作用包括:

  • 数据共享:让多个进程能够共享数据。
  • 进程同步:协调进程的执行顺序,避免资源冲突。
  • 控制与协作:让进程之间进行协作或控制执行。
  • 高效并发:提高系统的处理能力和资源利用率。
  • 模块化设计:简化系统设计,通过独立的进程模块进行工作。

进程间通信的分类

Linux 提供了多种进程间通信机制,以适应不同的应用场景:

  • 管道、消息队列、共享内存:适用于同一系统内的进程间通信。
  • 信号量、套接字:用于进程同步与资源访问控制。
  • 信号和D-Bus:用于事件通知和消息传递。
  • 内存映射文件:用于高效的大数据交换。

管道

管道(Pipe)是一种常见的进程间通信(IPC)机制,用于不同进程之间传递数据。它本质上是一个数据缓冲区,允许一个进程将数据写入其中,另一个进程从管道中读取数据。管道是一种单向通信的方式,但可以通过创建多个管道来实现双向通信。

管道的类型:

  1. 匿名管道(Anonymous Pipe)
    • 匿名管道是无名的、临时的,通常用于父子进程之间的通信。
    • 由于匿名管道没有文件名,它们只能在创建它们的进程间使用。
    • 通过 pipe() 系统调用可以创建匿名管道,常用于同一系统内的进程间通信。
  2. 命名管道(Named Pipe,FIFO)
    • 命名管道是带有名字的管道,可以跨进程甚至跨系统使用。
    • 命名管道在文件系统中有一个路径,进程可以通过路径访问该管道。
    • 通过 mkfifo() 系统调用创建命名管道,适用于没有父子关系的进程间通信。

管道原理

写入数据
读取数据
父进程
管道
子进程

管道用于进程间的通信,特别是用于父子进程之间的简单数据传输。父进程创建管道,并通过管道的写端向管道写入数据;子进程从管道的读端读取数据。由于管道的特性,父子进程共享这对文件描述符,因此它们可以通过该管道进行通信。

  1. 父进程创建管道:父进程通过 pipe() 创建管道,得到一对文件描述符。
  2. 创建子进程:父进程调用 fork() 创建子进程,子进程会继承父进程的文件描述符。
  3. 父子进程通信:
    • 父进程通过写端写入数据到管道。
    • 子进程通过读端读取管道中的数据。
  4. 关闭管道:在数据传输完毕后,父子进程都应关闭管道的文件描述符,防止资源泄露。

匿名管道

匿名管道(Anonymous Pipe) 是一种用于父子进程间进行通信的机制,它允许数据在两个进程之间传输,而无需显式的文件名或路径。匿名管道的特点是它没有名字,并且通常只能用于具有亲缘关系的进程(即父进程与子进程)

匿名管道的特性

  1. 具有血缘关系的进程可以进行匿名管道通信。
  2. 管道只能进行单向通信。
  3. **父子进程会进行协同:**父进程和子进程之间的协同工作不仅可以在数据处理上进行配合,还可以在任务执行上互相协作。
  4. **管道是面向字节流的:**这意味着管道在传输数据时并不会关心数据的具体类型,而是以字节流的方式进行传输。
  5. 管道是基于文件,文件基于进程的生命周期。

匿名管道的SysCall

int pipe(int pipefd[2])

参数:

  • pipefd[2]:一个整数数组,长度为 2。pipefd[0] 用于读取数据(读端),pipefd[1] 用于写入数据(写端)。

返回值:

  • 成功:返回 0
  • 失败:返回 -1,并设置 errno 以指示错误原因。

功能:

pipe()创建一个管道并将两个文件描述符放入 pipefd 数组中:

  • pipefd[0] 是管道的读端,用于从管道中读取数据。
  • pipefd[1] 是管道的写端,用于向管道中写入数据。

这些文件描述符可以用于与其他进程或线程进行数据通信。

匿名管道示例

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

#define NUM 2  // 定义管道数组的大小
#define SIZE 1024  // 定义缓冲区大小

// Reader函数:读取管道中的数据并打印出来
void Reader(int fd)
{
    char buffer[SIZE];  // 缓冲区用于存储读取的数据
    while (true)
    {
        buffer[0] = 0;  // 清空缓冲区的第一个字节

        // 从管道读取数据
        ssize_t n = read(fd, buffer, sizeof(buffer));
        if (n > 0)
        {
            buffer[n] = '';  // 添加字符串结束符
            std::cout << "father say:[" << "PID : " << getpid() << "]: " << buffer << std::endl;
        }

        // 可以通过 sleep(1) 暂停 1 秒,避免 CPU 过度使用(目前注释掉)
        //sleep(1);
    }
}

// Writer函数:向管道中写数据
void Writer(int fd)
{
    char buffer[SIZE];  // 缓冲区用于存储要写入的数据
    std::string msg = "hello I am child";  // 子进程发送的消息
    int num = 1;  // 用于编号消息

    while (true)
    {
        buffer[0] = 0;  // 清空缓冲区的第一个字节
        snprintf(buffer, sizeof(buffer), "child-PID: %d-%s-%d", getpid(), msg.c_str(), num);  // 格式化消息
        num++;  // 自增消息编号

        // 写入管道
        write(fd, buffer, strlen(buffer));
        sleep(1);  // 每次写入后暂停 1 秒
    }
}

int main()
{
    int pipefd[NUM] = {0};  // 创建一个管道文件描述符数组

    // 创建管道
    int n = pipe(pipefd);
    if (n < 0) return -1;  // 如果创建管道失败,返回 -1

    // 创建子进程
    pid_t id = fork();
    if (id < 0) return -2;  // 如果创建子进程失败,返回 -2

    if (id == 0)  // 子进程部分
    {
        close(pipefd[0]);  // 关闭读端,因为子进程只需要写入数据

        // 调用 Writer 函数向管道中写数据
        Writer(pipefd[1]);
        exit(0);  // 子进程结束
    }

    // 父进程部分
    close(pipefd[1]);  // 关闭写端,因为父进程只需要读取数据

    // 调用 Reader 函数从管道中读取数据
    Reader(pipefd[0]);

    // 等待子进程结束
    pid_t ret = waitpid(id, NULL, 0);
    if (ret == 0)
    {
        std::cout << "success return" << std::endl;  // 子进程正常退出
    }

    return 0;
}

代码流程:

  1. 创建管道
    • 使用 pipe() 创建一个管道,并通过 pipefd[0]pipefd[1] 分别访问读端和写端。
  2. 创建子进程
    • 使用 fork() 创建子进程。
    • 在子进程中,关闭管道的读端,调用 Writer() 函数向管道写数据。
    • 在父进程中,关闭管道的写端,调用 Reader() 函数从管道读取数据。
  3. 管道通信
    • 子进程通过写端 (pipefd[1]) 向管道写数据。
    • 父进程通过读端 (pipefd[0]) 从管道读取数据并打印。
  4. 进程同步
    • 使用 waitpid() 等待子进程的结束。

主要功能:

  • 父子进程的管道通信:父进程读取子进程写入管道的数据并输出。
  • 无限循环的读写操作:子进程不断向管道写入数据,而父进程不断从管道读取数据。

管道的4种情况(用代码自己验证)

  1. 读端正常,写端关闭:读端会挂起阻塞。
  2. 读端正常,写端写满:写端会阻塞。
  3. 读端正常,写端关闭:读端就会读到0(表示读到了尽头)
  4. 写端正常,读端关闭:OS会通过操作系统杀掉写端。(13号信号:管道信号);

命名管道

Linux 中的命名管道(Named Pipe,通常称为 FIFO)是一种特殊类型的文件,它用于在不同进程之间进行数据交换。它与匿名管道(Anonymous Pipe)相比,具有一些独特的特性。

命名管道的特性

  • 跨进程通信:命名管道不仅限于父子进程之间的通信,它可以用于任何两个在系统中运行的进程之间,甚至是属于不同用户的进程。
  • 阻塞行为:(这一点类似于匿名管道)
    1. 写操作阻塞:如果管道的缓冲区已满,写入数据的进程会被阻塞,直到有进程从管道中读取数据释放出空间。
    2. 读操作阻塞:如果管道为空,读取数据的进程会被阻塞,直到有进程写入数据。

命名管道的创建和销毁

创建

bash下
mkfifo name
  • p开头的是管道文件。

C++代码中
int mkfifo(const char *pathname, mode_t mode);
  • pathname:指定要创建的FIFO文件的路径。

  • mode:设置FIFO文件的权限,通常使用标准的文件权限值(例如 0664)。

销毁

bash
unlink name

C++代码下

int unlink(const char *pathname);
  • pathname:要删除的文件路径。

命名管道的示例

  • 提供server端进行读取管道。
  • 提供client端进行写入管道。

server

#include "piped.hpp"

int main()
{
    // 创建命名管道(FIFO文件),进行进程间通信
    int n = mkfifo(FIFO_FILE, MODE);  // 使用 mkfifo 系统调用创建命名管道,FIFO_FILE 为管道文件路径,MODE 为权限模式
    if (n < 0) {
        perror("mkfifo");  // 如果创建管道失败,打印错误信息
        exit(FIFO_CREAT_ERR);  // 退出程序并返回自定义的错误码 FIFO_CREAT_ERR
    }

    // 打开命名管道,进行读取操作
    int fd = open(FIFO_FILE, O_RDONLY);  // 使用 open 系统调用打开管道文件进行只读操作
    if (fd < 0) {
        return FIFO_OPEN_ERR;  // 如果打开管道失败,返回自定义的错误码 FIFO_OPEN_ERR
    }

    // 不断读取管道中的数据
    while (true)
    {
        char buffer[SIZE] = {0};  // 创建一个字符数组 buffer 来存放从管道读取的数据
        int n = read(fd, buffer, sizeof(buffer));  // 使用 read 系统调用从管道读取数据,读取的最大字节数为 buffer 的大小
        if (n == -1) {
            perror("read");  // 如果读取数据失败,打印错误信息
            exit(FIFO_READ_ERR);  // 退出程序并返回自定义的错误码 FIFO_READ_ERR
        }
        else if (n > 0) {
            buffer[n] = 0;  // 确保读取的数据是以 null 字符 '' 结束的,以方便处理为字符串
            std::cout << "PID :" << getpid() << " client said # " << buffer << std::endl;  // 打印读取的数据以及进程的 PID
        }
        else {
            break;  // 如果没有数据可读,退出循环
        }
    }

    close(fd);  // 关闭管道文件描述符
    return 0;  // 程序正常结束
}
代码解释
  1. 创建命名管道:
    使用 mkfifo() 创建一个命名管道,该管道的路径为 FIFO_FILE,其权限由 MODE 定义。如果创建失败,则通过 perror() 输出错误信息并退出。

  2. 打开命名管道:
    使用 open() 打开刚刚创建的命名管道文件,使用只读模式 (O_RDONLY)。如果管道打开失败,则退出并返回错误码。

  3. 读取数据:
    程序通过 read() 从管道中读取数据,每次读取的数据存放到 buffer 中,并且确保数据以 null 字符结束。读取到的数据会被打印出来,显示发送数据的客户端信息。

  4. 处理管道读取:
    如果读取操作成功且有数据,程序会打印客户端的消息。如果读取操作返回 0(表示管道关闭),则退出循环。

  5. 关闭文件描述符:
    当管道的数据读取完毕后,程序会通过 close() 关闭管道文件描述符。

cilent

#include "piped.hpp"  

int main()
{
    // 打开命名管道文件(FIFO),以写模式打开
    int fd = open(FIFO_FILE, O_WRONLY);  // 使用 open 系统调用以写模式打开管道文件 FIFO_FILE
    if (fd == -1) {
        perror("open");  // 如果打开失败,打印错误信息
        exit(FIFO_OPEN_ERR);  // 退出程序并返回自定义的错误码 FIFO_OPEN_ERR
    }
    std::cout << "client open file done" << std::endl;  // 输出确认消息,表示管道文件已成功打开
    
    // 不断读取用户输入并将其写入管道
    while (true)
    {
        std::string str;  // 定义一个字符串来存储用户输入
        std::cout << "Please Enter@";  // 提示用户输入
        getline(std::cin, str);  // 从标准输入读取一行数据并存储到 str 中
        std::cout << str << std::endl;  // 打印用户输入的内容
        
        // 将输入的字符串写入管道
        int n = write(fd, str.c_str(), str.size());  // 使用 write 系统调用将输入字符串写入管道
        if (n == -1) {
            perror("write");  // 如果写入失败,打印错误信息
            exit(FIFO_WRITE_ERR);  // 退出程序并返回自定义的错误码 FIFO_WRITE_ERR
        }
    }

    close(fd);  // 关闭管道文件描述符
    return 0;  // 程序正常结束
}
代码解释:
  1. 打开管道文件:
    • 使用 open() 函数以写模式(O_WRONLY)打开命名管道文件 FIFO_FILE。如果管道文件打开失败,程序会打印错误信息并退出。
  2. 用户输入并写入管道:
    • 程序通过 std::getline(std::cin, str) 获取用户的输入,并将其存储在 str 变量中。
    • 输入的字符串会被通过 write() 系统调用写入管道,写入的数据是通过 str.c_str() 获取的字符串指针,str.size() 获取的字符串大小。
  3. 错误处理:
    • 如果 write() 函数返回错误(即返回 -1),程序会打印出错误信息,并退出,返回错误码 FIFO_WRITE_ERR
  4. 关闭管道文件:
    • 在写入完成后,程序会通过 close() 关闭管道文件描述符。

头文件包含以及宏定义hpp

#pragma once

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

#define FIFO_FILE "./mypiped"
#define MODE 0664
#define SIZE 1024

enum 
{
    FIFO_CREAT_ERR = 1 ,
    FIFO_OPEN_ERR      ,
    FIFO_READ_ERR      ,
    FIFO_WRITE_ERR
};

管道文件描述符。

头文件包含以及宏定义hpp

#pragma once

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

#define FIFO_FILE "./mypiped"
#define MODE 0664
#define SIZE 1024

enum 
{
    FIFO_CREAT_ERR = 1 ,
    FIFO_OPEN_ERR      ,
    FIFO_READ_ERR      ,
    FIFO_WRITE_ERR
};

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

搜索文章

Tags

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