最新资讯

  • 处理 Linux 信号:进程控制与异常管理的核心

处理 Linux 信号:进程控制与异常管理的核心

2025-04-26 23:37:08 1 阅读

个人主页:chian-ocean

文章专栏-Linux

前言:

在 Linux 操作系统中,信号是用于进程间通信的一种机制,能够向进程发送通知,指示某些事件的发生。信号通常由操作系统内核、硬件中断或其他进程发送。接收和处理信号是 Linux 系统中进程控制和资源管理的一个重要组成部分。

信号的保存

信号递送(Delivery)

  • 信号的处理动作称为信号递送(Delivery)
    • 这意味着在 Linux 系统中,当信号发生时,它会被传递到目标进程并执行相应的操作。递送是信号处理的第一步,是信号机制中至关重要的一部分。

2. 信号未决(Pending)

  • 信号从产生到递送之间的状态,称为信号未决(Pending)。

    • 当信号发送到一个进程,但该进程因某些原因(如信号被屏蔽或进程正在执行其他操作)暂时无法处理信号时,这个信号就会处于未决状态,等待后续处理。
  • Linux内核是通过一个一个位图编标记信号,进而储存信号

  • block 位图(通常是一个 sigset_t 类型的数据结构)用于记录当前进程被阻塞的信号。每一位代表一个特定的信号,当该位被设置为1时,表示该信号处于被阻塞状态;如果该位是0,则表示该信号未被阻塞,可以递送给进程。
  • pending 位图(Pending Bitmap)用于记录进程中待处理的信号。位图是一个位数组,其中每个比特代表一个信号的状态(是否待处理)。
  • headler代表的是该信号所需要用的方法。

sigset_t

定义:

sigset_t 是一个适用于信号管理的基本数据类型,通常在头文件 中定义。它的具体实现依赖于系统,但通常是一个位图或位集合,每一位表示一个信号的状态(是否被屏蔽、是否待处理等)。

sigset_t 的用途

  • 信号屏蔽:用于设置进程的信号掩码(signal mask),即哪些信号被屏蔽,不允许递送。例如,通过 sigprocmask 函数修改信号掩码。
  • 信号检查:通过 sigpending() 函数检查进程是否有待处理的信号。
  • 信号操作:例如,sigaddset()sigdelset() 等函数可以用来向信号集添加或移除特定信号

常用函数与 sigset_t 的操作

在 Linux 系统中,sigset_t 是一个数据类型,用于表示信号集,通常用于管理信号的掩码。它用于存储一个进程中多个信号的集合,可以用来表示进程阻塞的信号、待处理的信号等。

sigset_t 类型定义

sigset_t 是一个适用于信号管理的基本数据类型,通常在头文件 中定义。它的具体实现依赖于系统,但通常是一个位图或位集合,每一位表示一个信号的状态(是否被屏蔽、是否待处理等)。

sigset_t 的用途

sigset_t 主要用于以下几个方面:

  • 信号屏蔽:用于设置进程的信号掩码(signal mask),即哪些信号被屏蔽,不允许递送。例如,通过 sigprocmask 函数修改信号掩码。
  • 信号检查:通过 sigpending() 函数检查进程是否有待处理的信号。
  • 信号操作:例如,sigaddset()sigdelset() 等函数可以用来向信号集添加或移除特定信号。

sigset_t 的操作

以下是一些与 sigset_t 相关的常见操作函数:

  • sigemptyset(sigset_t ,*set): 初始化一个空的信号集(即不包含任何信号)。

    sigset_t set;
    sigemptyset(&set); // 将 set 设为空信号集
    
  • sigfillset(sigset_t ,*set): 初始化一个包含所有信号的信号集。

    sigset_t set;
    sigfillset(&set); // 将 set 设为包含所有信号的信号集
    
  • sigaddset(sigset_t ,*set, int signo): 将指定的信号添加到信号集。

    sigset_t set;
    sigemptyset(&set);
    sigaddset(&set, SIGINT); // 将 SIGINT 添加到 set 中
    
  • sigdelset(sigset_t ,*set, int signo): 从信号集移除指定的信号。

    sigdelset(&set, SIGINT); // 从 set 中删除 SIGINT
    
  • sigismember(const sigset_t ,*set, int signo): 检查指定的信号是否在信号集中。

    if (sigismember(&set, SIGINT)) {
        // 如果 SIGINT 在 set 集合中
    }
    

