第72讲:MySQL数据库锁机制剖析:行级锁、间隙锁与临键锁详解及应用指南

news2024/11/17 17:32:41

文章目录

    • 1.行级锁的概念
    • 2.行锁的概念以及基本使用
      • 2.1.行锁的概念
      • 2.2.常见的SQL语句所对应的行锁类别
      • 2.3.行锁的基本使用
    • 3.间隙锁和临键锁的概念以及基本使用
      • 3.1.间隙锁和临键锁的概念
      • 3.2.间隙锁和临键锁的基本使用

1.行级锁的概念

行级锁指的是,每次操作锁住的是表中一行的数据,锁的力度最小,发生锁冲突的概率也是最低的,并且并发度也是最高的,行级锁主要应用于InnoDB存储引擎中。

在InnoDB存储引擎中,表中每一行数据都是基于索引组织的,在索引中分为聚集索引和二级索引,聚集索引的叶子节点挂的是表中的一行数据,二级索引的叶子节点挂的是表中每条数据的主键,因此在InnoDB存储引擎中,表中的数据都是基于索引组织存放的,并且基于索引组织存放后,叶子节点之间是有序存储的还形成了双向链表。

行级锁是通过索引结构中每行数据对应的索引项来实现的,索引项也就是索引元素、聚集索引中的叶子节点(主键),每个叶子节点都对应表中的每一行数据,因为行级锁是通过表中索引结构的索引元素来添加行数锁的,并非是对表中的每条记录添加的行级锁,

对于行级锁主要分为以下三类:

  • 行锁

顾名思义,就是锁定单行记录的锁,主要是为了防止当前事务对这条数据处理时,其他的事务也对这条数据进行处理,在RC、RR隔离级别下都支持行锁。

image-20220621215213741

  • 间隙锁

间隙锁指的是锁住两个叶子节点之间间隙部分的索引元素,但是不锁定对应的记录,只是要确保索引元素之间的间隙不发生改变,以免其他事务通过索引元素之间的间隙元素写入数据,产生幻读的现象。在RR隔离级别下支持。

如下图所示,只是为了锁住两个叶子节点间的索引元素间隙,例如29和34两个索引元素,只是为了锁定29-34之间的间隙,防止新数据通过29-34之间的一个索引元素写入数据,从而导致幻读的现象。

image-20220621215518736

  • 临键锁

临键锁指的是将行锁与间隙锁组合锁定,既锁定数据又要锁定住叶子节点之间的间隙元素,在RR隔离级别下支持。

image-20220621215740464

2.行锁的概念以及基本使用

2.1.行锁的概念

在行锁中还会分为两种类型的行锁,一种是共享锁(S),另外一种是排它锁(X)。

默认的情况下,InnoDB在RR事务隔离级别运行行锁,通过next-key锁进行搜索和索引扫描,防止幻读。

当我们针对唯一索引的字段进行检索时,对已存在的记录进行匹配,将会优化为行锁。

InnoDB的行锁是针对索引加的锁,因此当不通过索引字段检索数据时,默认会将表加上一个表锁。

1)共享锁

在共享锁中,允许多个事务读取读取相同数据集的共享锁语句,但是拒绝排它锁处理与共享锁相同的数据集。

例如事务A查询表中小明人员的年龄,产生了行共享锁,此时事务B也查询小明人员的年龄产生共享锁,共享锁之间互相兼容,因此两个事务同时读取相同数据集的内容是允许的,没有任何问题。

但是当事务A查询表中小明人员的年龄时,事务B此时要修改小明人员的信息,修改操作会产生排它锁,事务A正在读取这条数据,事务B却要修改,此时会出现行锁冲突,使事务B的修改语句一直处于阻塞状态。只有当事务A针对这条数据处理完提交事务后,事务B才能成功执行对应的修改SQL。

结论:共享锁与共享锁之间相互兼容,但是共享锁与排它锁之间互斥,会产生冲突,此时只有当共享锁释放后,排它锁才能执行。

2)排它锁

在排它锁中,不允许事务读取相同数据集的共享锁和排它锁。

