最新资讯

  • Linux下学【MySQL】底层存储的秘密---索引(存储引擎到底是什么?聚簇索引和非聚簇索引又是啥?)联合软硬件理解,通俗易懂,图文并茂

Linux下学【MySQL】底层存储的秘密---索引(存储引擎到底是什么?聚簇索引和非聚簇索引又是啥?)联合软硬件理解,通俗易懂,图文并茂

2025-04-27 10:37:33 1 阅读

绪论​

每日激励:“不设限和自我肯定的心态:I can do all things。 — Stephen Curry”

绪论​:
本章是MySQL中进阶的部分,通过了解索引知道MySQL底层到底是如何存储数据的,以及MySQL底层中的结构到底是啥,本章主要具体的讲到了索引、MySQL数据如何存储page、存储引擎的结构B+树任何管理page数据、索引的操作(本质其实是主键的操作),最终相信通过本章索引的理解你会对MySQL数据库存储有很大的提升,下期将更新MySQL另一大知识点事务,敬请期待~
————————
若有看不懂如何登录Linux中的MySQL来执行具体代码的或者不知道如何创建表等一些列MySQL基础的的请看—》MySQL专栏(文章平均94分)
——————————
早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。


1. 什么是索引?没有索引可能会有什么问题?

索引:提高数据库的性能,索引是物美价廉的东西了。

不用加内存,不用改程序,不用调sql,只要执行正确的 create index ,查询速度就可能提高成百上千倍。但是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的IO。所以它的价值,在于提高一个海量数据的检索速度

这些操作全部是在mysql的内存中进行的,然后定期刷新到外设硬盘中mysql的服务器,本质是在内存中的,所有的数据库的CURD操作,全部是在内存中进行的!索引也是如此!

实验海量表中没有索引时有什么问题

先整一个海量表,在查询的时候,看看没有索引时有什么问题?
index.data.sql:

--构建一个8000000条记录的数据 --构建的海量表数据需要有差异性,所以使用存储过程来创建, 拷贝下面代码就可以了,暂时不用理解 -- 产生随机字符串 
delimiter $$ 
create function rand_string(n INT) 
returns varchar(255) 
begin 
declare chars_str varchar(100) default 
	'abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ'; 
declare return_str varchar(255) default ''; 
declare i int default 0; 
while i < n do 
	set return_str = concat(return_str,substring(chars_str,floor(1+rand()*52),1)); 
	set i = i + 1; 
	end while; 
	return return_str; 
	end $$ 
delimiter ;

--产生随机数字 
delimiter $$ 
create function rand_num()
 returns int(5) 
 begin declare i int default 0;
  set i = floor(10+rand()*500);
   return i;
 end $$
delimiter ; 

--创建存储过程,向雇员表添加海量数据 
delimiter $$ 
create procedure insert_emp(in start int(10),in max_num int(10))
begin 
declare i int default 0;
 set autocommit = 0;
  repeat set i = i + 1;
   insert into EMP values ((start+i) ,rand_string(6),'SALESMAN',0001,curdate(),2000,400,rand_num());
until i = max_num end repeat;
 commit;
  end $$ 
delimiter ; 
-- 执行存储过程,添加8000000条记录 call insert_emp(100001, 8000000);

注意对于这些海量数据的表中,我们一定要使用limit限制。

查询海量数据中的empno=998877,并且因为数据非常海量所以查询数据也会偏久(花费5s),这在项目中是不太允许存在的:


那么就可以使用索引了(先了解下后面细讲):


创建索引:
alter tableadd index(字段名);

alter table EMP add index(empno);

当添加索引后再次查询(发现效率就能提高非常多!):

这就是索引带来的好处!

2. 硬件理解(可略过,不过看了你会对IO有不一样的理解)

认识磁盘

(磁盘大致主结构如下)