控制sigset_t常见函数

sigprocmask(int how, const sigset_t ,*set, sigset_t ,*oldset): 修改进程的信号掩码(即屏蔽哪些信号)。

  • sigismember(const sigset_t ,*set, int signo): 检查指定的信号是否在信号集中。

    if (sigismember(&set, SIGINT)) {
        // 如果 SIGINT 在 set 集合中
    }
    
    • how:

      参数控制信号掩码的设置方式:

      • SIG_BLOCK:把 set中的信号添加到 blocked(blocked= blocked | set)
      • SIG_UNBLOCK:从 blocked中删除 set中的信号(blocked= blocked & set)
      • SIG_SETMASKblock= set
    sigset_t set, oldset;
    sigemptyset(&set);
    sigaddset(&set, SIGINT);
    sigprocmask(SIG_BLOCK, &set, &oldset); // 阻塞 SIGINT
    
  • sigpending(sigset_t g*set): 获取当前进程的未决信号集,返回一个信号集,表示所有尚未被处理的信号。

    sigset_t set;
    sigpending(&set); // 获取当前进程的待处理信号
    

屏蔽字的实例

#include 
#include 
#include 

// 函数:用于打印信号集中的信号状态
void pendingprint(sigset_t &pending)
{
    // 遍历信号集中的每个信号,从31到1(Linux支持的信号范围通常是1到31)
    for(int i = 31; i >= 1; i--)
    {
        // 检查信号集pending中是否包含第i个信号
        if (sigismember(&pending, i))
        {
            std::cout << "1";  // 如果信号存在,打印"1"
        }
        else
        {
            std::cout << "0";  // 如果信号不存在,打印"0"
        }
    }
    std::cout << "
";  // 换行打印结果
}

int main()
{
    // 定义信号集,用于保存信号掩码、旧掩码和待处理信号集
    sigset_t mask, old_mask;
    sigset_t pending;

    // 初始化信号集mask为空信号集
    sigemptyset(&mask);

    // 将SIGINT信号(Ctrl+C触发的中断信号)添加到信号集mask中
    sigaddset(&mask, SIGINT);

    // 将SIGINT信号添加到当前进程的信号掩码中,即阻塞SIGINT信号
    // 并保存原来的信号掩码到old_mask中
    sigprocmask(SIG_BLOCK, &mask, &old_mask);
    
    int cnt = 0;
    while(true)
    {
        // 获取当前进程的待处理信号集,并保存在pending中
        sigpending(&pending);

        // 调用pendingprint函数,打印待处理信号集中的信号
        pendingprint(pending);

        // 每次睡眠1秒钟
        sleep(1);

        // 计数器,每次增加1
        if(++cnt == 5)
        {
            // 在第20次循环时,解除阻塞SIGINT信号
            std::cout << "SIGINT UNLOCK" << std::endl;

            // 恢复之前的信号掩码,即解除对SIGINT信号的阻塞
            sigprocmask(SIG_SETMASK, &old_mask, NULL);
        }
    }
    std::cout << "QUIT..." << std::endl;

    return 0;
}
  • 代码中我会每秒打印penging中的数据
  • 第三秒中的时候,像进程发送2好信号,penging中会显示为处理的信号,在bolck中该信号被阻塞,也就是被屏蔽。
  • 代码执行第五秒中的时候,进程阻塞信号解除,由于penging中有未处理的信号,就会执行2好号信号。

信号的捕捉

信号捕捉的时机

  1. 进程是否正在执行系统调用。
  2. 进程是否在空闲状态(如调用 sleep())。
  3. 信号是否被发送。
  4. 信号是否被阻塞或保留直到适当时机。
  5. 信号是否导致进程退出或崩溃时处理。

信号执行的流程

  • 用户模式:进程在用户模式下执行,直到某个信号因中断、异常或系统调用被触发。
  • 内核模式:当信号被触发时,操作系统切换到内核模式,进行信号的处理。内核会完成信号的处理并准备将进程返回到用户模式之前的状态。
  • 信号处理:在信号处理过程中,内核会调用信号处理函数(如 do_signal())。如果信号需要对用户指定的特定处理,系统会在信号处理时调用相应的函数。
  • 处理返回:信号处理函数执行完毕后,操作系统会通过 sigreturn 系统调用返回到用户模式。
  • 恢复执行:操作系统恢复用户模式下的程序执行,从中断的地方继续执行。