例如事务A正在修改姓名为小明的数据,此时事务B也要修改或者查询姓名为小明的数据,此时无论是修改或者查询都会处于阻塞状态,因为事务A正在操作这条数据并且产生了排它锁,而事务B的修改也会产生排它锁、查询会产生共享锁,无论排它锁还是共享锁都被事务A的排它锁互斥,从而产生行锁冲突。

结论:排它锁与共享锁和其他的排它锁都互斥,会导致行锁冲突,对于一条数据只有当排它锁释放之后,才能对这条数据进行处理。

2.2.常见的SQL语句所对应的行锁类别

SQL行锁类型说明
INSERT排它锁自动加锁
UPDATE排它锁自动加锁
DELETE排它锁自动加锁
SELECT不加任何锁
SELECT…LOCK IN SHARE MODE共享锁手动在SELECT之后添加LOCK IN SHARE MODE
SELECT…FOR UPDATE排它锁手动在SELECT之后添加FOR UPDATE

2.3.行锁的基本使用

1)普通的select查询不会加任何的锁,此处略过,没有效果

2)验证共享锁与共享锁之间的兼容

首先开启一个事务,创建一个共享锁,然后在其他客户端也执行相同的查询共享锁,观察效果。

1.首先开启一个事务
mysql> begin;

2.创建一个行共享锁
mysql> select * from xscjb limit 1 lock in share mode;
+----+--------+------+------+------+------+
| xh | xm     | ywcj | sxcj | yycj | pjcj |
+----+--------+------+------+------+------+
|  1 | 小明   |   66 |   75 |   93 | NULL |
+----+--------+------+------+------+------+

3.查看行共享锁
mysql> select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;
+---------------+-------------+------------+-----------+-----------+-----------+
| object_schema | object_name | index_name | lock_type | lock_mode | lock_data |
+---------------+-------------+------------+-----------+-----------+-----------+
| db_1          | xscjb       | NULL       | TABLE     | IS        | NULL      |
| db_1          | xscjb       | PRIMARY    | RECORD    | S         | 1         |
+---------------+-------------+------------+-----------+-----------+-----------+
#lock_mode为S时,就表示是行共享锁

4.其他客户端也执行相同的查询语句没有任何影响
mysql> select * from xscjb limit 1 lock in share mode;
+----+--------+------+------+------+------+
| xh | xm     | ywcj | sxcj | yycj | pjcj |
+----+--------+------+------+------+------+
|  1 | 小明   |   66 |   75 |   93 | NULL |
+----+--------+------+------+------+------+

image-20220621223758341

3)验证共享锁与排他锁之间的兼容

首先开启一个事务,查询xscjb中xh为1的数据,不提交,然后再开启一个事务,更改id为2的数据观察效果,紧接着也更改id为1的数据。

1.首先开启一个事务
mysql> begin;

2.创建一个行共享锁,查询xh为1的数据
mysql> select * from xscjb where xh = 1 lock in share mode;
+----+--------+------+------+------+------+
| xh | xm     | ywcj | sxcj | yycj | pjcj |
+----+--------+------+------+------+------+
|  1 | 小明   |   66 |   75 |   93 | NULL |
+----+--------+------+------+------+------+
1 row in set (0.00 sec)

3.查看行共享锁
mysql> select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;
+---------------+-------------+------------+-----------+---------------+-----------+
| object_schema | object_name | index_name | lock_type | lock_mode     | lock_data |
+---------------+-------------+------------+-----------+---------------+-----------+
| db_1          | xscjb       | NULL       | TABLE     | IS            | NULL      |
| db_1          | xscjb       | PRIMARY    | RECORD    | S,REC_NOT_GAP | 1         |
+---------------+-------------+------------+-----------+---------------+-----------+
#lock_mode为S时,就表示是行共享锁

4.再开启一个事务修改xh为2的数据,正常修改
mysql> update xscjb set ywcj = '100' where xh = 2;

5.紧接着修改与第一个事务相同数据集的数据,会一直处于阻塞状态
mysql> update xscjb set ywcj = '100' where xh = 1;

#只有当第一个事务提交完毕后,才能对相同的数据集进行处理

image-20220621224548338

4)验证排它锁与排他锁之间的冲突

首先打开第一个事务,修改xh为1的数据,产生排它锁,然后再打开另一个事务,也修改xh为1的数据,验证排它锁与排它锁之间的互斥。

1.首先开启一个事务
mysql> begin;

