最新资讯

  • 【Linux篇】进程控制

【Linux篇】进程控制

2025-04-27 03:01:53 0 阅读

📌 个人主页: 孙同学_
🔧 文章专栏:Liunx
💡 关注我,分享经验,助你少走弯路!

1. 进程创建

1.1 fork函数

linuxfork函数是非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。

#include 
pid_t fork(void);
返回值:⾃进程中返回0,⽗进程返回⼦进程id,出错返回-1

进程调用fork,当控制转移到内核中的fork代码后,内核做:

  • 分配新的内存块和内核数据结构给子进程
  • 将父进程部分数据结构内容拷贝至子进程
  • 添加子进程到系统进程列表当中
  • fork返回,开始调度器调度

    当一个进程调用fork之后,就有两个二进制代码相同的进程。而且它们都运行到相同的地方。但每个进程都将可以开始它们自己的旅程,看如下程序。
int main( void )
{
 pid_t pid;
 printf("Before: pid is %d
", getpid());
 if ( (pid=fork()) == -1 )perror("fork()"),exit(1);
 printf("After:pid is %d, fork return %d
", getpid(), pid);
 sleep(1);
 return 0;
} 
运⾏结果:
[root@localhost linux]# ./a.out
Before: pid is 43676
After:pid is 43676, fork return 43677
After:pid is 43677, fork return 0

这里看到了三行输出,一行before,两行after。进程43676先打印before消息,然后它有打印after。另一个after消息有43677打印的。注意到进程43677没有打印before,为什么呢?如下图所示

所以,fork之前父进程独立执行,fork之后,父子两个执行流分别执行。
注意fork之后,谁先执行完全由调度器决定。

1.2 写时拷贝

通常,父子代码共享,父子再不写入时,数据也是共享的,当任意一方试图写入,便以写时拷备的方式各自一份副本。具体见下图:

上图显示父进程代码段在自己的页表中是只读的,包括我们以前定义的字符常量区,代码是不可写的,可是数据段为什么也是只读的?起始在我们的父进程还没创建子进程前,代码段是只读的没问题,但是数据段对应的映射关系,可能有一百个一千个映射地址,这些映射地址的权限实际上是读写的,但一旦创建了子进程,操作系统就会把数据段的权限也改成只读的。 然后后面的父子进程,比如说子进程尝试对它的数据进行写入,当它写入时,操作系统就会发现你要访问的数据,第一,数据是合法的,因为虚拟地址物理地址都有,而且它发现访问的区域是数据段,如果是代码段肯定在start_code,end_code这个区间里面,如果是数据段肯定在start_data,start_end这个区间里面,发现你是数据段,而且页表的映射关系是正确的,但是发现数据段怎么是只读的,所以这时候操作系统就会出错,这种出错不是真的错了,是操作系统检测到一个用户对一个只读的区域进行写入,但操作系统经过检查发现它是数据段,而且是子进程,这时候操作系统就会触发写时拷贝。写时拷贝是通过设置页表的权限,让页表让操作系统出错的行为。让操作系统知道我们正在访问一个只读的区域,进而在错误的驱使之下让操作系统完成对应的写时拷贝这样的任务。

因为有写时拷贝技术的存在,所以父子进程得以彻底分离离!完成了进程独立性的技术保证!
写时拷贝,是一种延时申请技术,可以提高整机内存的使用率

为什么要写时拷贝?

  1. 减少子进程的创建时间
  2. 减少内存浪费

1.3 fork调用失败的原因

  • 系统中有太多的进程
  • 实际用户的进程数超过了限制

2. 进程终止

进程终止的本质是释放系统资源,就是释放进程申请的相关内核数据结构和对应的数据和代码。

2.1 进程退出场景

  1. 代码运行完毕,结果正确
  2. 代码运行完毕,结果不正确
  3. 代码异常终止(退出码无意义)

2.2 进程常见退出方式

正常终止(可以通过 echo $? 查看最近进程的退出码):

  1. main返回(main函数结束表示进程结束,其他函数只表示自己函数调用完成)
  2. 调用exit(status)(任何地方调用exit表示进程结束,并返回给父进程bash子进程的退出码)
  3. _exit:终止一个调用进程(相当于谁调用它,它把谁“弄死”)
2.2.1 exit函数
#include 
void exit(int status);

exit最后也会调用_exit,但在调用_exit之前,还做了其他工作:

  1. 执行用户通过atexiton_exit定义的清理函数。
  2. 关闭所有打开的流,所有的缓存数据均被写入
  3. 调用_exit
2.2.2 _exit函数
#include 
void _exit(int status);
参数:status 定义了进程的终⽌状态,⽗进程通过wait来获取该值

说明:虽然statusint,但是仅有低8位可以被父进程所用。所以_exit(-1)时,在终端执行$?发现返回值是255。

2.2.3 exit和_exit的区别:

exit是c语言提供的,_exit是系统提供的
进程如果exit退出的时候,exit()会进行缓冲区的刷新
进程如果exit退出的时候,_exit不会进行缓冲区的刷新

库函数和系统调用是上下层的关系,库函数没有进程终止能力,只能调用系统调用,操作系统给它提供的进程终止的接口它才能终止进程,所以exit的底层封装了_exit,所以我们之前谈论的缓冲区一定不在操作系统的内部,而是库缓冲区(c语言提供的缓冲区)

异常退出

  • ctrl + c,信号终止
2.2.4 退出码

退出码在Linux中通常用来表示命令执行后的结果,0表示成功,非0表示不同的错误类型
Linux Shell 中的主要退出码:

退出码说明
0成功(命令正常执行)
1一般性错误(如参数错误、文件未找到、权限不足等)
2Shell 内置命令误用(如语法错误、未找到命令等)
126权限问题(命令不可执行,如缺少执行权限)
127命令未找到(Shell 找不到指定命令)
130进程被 Ctrl+C 终止(SIGINT 信号)
141进程被 SIGHUP 信号终止(如终端关闭)

3. 进程等待

3.1 进程等待必要性

  • 之前讲过,子进程退出,父进程如果不管不顾,就可能造成僵尸进程的问题,进而造成内存泄漏。
  • 进程一旦变成僵尸状态,那就刀枪不入,“杀人不眨眼”的kill-9也无能为力,因为谁也没有办法杀死一个已经死去的进程。
  • 最后,父进程派给子进程的任务完成的如何,我们需要知道。如,子进程运行完成,结果对还是不对,或者是否正常退出。
  • 父进程通过进程等待的方式,回收子进程资源,获取子进程退出信息

3.2 进程等待的方法

3.2.1 wait方法

如果等待子进程,子进程没有退出,父进程就会阻塞在wait调用处(相当于scanf)

#include
#include
pid_t wait(int* status);
返回值:
 成功返回被等待进程pid,失败返回-1。
参数:
 输出型参数,获取子进程退出状态,不关⼼则可以设置成为NULL
3.2.2 waitpid方法
pid_ t waitpid(pid_t pid, int *status, int options);
返回值:
 当正常返回的时候waitpid返回收集到的子进程的进程ID;
 如果设置了选项WNOHANG,⽽调⽤中waitpid发现没有已退出的子进程可收集,则返回0;
 如果调⽤中出错,则返回-1,这时errno会被设置成相应的值以指⽰错误所在;
参数:
 pid:
	 Pid = -1,等待任⼀个子进程。与wait等效。
	 Pid > 0.等待其进程ID与pid相等的⼦进程。
 status: 输出型参数
	 WIFEXITED(status): 若为正常终⽌子进程返回的状态,则为真。(查看进程是否是正常退出)
	 WEXITSTATUS(status)((status>>8)&0xFF): 若WIFEXITED⾮零,提取子进程退出码。(查看进程的退出码)
 options:默认为0,表⽰阻塞等待
 WNOHANG: 若pid指定的子进程没有结束,则waitpid()函数返回0,不予以等
待。若正常结束,则返回该子进程的ID。
  • 如果子进程已经退出,调用wait/waitpid时,wait/waitpid会立即返回,并且释放资源,获得子进程退出信息。
  • 如果在任意时刻调用wait/waitpid,子进程存在且正常运行,则进程可能阻塞。
  • 如果不存在该子进程,则立即出错返回。
3.2.3 获取子进程status
  • waitwaitpid,都有一个status参数,该参数是一个输出型参数,由操作系统填充。
  • 如果传递NULL,表示不关心子进程的退出状态信息。
  • 否则,操作系统会根据该参数,将子进程的退出信息反馈给父进程。
  • status不能简单的当作整形来看待,可以当作位图来看待,具体细节如下图(只研究status低16比特位):
3.2.4 阻塞与非阻塞等待
  • 进程的阻塞等待方式:
#include 
#include 
#include 
#include 
#include 
int main(void)
{
    pid_t pid;
    if ((pid = fork()) == -1)
        perror("fork"), exit(1);
    if (pid == 0) {
        sleep(20);
        exit(10);
    }
    else {
        int st;
        int ret = wait(&st);

        if (ret > 0 && (st & 0X7F) == 0) { // 正常退出 
            printf("child exit code:%d
", (st >> 8) & 0XFF);
        }
        else if (ret > 0) { // 异常退出 
            printf("sig code : %d
", st & 0X7F);
        }
    }
}
测试结果:
# ./a.out #等20秒退出
child exit code : 10
# ./a.out #在其他终端kill掉
sig code : 9
  • 进程的非阻塞等待方式:
#include 
#include 
#include 
#include 
#include 
typedef void (*handler_t)(); // 函数指针类型 
std::vector<handler_t> handlers; // 函数指针数组 
void fun_one() {
    printf("这是⼀个临时任务1
");
}
void fun_two() {
    printf("这是⼀个临时任务2
");
}
void Load() {
    handlers.push_back(fun_one);
    handlers.push_back(fun_two);
}
void handler() {
    if (handlers.empty())
        Load();
    for (auto iter : handlers)
        iter();
}
int main() {
    pid_t pid;
    pid = fork();
    if (pid < 0) {
        printf("%s fork error
", __FUNCTION__);
        return 1;
    }
    else if (pid == 0) { // child
        printf("child is run, pid is : %d
", getpid());
        sleep(5);
        exit(1);
    }
    else {
        int status = 0;
        pid_t ret = 0;
        do {
            ret = waitpid(-1, &status, WNOHANG); // ⾮阻塞式等待 
            if (ret == 0) {
                printf("child is running
");
            }
            handler();
        } while (ret == 0);
        if (WIFEXITED(status) && ret == pid) {
            printf("wait child 5s success, child return code is :%d.
",
                WEXITSTATUS(status));
        }
        else {
            printf("wait child failed, return.
");
            return 1;
        }
    }
    return 0;
}

4. 进程替换

我们先来看一段代码:


上面这种现象就叫做程序替换,也就是我自己的程序把系统当中的指令跑起来了。在程序替换的时候,并没有创建新的进程,只是把当前进程的代码和数据用新的进程的代码和数据覆盖式的进行替换。

  1. 问题一:“为什么我的程序运行结束了”,这段话没有在显示器上打印出来?
    答案是一旦程序替换成功就去执行新代码了,原始代码的后半部分已经不存在了
  • 有没有办法让后面的代码能继续执行?
    答案是有的,创建一个子进程,让子进程去做替换工作,让父进程继续执行后面的代码。

    效果演示:

    📌Tips:程序替换也能替换我们自己写的程序,就相当于一种加载器,可以加载各种程序,包括编译型的解释型的,程序替换本质上不会创建新的进程
    为什么不会影响父进程呢?
    a.进程具有独立性 b.数据和代码发生写时拷贝
  1. execl的返回值

    execl函数只有失败返回值,没有成功返回值
    💦结论exec*系列的函数,不用做返回值判定,只要返回,就是失败

4.1 替换原理

4.2 替换函数

  1. int execl(const char *path,const char *arg,...),第一个参数表示程序+路径名,第二个参数有个口诀:命令行怎么写,我们就怎么传(当然传-al也是可以的),而把参数一个一个的传进来我们称之为list,类似于以链表的形式传给它,所以execl这个l就是llist的意思,execl函数的最后一个参数必须以NULL结尾,表明参数传递完成

  2. int execlp(const char *file,cont char *arg,...),execlp当中的p表示PATH,所以第一个参数只需传要执行的程序名就行了,因为execlp会自动的在环境变量(PATH)里查找对应的命令,所以execlp一般执行系统级的命令。后面参数的传递和上面的相同

  3. int execv(const char *path,char *const argv[]),首先它没有带p所以它的参数是path,所以同上上,这里的v就相当于vector,所以第二个参数就以数组的形式呈现了,所以就必须提供一个命令行参数表,就是指针数组,就是把ls -a -l整体放在数组里,一次性传递,这个表也必须以NULL结尾。所以我们以前执行的所有命令行参数都是父进程通过execv传给子进程的

  4. int execvp(const char *path,char *const argv[]),有p所以不用带路径

  5. int execvpe(const *file,char *const argv[],char *const envp[])这里的v表示以数组的方式传进来,p表示不用带路径,e表示环境变量,如果非要传递环境变量列表,要求:被替换的子进程使用全新的Env列表(自己写的)

    若要以新增的方式传递环境列表呢?
    putenv表示哪个进程调用它,就在谁的环境变量表里新增一个环境变量(B是A的子进程,C是B的子进程,如果B在它的环境列表里导入了一个新的环境变量,A的环境列表里看不到,而C的环境列表里能看到)
    ➁如果我们就行用execvpe的方式呢?environ

    表示把新增的环境变量添加到环境变量表里面去,然后把环境变量表的起始地址传给execvpe

  6. int execle(const *path,const *arg,...,char * const envp[])

总结:
这些函数原型看起来很容易混,但只要掌握了规律就很好记。

  • l(list):表示参数采用列表
  • v(vector):参数用数组
  • p(path):有p自动搜索环境变量PATH
  • e(env):表示自己维护环境变量

上面这些函数都是对系统调用进行了语言型的封装,最后都要调用系统调用execve,为什么要做语言封装呢?因为程序替换时要面对各种各样上层替换的场景。所以execve在man手册第2节

下图exec函数簇一个完整的例子:


👍 如果对你有帮助,欢迎:

  • 点赞 ⭐️
  • 收藏 📌
  • 关注 🔔

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

搜索文章

Tags

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