最新资讯

  • 【Linux】自动化编译工具——make/makefile(超细图例详解!!)

【Linux】自动化编译工具——make/makefile(超细图例详解!!)

2025-04-28 17:00:58 1 阅读

目录

一、前言

 二、make / Makefile背景介绍

 🥝Makefile是干什么的?

 🍇make又是什么?

三、demo实现【见见猪跑🐖】 

 四、依赖关系与依赖方法

1、概念理清 

2、感性理解【父与子👨】

3、深层理解【程序的翻译环境 + 栈的原理】 

 五、多学一招:项目清理

 1、演示与原理讲解

 2、.PHONY伪目标的作用

 3、.PHONY伪目标的原理 

 六、make的工作原理分析

 1、再谈make与Makefile

 2、探究make的判断机制🔍

 七、Makefile小知识📚

 八、总结与提炼

 九、共勉


一、前言

        在之前的博客中,讲解了 Linux的基本指令:指令详解  ,但是呢,在我们常见的项目编译中肯定会包含很多代码文件,只会运用 指令 是不够滴,所以本次博客我们来介绍一下如何使用 make/Makefile 实现项目的自动化构建

  • 大部分老铁都应该知道如何在Linux上编译C语言代码,而且清楚了可执行文件a.out的由来,是从
    • test.c经过预编译test.i
    • test.i经过编译test.s
    • test.s经过汇编test.o
    • test.o经过链接a.out
  • 如果有老铁还不清楚的可看看这篇 编译+链接 的过程,是不是觉得很冗余复杂,我们平常做做练习还好,但若是到了那些大型工程中,可是具有上千、上万条代码,若是一次编译完成之后又修改了源代码,接着又想进行编译,此时便需要重新敲入指令,那会使得工作量变得很大。可是在VS中,我们可以无限地修改自己的代码,然后随时编译运行,不需要考虑这些复杂的原理
  • Linux中有没有这样的一站式操作呢,那就是【make/Makefile】👈

 二、make / Makefile背景介绍

首先我们来介绍一下什么是make/Makefile,以及它们之间的关系 

 🥝Makefile是干什么的?

  • Makefile 是一个文件。它是一个工程文件的编译规则,它记录了原始码如何编译的详细信息、描述了整个工程的编译链接等规则。
  • Makefile 带来的好处就是——“自动化编译"。一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率🚀

🎯先来看一下Makefile的【语法】: 

target(目标文件):文件1 文件2(依赖文件列表)		//依赖关系

gcc -o 欲建立的执行文件 目标文件1 目标文件2		///依赖方法
	 command
	 ...
	 ...
  • target就是我们想要建立的信息,一般称作目标文件。而后面的依赖文件列表就是具有相关性的 object files,也就是目标文件所依赖的文件(可以是一个或多个,也可以没有)

 🎯然后看一下Makefile的【规则】:

  •  目标文件与依赖文件列表文件之间要使用冒号隔开目标文件:依赖文件列表
  •  target可以是一个目标文件、执行文件,甚至可以是一个标签【后面会提到的伪目标】
  •  依赖方法前面必须加Tab空格键
  •  依赖方法以gcc为例,也可以是其他的shell指令【command】

💪会不会写Makefile ,从一个侧面说明了一个人是否具备完成大型工程的能力💪 

 🍇make又是什么?

  • make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi 的 make,Visual C++的nmake,Linux下GNU的make。可见,Makefile都成为了一种在工程方面的编译方法

【总结一下】:make 一条命令makefile 是一个文件,两个搭配使用,完成项目自动化构建👈 

三、demo实现【见见猪跑🐖】 

了解可什么是make/Makefile之后,我们就来用一用它们 

  • 刚才说到make命令是用来解释 Makefile 中指令的,所以我们需要创建一个。我喜欢用大写的Makefile,当然你写成 makefile 也是可以的
  •  这里直接vim Makefile即可,进入编辑界面,如果有不懂vim的,可以看看我的文章----------
  • Vim 的超详细使用

  • 此时我们可以再创建一个test.c,作为源文件,然后开始往里面写内容
  • 现在我要通过gcc去编译这个test.c的文件,然后生成一个我自己命名的【mytest】这个可执行文件,此时我们只需要在Makefile写上这两行即可
mytest:test.c
	gcc -o mytest test.c

  • 然后回到命令行,我们来执行一下这个make指令,它就是自动在当前源文件的所在路径下搜寻Makefile,并解释里面命令。之后若是我们需要去编译任何文件,只需要在Makefile里面做一个添加即可,怎么样,是不是很方便

看到了 make / Makefile 的基本实现过程,我们再来说一下 它的原理吧!!!

 四、依赖关系与依赖方法