2.修改xh为1的数据
mysql> update xscjb set ywcj = '100' where xh = 1;

3.查看产生的排它锁
mysql> select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;
+---------------+-------------+------------+-----------+---------------+-----------+
| object_schema | object_name | index_name | lock_type | lock_mode     | lock_data |
+---------------+-------------+------------+-----------+---------------+-----------+
| db_1          | xscjb_logs  | NULL       | TABLE     | IX            | NULL      |
| db_1          | xscjb       | NULL       | TABLE     | IX            | NULL      |
| db_1          | xscjb       | PRIMARY    | RECORD    | X,REC_NOT_GAP | 1         |
+---------------+-------------+------------+-----------+---------------+-----------+
#lock_mode为X表示排它锁

4.再开启一个事务同样修改xh为1的数据
mysql> update xscjb set ywcj = '100' where xh = 1;

#会一直处于阻塞状态,只有当第一个事务提交完成后,这个操作才能被执行。

image-20220621224948435

5)当检索的字段没有索引时字段添加表锁

xscjb表中xm字段是没有索引的,下面我们在SQL语句中就使用这个没有添加索引的字段,作为检索条件,观察会有什么效果。

1.开启事务A修改xm为小黑的数据
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update xscjb set ywcj = '100' where xm = '小黑';

2.开启事务B修改小李的数据
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update xscjb set ywcj = '100' where xm = '小李';

此时会发现小黑的数据修改成功了,但是小李的数据却不能修改,并且即使是有排它锁,只要不是相同的数据集就可以修改,那么目前是不能被修改的,这样就说明了当检索的字段不是索引字段时,那么行锁就会升级为表锁,只有当事务A提交后,事务B才能对表中的行进行处理,更验证了行锁是根据索引去添加的。

image-20220621225629387

我们只需要将xm字段添加一个索引,就不会导致行锁升级为表锁了。

3.间隙锁和临键锁的概念以及基本使用

3.1.间隙锁和临键锁的概念

间隙锁是锁的索引结构中,两个叶子节点之间间隙的索引元素,只是锁住间隙,不锁住数据。

例如两个叶子节点分别是7和10,间隙锁就会锁住7-10之间的间隙,此时插入数据时就不能使用7-10之间的 值作为主键值,避免间隙被使用。

间隙锁唯一的目的就是防止其他的事务将数据插入到两个叶子节点之间的间隙位置,间隙可以共存,一个事务采用的间隙锁不会阻止另一个事务在同一间隙上采用的间隙锁。也就是说多个事务可以同时开启相同的间隙锁。

为什么要用间隙锁和临键锁呢?因为在查询、修改某个范围的数据时,如果没有间隙锁,那么其他事务就可能会在这一段间隙内写入数据,从而影响当前事务提交数据的准确性,因为我们要锁定这个范围内的间隙已经对应的数据。

3.2.间隙锁和临键锁的基本使用

1)使用唯一索引列进行等值检索时,如果给不存在的记录添加锁后,会被设置成间隙锁。

开启一个事务A,修改xscjb中的一条数据,但是修改的数据在表中不存在,观察产生的间隙锁。

1.开启事务A修改表中不存在的数据
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update xscjb set ywcj = '120' where xh = '10';
#当修改的数据时表中不存在的数据,会自动将这个主键范围内设置一个间隙锁

2.查看产生的间隙排它锁
mysql> select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;
+---------------+-------------+------------+-----------+-----------+-----------+
| object_schema | object_name | index_name | lock_type | lock_mode | lock_data |
+---------------+-------------+------------+-----------+-----------+-----------+
| db_1          | xscjb       | NULL       | TABLE     | IX        | NULL      |
| db_1          | xscjb       | PRIMARY    | RECORD    | X,GAP     | 13        |
+---------------+-------------+------------+-----------+-----------+-----------+
#lock_mode为GAP表示是间隙锁
#lock_data这里的13表示锁住的间隙最大是13,最小是从距离13最近的范围,也就是8,8-13之间产生了间隙锁

3.此时开启事务B写入主键为11的数据将会阻塞
mysql> insert into xscjb values ('11','小笑','11','11','11',NULL);

