最新资讯

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

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

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

绪论​

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