用户态和内核态的切换

用户态到内核态

  • 触发方式:通过系统调用(如read(), write())或硬件中断(如键盘中断)。
  • 过程:
    • 当用户程序调用系统调用时,会执行一个软中断(例如x86的int 0x80指令)。
    • 内核会保存当前用户程序的上下文(如程序计数器、堆栈指针等),并设置内核模式。
    • 进入内核代码执行,执行完后,准备返回用户态。

内核态到用户态

  • 触发方式:内核任务完成后,需要返回用户程序继续执行。
  • 过程:
    • 内核将处理结果返回用户进程,并恢复用户进程的上下文。
    • 恢复用户态的堆栈指针、程序计数器等寄存器,并将程序从内核模式切换回用户模式。
    • 继续执行用户进程。

sigaction

  • sigaction是处理粒度更加强大的一个系统调用。

int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
参数:
  • signum:指定信号的编号(例如,SIGINTSIGTERM 等)。
  • act:指向 struct sigaction 结构体的指针,用于指定新的信号处理程序及其设置。
  • oldact:指向 struct sigaction 结构体的指针,用于保存之前的信号处理程序(可选)。如果不关心旧的处理程序,可以传递 NULL
返回值:
  • 成功时,返回 0
  • 失败时,返回 -1 并设置 errno
struct sigaction {
    void (*sa_handler)(int);   // 信号处理函数
    void (*sa_sigaction)(int, siginfo_t *, void *);  // 备用信号处理函数
    sigset_t sa_mask;           // 用于指定在信号处理期间要阻塞的信号
    int sa_flags;               // 信号处理行为的标志
    void (*sa_restorer)(void);  // 不常用,保留字段
};

代码示例:

#include
#include
#include
#include
#include

// 信号处理函数,当捕获到信号时执行
void headler(int signo)
{
    // 输出捕获到的信号类型
    std::cout << "catch signal --- signo :" << signo << std::endl;
    sleep(4);
    // 退出程序,返回 1 作为退出状态
    exit(1);
}

int main()
{   
    // 定义 sigaction 结构体,用于设置新的信号处理行为 (sa) 和保存旧的信号处理行为 (osa)
    struct sigaction sa, osa;
    
    // 使用 memset 将结构体清零,确保结构体中的字段没有未初始化的值
    memset(&sa, 0, sizeof(sa));
    memset(&osa, 0, sizeof(osa));

    // 清空信号集,准备设置信号屏蔽
    sigemptyset(&sa.sa_mask);
    // 将 SIGINT 信号添加到屏蔽信号集中,意思是处理 SIGINT 时,其他信号会被阻塞
    sigaddset(&sa.sa_mask, SIGINT);

    // 设置自定义的信号处理函数,当 SIGINT 信号触发时,调用 headler 函数
    sa.sa_handler = headler;

    // 注册信号处理函数,绑定 SIGINT 信号与信号处理函数 headler,同时保存原来的信号处理方式
    sigaction(SIGINT, &sa, &osa);

    // 进入一个无限循环,模拟进程运行
    while (true)
    {
        // 输出当前进程的 pid,表示进程正在运行
        std::cout << "Process Running ...: pid: " << getpid() << std::endl;
        // 每 1 秒输出一次,模拟进程持续运行
        sleep(1);
    }

    return 0;
}

信号处理函数 headler

  • 该函数定义了如何处理接收到的 SIGINT 信号。当捕获到 SIGINT 信号时,会输出信号编号,然后模拟处理过程(休眠 4秒),最后退出程序并返回状态码 1。

信号处理结构体 sigaction

  • sigaction 是用来定义和控制信号处理方式的结构体。通过它可以设置信号的处理函数、信号掩码等信息。
  • 通过 memset 清空结构体,确保没有未初始化的字段。
  • 使用 sigemptysetsigaddset 配置信号屏蔽集,指定在处理 SIGINT 时,阻塞其他信号(在本例中,仅阻塞 SIGINT 自身)。

sigaction 调用

  • sigaction(SIGINT, &sa, &osa) 设置 SIGINT 信号的处理程序为 headler,并保存原来的信号处理方式(虽然在这里我们没有使用 osa 来恢复原处理方式)。