首先我们来查询一下xscjb表的数据,可以看到主键8-13这个范围内没有其他数据,此时我们开启一个事务A来修改主键为10的数据,主键为10的数据不存在,并处于8-13的间隙内,此时就会产生一个间隙锁,间隙锁的范围就是8-13,可以从lock_data这里看到最大的间隙范围值,对应的最小间隙范围值就是距离13最近的一个值,也就是8-13,这时开启了事务B,事务B想要插入xh为11的数据,则会被阻塞,因为xh为11这个值处于8-13的间隙内,因此会被阻塞,当事务A提交后,阻塞才会被释放。

image-20220621231524231

2)使用普通索引非唯一索引进行等值检索,一直向后遍历直到直到不满足检索条件的数据,此时既会产生间隙锁又会产生临键锁。

我们的条件是对非唯一索引字段进行检索,那么一次检索中,可能就会出现多条相同的值,例如我们检索条件是nl=18,那么表中可能有很多条nl=18的数据,查询nl=18的数据时会加上共享锁,但是我们不能只锁住这一行数据,因为还会有很多条记录存在,因此还需要接着往后面遍历,直到找到一个不满足条件值,例如检索到了nl=26的数据,此时后面就没有nl=18的数据了,那么此时会对所有nl=18的数据添加临键锁,并且还会对nl=18~26之前的所有间隙添加间隙锁,保证数据获取的一致性。

首先为xscjb表中的ywcj字段添加一个普通索引。

mysql> create index idx_xscjb_ywcj on xscjb(ywcj);

使用普通索引作为检索条件,观察添加的间隙锁和临键锁。

mysql> select * from xscjb where ywcj = 88 lock in share mode;
+----+--------+------+------+------+------+
| xh | xm     | ywcj | sxcj | yycj | pjcj |
+----+--------+------+------+------+------+
|  8 | 小李   |   88 |   77 |   66 | NULL |
| 13 | 小赵   |   88 |   77 |   66 | NULL |
| 18 | 小王   |   88 |   77 |   66 | NULL |
| 25 | 小江   |   88 |   77 |   66 | NULL |
+----+--------+------+------+------+------+

mysql> select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;
+---------------+-------------+----------------+-----------+---------------+-----------+
| object_schema | object_name | index_name     | lock_type | lock_mode     | lock_data |
+---------------+-------------+----------------+-----------+---------------+-----------+
| db_1          | xscjb       | NULL           | TABLE     | IS            | NULL      |
| db_1          | xscjb       | idx_xscjb_ywcj | RECORD    | S             | 88, 8     |
| db_1          | xscjb       | idx_xscjb_ywcj | RECORD    | S             | 88, 13    |
| db_1          | xscjb       | idx_xscjb_ywcj | RECORD    | S             | 88, 18    |
| db_1          | xscjb       | idx_xscjb_ywcj | RECORD    | S             | 88, 25    |
| db_1          | xscjb       | PRIMARY        | RECORD    | S,REC_NOT_GAP | 25        |
| db_1          | xscjb       | PRIMARY        | RECORD    | S,REC_NOT_GAP | 18        |
| db_1          | xscjb       | PRIMARY        | RECORD    | S,REC_NOT_GAP | 13        |
| db_1          | xscjb       | PRIMARY        | RECORD    | S,REC_NOT_GAP | 8         |
| db_1          | xscjb       | idx_xscjb_ywcj | RECORD    | S,GAP         | 100, 1    |
+---------------+-------------+----------------+-----------+---------------+-----------+
10 rows in set (0.00 sec)

可以看到使用普通索引查询出多条ywcj为88的数据,此时对于所有查询出来88的数据都会添加一个临键锁,并且也会对88-100之间的间隙设置一个间隙锁。此时ywcj为88的数据也不允许被排它锁进行修改,88~100之间的间隙也不允许写入数据。

image-20220621234556120

3)使用唯一索引检索一个范围,观察加的锁。

我们使用唯一索引字段去检索一个范围查询,观察加的锁。

1.开启事务检索唯一索引的范围查询
mysql> begin;

mysql> select * from xscjb where xh > 15 lock in share mode;
+----+--------+------+------+------+------+
| xh | xm     | ywcj | sxcj | yycj | pjcj |
+----+--------+------+------+------+------+
| 18 | 小王   |   88 |   77 |   66 | NULL |
| 19 | 小黑   |  100 |   77 |   66 | NULL |
| 25 | 小江   |   88 |   77 |   66 | NULL |
+----+--------+------+------+------+------+