通过小小的demo,想必你已经感受到了【自动化构建工具】的强大,我们来仔细看看Makefile中的指令为何要如此书写✍ 

1、概念理清 

  • 对于 mytest:test.c,冒号左侧是目标文件,右侧是它的依赖文件,所以就可以说它们之间存在一种【依赖关系】,只有test.c存在才可以有mytest
  • 那要如何通过test.c去生成mytest呢❓ 此时就需要使用到下面的这句gcc指令gcc -o mytest test.c 👉它叫做【依赖方法

 2、感性理解【父与子👨】

 就这么说还是不太好理解,我们举个父与子的生活小案例来帮助理解

今天呢,是这个月的12号的了,家里面在月初给你的2000块钱差不多也花完了,于是这两天只能吃土,此时你打开微信后看到和老爸的聊天框,于是就想着和老爸要点钱【毕竟儿子向父亲要钱天经地义😀

  •  这里的老爸和儿子指的就是[依赖关系]
  •  儿子向老爸要钱指的就是[依赖方法]


下面辨析几种依赖关系与依赖方法 

错误的依赖方法 

  • 此时你打电话和你老爸说:“我是你儿子,你帮我写作业。”
  • 以上这句话就是依赖关系正确,但是依赖方法不正确。老爸帮儿子写作业无法执行

所以只有依赖关系不行,还得有正确的依赖方法 

错误的依赖关系 

  • 此时你拿起室友的手机和他爸爸打电话说:“我是你儿子,你给我点零花钱。”
  • 以上这句话就是依赖方法正确,但是依赖关系不正确。因为别人的老爸没义务给你钱

依赖方法对了,但是依赖关系不对也不行 

 ✔️ 正确的依赖关系与依赖方法

  • 经历了种种挫折后,你重新拿起手机说:“老爸,我是你儿子,可以给我点零花钱吗?”
  • 上面这种说法就是完全正确的依赖关系与依赖方法

完成一件事,必须得有正确的依赖关系 + 正确的依赖方法 

3、深层理解【程序的翻译环境 + 栈的原理】 

 看完了【依赖关系】与【依赖方法】的感性理解,相信你对它们有了一定程度的认识,接下去深入地来了解一下它们之间的关系

  1 mytest:test.o
  2     gcc test.o -o mytest
  • 开头提到过源程序是如何经过一步步的编译来形成可执行文件的吗,因为可执行文件mytest是依赖于汇编后的目标文件test.o的,但是现在我们没有这个文件,因此就要去倒推一下如何获取这个test.o
  •   对于test.o来说,它依赖于test.s这个经过编译之后文件,可是【test.s】不存在,所以跳转到下一条依赖关系
  3 test.o:test.s
  4     gcc -c test.s -o test.o
  • 对于test.s来说,它依赖于test.i这个经过预编译之后的文件,可是【test.i】不存在,所以跳转到下一条依赖关系 
  5 test.s:test.i
  6     gcc -S test.i -o test.s
  •  对于test.i来说,它依赖于test.c这个源文件,查找后发现源文件存在,于是开始执行gcc命令
  7 test.i:test.c
  8     gcc -E test.c -o test.i

 以下就是我们需要在Makefile中修改的【依赖关系】与【依赖方法】

  • 最后来到命令行中执行一下【make】命令,便完成了所有的编译,对于之前一步步地写这个编译的过程,真的是来得方便很多

  • 因为只有当执行完了最后一条命令后生成了【test.i】的文件之后才可以一一往上继续执行,这种反着来的执行逻辑就相当于是我们在数据结构中学过的,有一个先进后出的逻辑

 那这个Makefile这么牛,我们将 gcc编译 的顺序修改一下,会发生什么呢?

  • 可是呢,当我再去make的时候,却发现这个执行的顺序还是按照没打乱之前的位置,这说明了一点:make会自动推导Makefile中的依赖关系形成栈式结构

【总结一下】:[依赖关系] 中,若是目标文件所依赖的文件不存在,就将这个依赖方法入栈,转到下一组[依赖关系],依次循环往复,直到当前目标文件所依赖的文件存在时,就进行出栈,开始执行依赖方法最后获取的便是那个我们最初想要的目标文件,即使Makefile中的编译顺序发生了变化,make也会去做一个自动推导的工作

 五、多学一招:项目清理

 1、演示与原理讲解