MySQL 给用户提供存储服务,而存储的都是数据,数据在磁盘这个外设当中。磁盘是计算机中的一个机械设备,相比于计算机其他电子元件磁盘效率是比较低的,在加上IO本身的特征,可以知道,如何提交效率,是 MySQL 的一个重要话题!

扇区


数据库文件,本质其实就是保存在磁盘的盘片当中。也就是上面的一个个小格子中,就是我们经常所说的扇区。当然,数据库文件很大,也很多,一定需要占据多个扇区。
题外话(回顾操作系统中的文件):

从上图可以看出来,在半径方向上,距离圆心越近,扇区越小,距离圆心越远,扇区越大
那么,所有扇区都是默认512字节吗?目前是的,我们也这样认为。因为保证一个扇区多大,是由比特位密度决定的。
不过最新的磁盘技术,已经慢慢的让扇区大小不同了,不过我们现在暂时不考虑。
我们在使用Linux,所看到的大部分目录或者文件,其实就是保存在硬盘当中的。(当然,有一些内存文件系统,如: proc , sys 之类,我们不考虑)

那么其中在Linux上的mysql的表本质也是一个个在Linux上的文件,所以说他本质也会访问文件也就是访问底层磁盘扇区获取数据
(磁盘的纵向图,观察扇区的)

柱面(磁道): 多盘磁盘,每盘都是双面,大小完全相等。那么同半径的磁道,整体上便构成了一个柱面

  • 每个盘面都有一个磁头,那么磁头和盘面的对应关系便是1对1的

  • 所以,我们只需要知道,磁头(Heads)、柱面(Cylinder)(等价于磁道)、扇区(Sector)对应的编号。即可在磁盘上定位所要访问的扇区。这磁盘数据定位方式叫做 CHS 。不过实际系统软件使用的并不是 CHS (但是硬件是),而是LBA,一种线性地址,可以想象成虚拟地址与物理地址系统将 LBA 地址最后会转化成为 CHS交给磁盘去进行数据读取。不过,我们现在不关心转化细节,知道这个东西,让我们逻辑自洽起来即可。

结论:
我们现在已经能够在硬件层面定位,任何一个基本数据块了(扇区)。那么在系统软件上,就直接按照扇区(512字节,部分4096字节),进行IO交互吗?
不是

  • 如果操作系统直接使用硬件提供的数据大小进行交互,那么系统的IO代码,就和硬件强相关,换言之,如果硬件发生变化,系统必须跟着变化,这样是效率偏低的。
  • 从目前来看,单次IO 512字节,还是太小了。IO单位小,意味着读取同样的数据内容,需要进行多次磁盘访问,会带来效率的降低。
  • 所以最终得出:文件系统读取基本单位,就不是扇区,而是数据块。(之前学习文件系统,就是在磁盘的基本结构下建立的)

故:系统读取磁盘,是以块为单位的,基本单位是 4KB 。

磁盘随机访问(Random Access)与连续访问(Sequential Access)

  1. 随机访问:本次IO所给出的扇区地址和上次IO给出扇区地址不连续,这样的话磁头在两次IO操作之间需要作比较大的移动动作才能重新开始读/写数据。
  2. 连续访问:如果当次IO给出的扇区地址与上次IO结束的扇区地址是连续的,那磁头就能很快的开始这次IO操作,这样的多个IO操作称为连续访问。
    因此尽管相邻的两次IO操作在同一时刻发出,但如果它们的请求的扇区地址相差很大的话也只能称为随机访问,而非连续访问。

磁盘是通过机械运动进行寻址的,随机访问不需要过多的定位,故效率比较高


通过了解了底层硬件,再来看上层软件


3. MySQL 与磁盘交互基本单位

而 MySQL 作为一款应用软件,可以想象成一种特殊的文件系统。它有着更高的IO场景,所以,为了提高基本的IO效率, MySQL 进行IO的基本单位是 16KB(而非文件4KB的) (后面统一使用 InnoDB 存储引擎讲解)
软硬件逻辑交互图:


查看innodb存储引擎的数据块大小sql:

show global status like 'innodb_page_size'


也就是说,磁盘这个硬件设备的基本单位是 512 字节(或4096)而 MySQL InnoDB引擎 使用 16KB 进行IO交互。即, MySQL 和磁盘进行数据交互的基本单位是 16KB 。这个基本数据单元,在 MySQL 这里叫做page(注意和系统的page区分)

4. MySQL底层数据存储

首先要了解MySQL底层本质也是通过OS和硬盘进行IO交互的,所以本质也就衍生出许多规则:

  1. MySQL 中的数据文件,是以page为单位(16kb)保存在磁盘当中的
  2. MySQL 的 CURD 操作,都需要通过计算,找到对应的插入位置,或者找到对应要修改或者查询的数据。
  3. 而只要涉及计算,就需要CPU参与,而为了便于CPU参与,一定要能够先将数据移动到内存当中。所以在特定时间内,数据一定是磁盘中有,内存中也有。后续操作完内存数据之后,以特定的刷新策略,刷新到磁盘。而这时,就涉及到磁盘和内存的数据交互,也就是IO了。而此时IO的基本单位就是Page。(mysql上层看起来是16kb,但底层内存和磁盘的IO交互还是4kb)
  4. 为了更好的进行上面的操作,== MySQL 服务器mysqld在内存中运行的时==候,在服务器内部,就申请了被称为 Buffer Pool 的的大内存空间,来进行各种缓存。其实就是很大的内存空间,来和磁盘数据进行IO交互。
  5. 而为了更高的效率,一定要尽可能的减少系统和磁盘IO的次数

了解了怎么多MySQL与底层的关系,其实本质就是为了引出一点:
MySQL和文件一样在底层磁盘中的存储都是以page块为单位的

那么话不多说,我就开始真正索引的理解


5. 索引的理解

  1. 创建表并插入数据:
  2. 发现我们向一个具有 主键的表中,乱序插入数据,发现数据会自动排序,这是谁做的?为什么做?(这后面会细说原因)
  3. 如何理解mysql中的page?
    1. 其中mysql的 buffer pool 128Mb,所以在mysql内部,一定需要并且会存在大量的page存在buffer pool中
    2. 也就决定了mysql 要将多个同时存在的page管理起来
    3. 要管理所有的MySQL内的page(需要先描述,在组织)

为何IO交互要是 Page