进程运行

  • 进入无限循环 while(true),打印当前进程的 pid(进程 ID),模拟一个长时间运行的进程。
  • 每秒输出一次进程信息,并通过 sleep(1) 使程序每秒钟暂停一次。

信号捕获时期的相关问题

  • 信号递归:信号处理期间默认屏蔽当前信号,避免递归调用。
void headler(int signo)
{
    int cnt  = 20;
    while(cnt --)
    {
        std::cout << "catch signal --- signo :" << signo <<std:: endl;
        sleep(1);
    }
    exit(1);
}
  1. 在这里面headler方法进行循环,并且休眠一秒,在此期间持续像进发送2号信号。

  1. 同时可以及逆行进行多信号屏蔽。
sigaddset(&sa.sa_mask,1);
sigaddset(&sa.sa_mask,3);
sigaddset(&sa.sa_mask,4);

  • 信号丢失:如果信号未及时处理,可能丢失,尤其是长时间阻塞时。
  • 系统调用中断:信号可能中断系统调用,导致 EINTR 错误。
  • 信号屏蔽问题:如果未正确设置信号掩码,可能导致信号被过多屏蔽或错误处理。

信号pending表的处理时机

  • 信号在调用处理方法之前会被制空
#include
#include
#include
#include
#include

// 声明一个全局的 sigset_t 变量,用于保存挂起的信号
sigset_t pending;

// 打印挂起信号的状态(1表示挂起,0表示没有挂起)
void PrintPending()
{
    sigset_t set;
    sigpending(&set);  // 获取当前挂起的信号集合

    // 遍历信号编号,打印每个信号的状态
    for (int signo = 31; signo >= 1; signo--)
    {
        if (sigismember(&set, signo))  // 检查该信号是否在挂起集合中
            std::cout << "1";  // 如果挂起,打印 1
        else
            std::cout << "0";  // 如果没有挂起,打印 0
    }
    std::cout << "
";  // 输出换行
}

// 信号处理程序
void headler(int signo)
{
    int cnt = 5;  // 设置循环次数为 5
    while (cnt--)  // 每次处理信号时,循环 5 次
    {
        PrintPending();  // 打印当前挂起的信号状态
        sleep(1);  // 休眠 1 秒,模拟信号处理的过程
        std::cout << "catch signal --- signo :" << signo << std::endl;  // 输出捕获到的信号编号
    }
    exit(1);  // 信号处理完毕后退出程序
}

int main()
{
    signal(SIGINT, headler);  // 设置 SIGINT 信号的处理函数为 headler

    sigset_t mask, old_mask;
        
    sigemptyset(&mask);  // 初始化信号集 mask,清空所有信号
    sigaddset(&mask, SIGINT);  // 将 SIGINT 信号加入到 mask 中,表示屏蔽 SIGINT 信号

    sigprocmask(SIG_BLOCK, &mask, &old_mask);  // 阻塞 SIGINT 信号,并保存原信号掩码到 old_mask
    
    int cnt = 1;
    while (true)
    {
        sigpending(&pending);  // 获取当前挂起的信号
        PrintPending();  // 打印挂起信号的状态
        sleep(1);  // 程序每秒输出一次状态
        cnt++;  // 计数器加 1
        std::cout << "Process Running ...: pid: " << getpid() << std::endl;  // 输出当前进程的 PID
        
        if (cnt % 5 == 0)  // 每经过 5 次循环
        {
            PrintPending();  // 再次打印挂起信号的状态
            sleep(1);  // 休眠 1 秒
            std::cout << "SIGINT UNLOCK" << std::endl;  // 输出解锁 SIGINT 信号的提示
            sigprocmask(SIG_SETMASK, &old_mask, NULL);  // 恢复原来的信号掩码,解除对 SIGINT 的阻塞
        }
    }

    std::cout << "QUIT..." << std::endl;  // 输出退出提示

    return 0;
}
  • 程序启动后,会阻塞 SIGINT 信号。
  • 每秒钟,程序打印当前进程的 PID 和挂起的信号状态。
  • 每经过 5 次循环,解除对 SIGINT 信号的阻塞,允许信号被捕获并处理。
  • 捕获到 SIGINT 信号后,headler 会打印挂起信号状态,处理信号并退出。

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

搜索文章

Tags

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