平时我们在进行各种操作之后目录中都会出现很多文件,此时当我们不想要这些文件的时候,就得去一一删除,显得尤为麻烦,如果编译可以使用Makefile来自动化构建,那清理项目中的文件可不可以呢,我们来看看 

  • 此时我们在Makefile中增加一个【清理】功能

  • 来看一下是否可以达到清理的目的

  • 当我想使用清理功能的时候,并没有像自动化编译那样直接make,而是在make后面加上了一个clean,这是为什么呢?
  • 新加上的.PHONY是什么?它对clean而言意味着什么?

 我们带着这些问题一起进入【伪目标】------ .PHONY 的学习📖

 2、.PHONY伪目标的作用

  • .PHONY是一个伪目标,Makefile中将 .PHONY 放在一个目标前就是指明这个目标是伪文件目标。其作用就是防止在Makefile中定义的执行命令的目标和工作目录下的实际文件出现名字冲突

  • 也就是下面这句,此时的clean.PHONY修饰了,那么它就可以反复执行它的依赖方法

.PHONY:clean
  • 可以看到对于目标文件clean来说,它的依赖文件列表为空,上面我们也有提到过它可以为空
 11 clean:
 12     rm -f mytest test.i test.s test.o
  • 所以只要你一直使用【make clean】,它便会反复地执行rm -f mytest test.i test.s test.o
  • .PHONY 配置项的目标clean并不是其他文件生成的实际文件,使make命令会自动绕过隐含规则搜索过程,也就是说执行命令make clean自动忽略名为"clean"文件的存在,因此声明.PHONY配置项会改善性能,并且不需要担心实际同名文件存在与否😮
  • 【通俗一点说】:.PHONY修饰的目标clean并不是某个依赖项生成的实际文件,因此make命令不再去搜寻当前文件夹下是否有clean文件,这样少去做一些事,自然会改善性能,并且不用担心当前文件夹下是否有同名的文件

 我们到命令行中来验证一下⌨️

  • 可以看到,我进行了三次make clean,不过其实在第一次执行的时候,就已经达成了我们清理的目的,可是后面还可以继续执行,这其实就是.PHONY修饰起的作用
  • 其实对于【clean】来说,不加修饰其实也是可以辺反复执行的,这点我们在本模块开头的时候有说到过。我现在将这个修饰去掉,来试试看

  • 可以看到,即使是去掉了.PHONY做修饰之后一样是可以反复执行

 那就有同学问:这是为什么呢?为何clean不加.PHONY修饰也可以多次执行

  • 原因就在于它的依赖对象为空,当我们需要生成这个【clean】目标文件的时候就不需一些文件必须要存在,因此就可以一直[clean]

 3、.PHONY伪目标的原理 

  • 可是呢,对于他的指令就不行了,例如我们上面说到过的gcc去编译一个文件的过程

  • 我们试着在【mytest】前面加上一个.PHONY的修饰试试

  • 然后再去试试能不能进行反复使用【这里给读者详细解释一下.PHONY修饰的原理】

我们来详细分析一下,首先可以清楚的是加上.PHONY修饰之后便可以多次make,但是可以看到在编译的过程中进行make的时候所执行的指令不太相同,只有gcc test.o -o mytest这一句,却少了如何产生【test.o】的过程,这是为何呢

  • 因为在经过一次make之后,gcc对【test.c】进行了预编译、编译、汇编,最后生成了【test.o】,那它就已经在那里了,在此中间我们没有再对源文件进行再度修改,在编译的时候,其实会去查看目标对象和依赖对象的生成时间,若是依赖对象的生成时间要早于目标对象,说明它还没有被重新修改过,所以无需再度去重新编译生成(这一块在后面make的工作原理中细讲)
  •  因此我们再去make的话gcc是不会重新编译的,可以当我去修改了一下【test.c】这个源文件之后,再度去make一下的话gcc又会对这个源文件进行一个重新的全过程编译。 

❗编译这一块比较复杂,需要重点理解❗ 

  • 不过其实可以看出,每次去修改一下就重新编译全部的文件,也是挺繁琐的。所以我们在开发的时候一般不给编译生成的目标文件带.PHONY的修饰,就防止其被多次重复编译

【总结一下】:

📚 .PHONY修饰的是伪目标,对于伪目标来说,它可以被反复执行

📚 .PHONY修饰的一定能被反复执行但是能被反复执行的不一定被.PHONY修饰

 六、make的工作原理分析

 1、再谈make与Makefile

  • 通过【ldd】去查看make指令的动态依赖关系,我们可以发现 make指令 也是依赖于标准的C库,而我们在Makefile中写得也都是一些指令,因此使用make指令才可以对Makefile中的内容做一个识别

 因此我们可以得出一个结论

👉make是专门给【Makefile】写的一个命令,在执行make的时候,就会自动在你当前目录下去搜索Makefile这个文件,搜索之后打开,然后对它里面的内容做分析 