为何MySQL和磁盘进行IO交互的时候,要采用Page的方案进行交互呢?用多少,加载多少不香吗?

  1. 如上面的5条记录,如果MySQL要查找id=2的记录,第一次加载id=1,第二次加载id=2,一次一条记录,那么就需要2次IO。如果要找id=5,那么就需要5次IO。
  2. 但,如果这5条(或者更多)都被保存在一个Page中(16KB,能保存很多记录),那么第一次IO查找id=2的时 候,整个Page会被加载到MySQL的Buffer Pool中,这里完成了一次IO。但是往后如果在查找id=1,3,4,5 等,完全不需要进行IO了,而是直接在内存中进行了。所以,就在单Page里面,大大减少了IO的次数。(也就是局部性性原理,相关信息一般在一起
  • 怎么保证,用户一定下次找的数据,就在这个Page里面?
  • 不能严格保证,但是有很大概率,因为有局部性原理。
  • 往往IO效率低下的最主要矛盾不是IO单次数据量的大小,而是IO的次数

5.1理解 Page

MySQL 中要管理很多数据表文件,而要管理好这些文件,就需要 先描述,在组织,我们目前可以简单理解成一个个独立文件是有一个或者多个Page构成的。

不同的 Page ,在 MySQL 中,都是 16KB ,使用 prev 和 next 构成双向链表
因为有主键的问题, MySQL 会默认按照主键给我们的数据进行排序
从上面的Page内数据记录可以看出,数据是有序且彼此关联的

为什么数据库在插入数据时要对其进行排序呢
按正常顺序插入数据不是也挺好的吗?
插入数据时排序的目的,就是优化查询的效率。页内部存放数据的模块,实质上也是一个链表的结构,链表的特点也就是增删快,查询修改慢,所以优化查询的效率是必须的。
正式因为有序,在查找的时候,从头到后都是有效查找,没有任何一个查找是浪费的,而且,如果运气好,是可以提前结束查找过程的。

理解多个Page

  • 通过上面的分析,我们知道,上面页模式中,只有一个功能,就是在查询某条数据的时候直接将一整页的数据加载到内存中,以减少硬盘IO次数,从而提高性能。但是,我们也可以看到,现在的页模式内部,实际上是采用了链表的结构,前一条数据指向后一条数据,本质上还是通过数据的逐条比较来取出特定的数据。
  • 如果有1千万条数据,一定需要多个Page来保存1千万条数据,多个Page彼此使用双链表链接起来,而且每个Page内部的数据也是基于链表的。那么,查找特定一条记录,也一定是线性查找。这效率也太低了

5.2页目录

本质就是书籍中开始的目录,通过目录的形式快速的找到索要找的数据
单页情况:
针对上面的单页Page,引入目录(如下图):
那么当前,在一个Page内部,我们引入了目录。比如,我们要查找id=4记录,之前必须线性遍历4次,才能拿到结果。现在直接通过目录2[3],直接进行定位新的起始位置,提高了效率。
为何通过键值 MySQL 会自动排序:

可以很方便引入目录

多页情况:
MySQL 中每一页的大小只有 16KB ,单个Page大小固定,所以随着数据量不断增大, 16KB 不可能存下所有的数据,那么必定会有多个页来存储数据

在单表数据不断被插入的情况下, MySQL 会在容量不足的时候,自动开辟新的Page来保存新的数据,然后通过指针的方式,将所有的Page组织起来

温馨提示:上面的图,是理想结构,大家也知道,目前要保证整体有序,那么新插入的数据,不一定会在新Page上面,这里仅仅做演示==

这样,我们就可以通过多个Page遍历,Page内部通过目录来快速定位数据
可是,貌似这样也有效率问题,在Page之间,也是需要 MySQL 遍历的,遍历意味着依旧需要进行大量的IO,将下一个Page加载到内存,进行线性检测。这样就显得我们之前的Page内部的目录,有点杯水车薪了

那么如何解决呢?解决方案,其实就是我们之前的思路

5.3目录项(给Page也带上目录)

  1. 用一个目录项来指向某一页,而这个目录项存放的就是将要指向的页中存放的最小数据的键值。
  2. 和页内目录不同的地方在于,这种目录管理的级别是页,而页内目录管理的级别是行。
  3. 其中,每个目录项的构成是:键值+指针(图中没有画全)

    存在一个目录页来管理页目录,目录页中的数据存放的就是指向的那一页中最小的数据,有数据,就可通过比较,找到该访问那个Page,进而通过指针,找到下一个Page。
  • 其实目录页的本质也是页,普通页中存的数据是用户数据,而目录页中存的数据是普通页的地址。
  • 这样既能管理好页目录,也能再次避免数据量的增加

    总体如下图:
    然后在最后再用一个页目录管理目录项

    这货就是传说中的B+树(不同在于在非叶子结点处相互没了链接),至此,我们已经给我们的表user构建完了主键索引。
    并且常见的存储引擎都是B+树!

总结一下:

  1. 常见的存储引擎底层都是通过B+数来对数据的page进行管理
  2. 而在存储引擎中的B+树:它是由3层构成
  3. 从下而上
  4. 第三层:就是一个个page,他们呢内部也有目录项,通过目录项能够快速的找到数据
  5. 第二层:是一个个目录项:每个目录项存储的是page的最小(起始)的主键
  6. 第三层:再通过一个目录来管理目录项
  7. 这样三层结构下来,就能快速的找到page及page中的数据

附:

  1. 叶子结点保存数据,路上结点没有只保存 目录项
    1. 非叶子结点,不存数据,可以存储更多目录项,也就是可以管理更多Page
    2. 这颗树一定是一个矮胖的树
    3. 也就意味着途径路上结点减少!找到目标数据也就只需要更少的 Page,IO次数更少 提高了效率!
    4. 每一个结点都有目录项,可以大大提高搜索效率,总体提高搜索效率
  2. 叶子结点全部用链表级联起来

而这颗B+树本质就是 MySQL:innode db 索引结构!我们也就是在这张表上进行增删查改
若没有主键同样也是这样的方法构建(mysql会自动生成隐藏主键),但没有索引!

复盘一下:

  1. Page分为目录页和数据页。目录页只放各个下级Page的最小键值。
  2. 查找的时候,自定向下找,只需要加载部分目录页到内存,即可完成算法的整个查找过程,大大减少了IO次数

为何选择B+树

  1. 节点不存储data,这样一个节点就可以存储更多的key。可以使得树更矮,所以IO操作次数更少。
  2. 叶子节点相连,更便于进行范围查找

6. 聚簇索引 VS 非聚簇索引

MyISAM 存储引擎-主键索引:MyISAM 引擎同样使用B+树作为索引结果,叶节点的data域存放的是数据记录的地址。下图为 MyISAM表的主索引, Col1 为主键

其中, MyISAM 最大的特点是,将索引Page和数据Page分离,也就是叶子节点没有数据,只有对应数据的地址

相较于 InnoDB 索引, InnoDB 是将索引和数据放在一起的

创建一个表,使用innodb存储引擎:

在Linux系统中就创建了两个表:

当我们创建表test2并使用MyISAM存储引擎:

此时就会有三个表(本质也就是将表和数据分开了):

  • MyISAM 这种用户数据与索引数据分离的索引方案,叫做非聚簇索引
  • 相反:聚簇索引就是:InnoDB这种将索引和数据放在一起的方案

6.1 辅助(普通)索引:

当然, MySQL 除了默认会建立主键索引外,我们用户也有可能建立按照其他列信息建立的索引(唯一键)。对于 MyISAM,建立辅助(普通)索引和主键索引没有差别,无非就是主键不能重复,而非主键可重复。

  • 同样, InnoDB 除了主键索引,用户也会建立辅助(普通)索引,我们以上表中的 Col3 建立对应的辅助索引如下图
    可以看到:
    1.InnoDB 的非主键索引中叶子节点并没有数据,而只有对应记录的key值
  1. 因为一份数据没必要主键索引存一份,其他辅助索引又存一份,浪费空间

所以通过辅助(普通)索引,找到目标记录,需要两遍索引

  1. 首先检索辅助索引获得主键
  2. 然后用主键到主索引中检索获得记录
  3. 这种过程,就叫做回表查询
  1. 只要有主键就会有主键索引(而系统在底层即使没有生成主键索引默认生成一个隐藏的主键)

总结:

  1. 索引的本质就是数据结构 B+ 树
  2. 当有主健就会有索引
  3. 而底层page中就会通过主键索引,连接起来这样也就会自动的进行排序
  4. 所以说我们在有主键的前提下:乱序插入他变成有序的原因就是如此

7. 索引的操作

0.索引的特点(本质就是主键特点)

  1. 一个表中,最多有一个主键索引,当然可以使符合主键
  2. 主键索引的效率高(主键不可重复)
  3. 创建主键索引的列,它的值不能为null,且不能重复
  4. 主键索引的列基本上是int

1. 创建主键索引:

  1. 直接通过设置主键
在创建表的时候,直接在字段名后指定 primary key
create table user1(id int primary key, name varchar(30));
create table user2(id int, name varchar(30), primary key(id));
  1. 创建标后添加主键(本质也是添加索引)
create table user3(id int, name varchar(30));
-- 创建表以后再添加主键
alter table user3 add primary key(id);

2. 查看表的索引

  1. show keys from 表名

  2. show index from 表名

  3. desc 表名

3. 唯一索引

  1. 本质就是创建唯一键的方法:
-- 在表定义时,在某列后直接指定unique唯一属性。
create table user4(id int primary key, name varchar(30) unique);
  1. 在表创建后添加唯一键
create table test1(id int primary key, name varchar(30));
alter table test1 add unique(name);


对于索引来说他本质是不需要我们自己设定的,当我们在设置约束:主键、唯一键时就会自动添加索引

4. 普通索引

  1. 第一种方式:
create table user8(id int primary key,
name varchar(20),
email varchar(30),
index(name) --在表的定义最后,指定某列为索引
);
  1. 第二种方式
create table user9(id int primary key, name varchar(20), email
varchar(30));
	
alter table user9 add index(name); --创建完表以后指定某列为普通索引


  1. 第三种方式
create table user10(id int primary key, name varchar(20), email
varchar(30));
-- 创建一个索引名为 idx_name 的索引
create index idx_name on user10(name);

5. 删除索引

  1. 删除主键索引:
alter table 表名 drop primary key

  1. 删除其他索引:
alter table 表名 drop index 索引名
索引名就是show keys
from 表名中的 Key_name 字段


因为他本质和普通索引是一样的

  1. 第三种方法方法:
drop index 索引名 on 表名;

6.复合索引

可以同时在多列上打上索引,相当于多列看成主键一样:

查看索引结构:

show index from test1G;


发现name和email都创建了索引结构,但这仅仅只是看起来,他们本质还是要联合进行查询的
验证方法当删除其中一个索引两个都将消失:

或者再使用能设置索引名的方法创建索引,发现两索引名称也是一致的

create index myindex on test1(name,email);

  1. 复合索引
  2. 索引最左匹配原则(当使用复合索引时,进行查询过程中需要匹配两个字段,它是从左往右匹配的)
  3. 索引覆盖(当在查询过程中,当匹配了左边的数据就不用再去匹配右边了,这样右边的就相当于被覆盖了般,也代表:索引只要有左边一个数据,就能将该复合索引找到,但注意索引的最左匹配原则,所以只能右两种情况:只有左边的索引,左右都在的索引)

8. 什么情况下添加索引

  1. 比较频繁作为查询条件的字段应该创建索引
  2. 唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件
  3. 更新非常频繁的字段不适合作创建索引
  4. 不会出现在where子句中的字段不该创建索引

9. 全文索引的创建

当对文章字段或有大量文字的字段进行检索时,会使用到全文索引。MySQL提供全文索引机制,但是有要求,要求表的存储引擎必须是MyISAM而且默认的全文索引支持英文,不支持中文。如果对中文进行全文检索,可以使用sphinx的中文版(coreseek)

创建表:

CREATE TABLE articles (
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
title VARCHAR(200),
body TEXT,
FULLTEXT (title,body) -- FULLTEXT创建全文索引
)engine=MyISAM;



插入一些数据:

现在需要再body内部进行搜索(表数据如下):

先进行平常正常的查询(并使用explain来查看查询的方式:type类型中的ALL就代表的是全部遍历式的查询,并且key为null也代表没有使用索引):

那如何使用全文索引呢?

explain SELECT * FROM articles WHERE MATCH (title,body) AGAINST ('database')G


本章完。预知后事如何,暂听下回分解。

如果有任何问题欢迎讨论哈!

如果觉得这篇文章对你有所帮助的话点点赞吧!

持续更新大量MySQL细致内容,早关注不迷路。

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

搜索文章

Tags

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