2.观察添加了什么锁
mysql> select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;
+---------------+-------------+------------+-----------+-----------+------------------------+
| object_schema | object_name | index_name | lock_type | lock_mode | lock_data              |
+---------------+-------------+------------+-----------+-----------+------------------------+
| db_1          | xscjb       | NULL       | TABLE     | IS        | NULL                   |
| db_1          | xscjb       | PRIMARY    | RECORD    | S         | supremum pseudo-record |
| db_1          | xscjb       | PRIMARY    | RECORD    | S         | 25                     |
| db_1          | xscjb       | PRIMARY    | RECORD    | S         | 19                     |
| db_1          | xscjb       | PRIMARY    | RECORD    | S         | 18                     |
+---------------+-------------+------------+-----------+-----------+------------------------+

当使用唯一索引进行范围检索时,会对检索出来的数据都加一个临键锁,不允许被其他事务处理,保证数据一致性,并且并不知道每次检索会出来多少条数据,因此还有一个supremum pseudo-record标志,也是临键锁,表示正无穷大,无论检索出来多少条数据,只要是这个范围的数据,都会添加临键锁,防止其他事务修改数据。

image-20220621235823348

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1270493.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PyCharm免费安装和新手使用教程

PyCharm是一款由JetBrains公司开发的Python集成开发环境(IDE)。它提供了一系列强大的功能,包括自动代码完成、语法高亮、自动缩进、代码重构、调试器、测试工具、版本控制工具等,使开发者可以更加高效地开发Python应用程序。 新手…

C++中的类型转换和异常

C类型转换 类型转换(cast) 是将一种数据类型转换成另一种数据类型。例如,如果将一个整型 值赋给一个浮点类型的变量,编译器会暗地里将其转换成浮点类型。 转换是非常有用的,但是它也会带来一些问题,比如在转换指针时&#xff0c…

a-table:表格组件常用功能记录——基础积累2

antdvue是我目前项目的主流,在工作过程中,经常用到table组件。下面就记录一下工作中经常用到的部分知识点。 a-table:表格组件常用功能记录——基础积累2 效果图1.table 点击行触发点击事件1.1 实现单选 点击事件1.2 实现多选 点击事件1.3 实…

高效办公:如何使用视频剪辑工具批量转码,mp4视频到TS视频

在视频处理过程中,转码是一项常见的任务。将MP4视频转换为TS视频可以提供许多优势,包括更好的兼容性、更广泛的设备和平台支持以及更高的视频质量。然而,手动转码大量视频文件可能会非常耗时且效率低下。为了实现高效办公,可以使用…

模板引擎详解

📑打牌 : da pai ge的个人主页 🌤️个人专栏 : da pai ge的博客专栏 ☁️宝剑锋从磨砺出,梅花香自苦寒来 🌤️动态页面的渲染方式 …

2023-简单点-树莓派-camera module 3介绍

Raspberry Pi Camera Module 3 介绍开头先说,注意事项libcamera感光芯片和驱动的兼容图额外:不同module的对应的参数图用bullseye系统测试摄像头预览窗口拍摄静态图片bayer raw图像获取超长曝光视频流raw视频流 ref 介绍 树莓派镜像在Bullseye版本之后&…

【每日一题】1657. 确定两个字符串是否接近-2023.11.30

题目: 1657. 确定两个字符串是否接近 如果可以使用以下操作从一个字符串得到另一个字符串,则认为两个字符串 接近 : 操作 1:交换任意两个 现有 字符。 例如,abcde -> aecdb操作 2:将一个 现有 字符的…

系统频繁崩溃,如何考虑系统的稳定性和可扩展性?

最近网传互联网应用信息系统频繁崩溃,语雀崩完淘宝崩,淘宝崩完滴滴崩,随着业务的发展和技术的进步,对于信息系统的要求也越来越高。信息应用系统为了满足不断增长的用户和业务需求,提高系统的稳定性和扩展性至关重要。…

华为云cce容器管理中的调度策略作用