make 是如何进行分析 Makefile 的呢,有什么规则吗❓

  • make扫描Makefile文件时会默认执行第一组依赖关系和依赖方法 
  • 还记得我们
    • 在获取mytest这个目标对象的时候都是直接使用的【make】吗;
    • 而在获取clean这个目标对象时却用的是【make clean】
  • 那你是否会感到疑惑为何不使用【make mytest】就可以获取到吗,就是因为默认执行的就是第一组的依赖关系和依赖方法
  • 我们可以试着把【clean】和【mytest】调个位置

  • 可以看到,在调换了位置之后我们直接【make】的话获取的就是clean对象了,想要去使用gcc编译源文件生成可执行文件就需要用到【make mytest】。
  • 不过也并不是第一组依赖关系和依赖方法就一定要直接【make】,我们使用【make clean】也是可以用的

 2、探究make的判断机制🔍

 好,我们来深入探讨一下刚才遗留下的问题:make究竟是如何知道我们的可执行文件是否需要重新编译呢❓

  • 再来回顾一下,当我们执行完一次【make】获取mytest这个目标文件后,第二次再去执行【make】指令就不会其效果了,这是为何呢?

  • 我们可以将源文件和可执行文件当做是一条时间轴。对于可执行文件来收,它生成的时间一定是晚于源文件的【因为中间要经过一系列编译 + 链接的过程】

  • 我们可以通过【stat】这个指令来查看源文件和可执行文件的所有属性,不过要观察的还是其中一个叫做ACM时间
    • Access: 最后一次访问该文件的时间
    • Change:最后一次改变该文件属性或状态的时间
    • Modify:最近一次修改文件内容的时间【比较的是这个时间】
  • 可以很清晰地看出10:30:14是要早于11:20:57的。所以【make】指令才会不起作用。所以它就是通过这个 Modify 时间来进行对比才能判断出是否需要重新编译

 七、Makefile小知识📚

 本模块来拓展一下有关make/Mailefile里的一些小知识

1. Makefile文件保存了编译器和链接器的参数选项,并且描述了所有源文件之间的关系。make程序会读取makefile文件中的数据,然后根据规则调用编译器,汇编器,链接器产生最后的输出

2. Makefile里主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释

  • 【显式规则】:如何生成一个或多个目标文件;
  • 【隐晦规则】:make有自动推导的功能,所以隐晦的规则可以让我们比较粗糙地简略地书写✍makefile,比如源文件与目标文件之间的时间关系判断之类;
  • 【变量定义】:在makefile中可以定义变量,当makefile被执行时,其中的变量都会被扩展到相应的引用位置上,通常使用 $(var) 表示引用变量;
  • 【文件指示】:包含在一个makefile中引用另一个makefile,类似C语言中的include

3. 默认的情况下,make命令会在当前目录下按顺序找寻文件名为“GNUmakefile”“makefile”“Makefile”的文件

4. 我们可以在Makefile中添加一些特殊符号,就可以起到一些特殊的功能 

  • 即这个$@$^,前者表示:左侧被编译的所有内容,即【目标文件】,后者表示:之后所有内容,即【依赖文件】

  • 此时,当我们再去make的时候,就可以发现这个特殊符号自动替换成了:两侧的【目标文件】和【依赖文件】


 接下去我再来介绍一种 Makefile 中的特殊文件

  • 写了这么多【make】,你是否感觉每次都会出现回显很麻烦呢?能不能像我们在敲普通指令的时候一样,直接给出结果呢?

  • 这里我们就可以在执行的命令行前加上这个@

  • 此时当我们在【make】和【make clean】的时候就不会产生任何回显了,可以达到一样的效果

 八、总结与提炼

 最后我们来总结一下本文所学习的内容📖

本文我们学习了Linux下的项目自动化构建工具make/Makefile 

  • 首先清楚了【Makefile】它是一个文件,我们可以在里面写入一些编译的规则。而【make】则是一个命令,它可以用来解析Makefile中的内容
  • 接着,在通过初次写一个小案例去接触make/Makefile的时候我们了解到了【依赖关系】和【依赖方法】,不仅感性地去理解了它们,而且深入地清楚了它们的底层实现逻辑是基于数据结构中的栈
  • 然后,不仅仅局限于一个目标文件,我们又学了一招,知道了如何去清理项目中的文件,知道了.PHONY修饰的文件叫做【伪目标文件】
  • 最后,我们通过再度触及make/Makefile,真正搞清楚了它们之间的关系,也了解到make在判断一个文件是否需要重新编译的时候是基于比较源文件与目标文件的【Modify时间】

 九、共勉

       以下就是我对【Linux】makefile自动化编译 的理解,如果有不懂和发现问题的小伙伴,请在评论区说出来哦,同时我还会继续更新对  Linux--进程 的理解,请持续关注我哦!!!!!    

 

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

搜索文章

Tags

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