研究不深,但是这个还是挺重要的,在这里记录一下。 在cce节点集群中,有时候会发现有的节点实例过于饱满,有的又有些空,导致部分节点由于压力过大,存在崩溃的危险,这时候调度策略就有用了。 我这…

new Date()国际化时间参数处理的存在偏差问题

[TOC](new Date()国际化时间参数处理的存在偏差问题) 实际存在场景:各国使用new Date进行处理时间到各国时区时处理后的日期与实际当地日期不符合,会存在以下场景如图: 统计日期和表头计算的日期不符合 点击某一天跳转到详情时间参数不正确 …

基于谷歌Flutter的媒体资讯APP的设计与实现

基于谷歌Flutter框架媒体资讯App的设计与实现 摘要: 当今社会,随着经济和科技的发展,人们的生活节奏也愈来愈快,人们生活的阅读时间也越来越少,越发的流行碎片化阅读,而同样的对于互联网的客户端开发者&am…

2.Ansible的copy模块,我最常用的模块

1. 简述 先从我自身的情况来说,我不是运维人员,并且对linux操作也不是特别熟悉,所以工作中我使用ansible基本就是在平常的自动化部署中,而使用最多的模块就是copy模块。我使用copy模块也主要是来替换生产环境的配置文件。所以&am…

数据结构树与二叉树(5)Huffman树

#include <iostream> #include <stack> #include <queue>using namespace std;struct Node {char name ;int code[200];int num 0;//code的下标int weight 0;//权重&#xff08;次数&#xff09;Node* lchild;//左孩子Node* rchild;//右孩子Node* parent;N…

获取Spring容器Bean工具类

获取Spring容器Bean工具类 1、创建SpringUtils工具类2、注册 SpringUtils工具类3、如果打包的是War方式&#xff0c;可能上面两个注册工具类的方法都没用 1、创建SpringUtils工具类 public class SpringUtils implements ApplicationContextAware {private static Application…

基于卷积神经网络的人体行为识别系统开发与设计

摘 要 基于卷积神经网络的人体行为识别的开发与设计 摘要&#xff1a;随着计算机领域不断的创新、其它行业对计算机的应用需求的提高以及社会对解放劳动力的迫切&#xff0c;人机交互成为人们关注的问题。深度学习的出现帮助了人们实现人机交互&#xff0c;而卷积神经网络是其…

Codeforces Round 907 (Div. 2) (C 贪心 D套路? F dfs序+差分树状数组)

A&#xff1a; 这种操作题&#xff0c;每次先想这个操作有什么性质 对于2^0来说可以操作 第1位 对于2^1来说可以操作 第1-2位 对于2^2来说可以操作 第1-4位 &#xff08;第3位无法单独修改&#xff09; 对于2^3来说可以操作 第1-8位&#xff08;第5 6 7位无法单独修改&…

SAP ABAP ALV Tree 的使用

在 SAP 业务系统中&#xff0c;大量地使用到了ALV Tree 对象&#xff0c;该对象在表格基础上对同类数据 进行归类&#xff0c;并对各分类能进行数据汇总&#xff0c;如图8-10 所示。 以航班表&#xff08;SPFLI&#xff09;为例&#xff1a; &#xff08;1&#xff09;按国家…

面试题:Docker 有几种网络模式?很多5 年工作经验都答不上来。。

文章目录 docker容器网络docker的4种网络模式bridge模式container模式host模式none模式 docker容器网络配置Linux内核实现名称空间的创建ip netns命令 创建Network Namespace操作Network Namespace转移设备veth pair创建veth pair实现Network Namespace间通信 四种网络模式配置…

springboot启动开启热部署

springboot启动开启热部署 手动方式 或者点idea上面的build->build project 自动方式 勾上Build project automatically 然后ctrl alt shift / 选择Registr 勾上就好了 新版idea可以在这里选 热部署范围设置 这是spring-boot-devtools起的作用&#xff0c;所以还…

Rest模式和参数

展开运算符和Rest参数都是JavaScript中的语法特性&#xff0c;用于处理函数的参数。它们在使用方式和功能上有一些区别。 展开运算符用于将可迭代对象展开为独立的值&#xff0c;而Rest参数用于将多个参数收集到一个数组中。展开运算符可以用于多种上下文&#xff0c;而Rest参数…