当前位置: 首页 > news >正文

【Docker-16】Docker Volume存储卷

Docker Volume(存储卷)

概念比喻
镜像程序的光盘(安装包)
容器安装并运行后的 App
独立的文件夹或硬盘,用来保存数据
宿主机装着 Docker 的电脑或服务器,是一切的基础

一、什么是存储卷?

存储卷就是将宿主机的本地文件系统中存在的某个目录直接与容器内部的文件系统上的某一目录建立绑定关系。这就意味着,当我们在容器中的这个目录下写入数据时,容器会将其内容直接写入到宿主机上与此容器建立了绑定关系的目录。

在宿主机上的这个与容器形成绑定关系的目录被称作存储卷。卷的本质是文件或者目录,它可以绕过默认的联合文件系统,直接以文件或目录的形式存在于宿主机上。

宿主机的/data/web 目录与容器中的/container/data/web 目录绑定关系,然后容器中的进程向这个目录中写数据时,是直接写在宿主机的目录上的,绕过容器文件系统与宿主机的文件系统建立关联关系,使得可以在宿主机和容器内共享数据库内容,让容器直接访问宿主机中的内容,也可以宿主机向容器写入内容,容器和宿主机的数据读写是同步的

QQ_1745049489204

生活案例

存储卷就相当于租了个地下室,建立对应的映射就相当于有了这个地下室的钥匙,能够使用房子以外的空间

QQ_1745049516720

如果有一天龙卷风来了,房子被吹毁了,但是地下室依然安然无恙,就相当于容器销毁了我们的这个地下室依然没有影响。

QQ_1745049530886

为什么需要存储卷?

  1. 数据丢失问题

容器按照业务类型,总体可以分为两类:

  • 无状态的(数据不需要被持久化)
  • 有状态的(数据需要被持久化)

显然,容器更擅长无状态应用。因为未持久化数据的容器根目录的生命周期与容器的生命周期一样,容器文件系统的本质是在镜像层上面创建的读写层,运行中的容器对任何文件的修改都存在于该读写层,当容器被删除时,容器中的读写层也会随之消失。

虽然容器希望所有的业务都尽量保持无状态,这样容器就可以开箱即用,并且可以任意调度,但实际业务总是有各种需要数据持久化的场景,比如 MySQL、Kafka 等有状态的业务。因此为了解决有状态业务的需求,Docker 提出了卷(Volume)的概念。

  1. 性能问题

UnionFS 对于修改删除等,一般效率非常低,如果对一于 I/O 要求比较高的应用,如redis 在实现持化存储时,是在底层存储时的性能要求比较高。

  1. 宿主机和容器互访不方便

宿主机访问容器,或者容器访问要通过 docker cp 来完成,应用很难操作

  1. 容器和容器共享不方便

存储卷分类

目前 Docker 提供了三种方式将数据从宿主机挂载到容器中

  • volume docker 管理卷,默认映射到宿主机的 /var/lib/docker/volumes 目录下,只需要在容器内指定容器的挂载点是什么,而被绑定宿主机下的那个目录,是由容器引擎 daemon 自行创建一个空的目录,或者使用一个已经存在的目录,与存储卷建立存储关系,这种方式极大解脱用户在使用卷时的耦合关系,缺陷是用户无法指定那些使用目录,临时存储比较适合。
  • bind mount 绑定数据卷,映射到宿主机指定路径下,在宿主机上的路径要人工的指定一个特定的路径,在容器中也需要指定一个特定的路径,两个已知的路径建立关联关系
  • tmpfs mount 临时数据卷,映射到于宿主机的内存中,一旦容器停止运行,tmpfs mounts 会被移除,数据就会丢失,用于高性能的临时数据存储。

QQ_1745049727877

二、管理卷 Volume

2.1创建卷

存储卷可以通过命令方式创建,也可以在创建容器的时候通过 -v and --mount 指定

方式一:Volume 命令操作

命令清单如下

QQ_1745051234353

1.docker volume create

功能:创建存储卷

语法
docker volume create [OPTIONS] [VOLUME]关键参数
○ -d, --driver:指定驱动,默认是 local
○ --label:指定元数据
样例:
匿名卷
root@Nanyiroot:~/cdd# docker volume create
083c74d76ddf1f432cb0975071fae962ba3ed762de3a43ef2d35bb7dd87ce0de命名卷
root@Nanyiroot:~/cdd# docker volume create myvoltest1
myvoltest1
2.docker volume inspect

功能:查看卷详细信息

语法:
docker volume inspect [OPTIONS] VOLUME [VOLUME...]关键参数
-f:指定相应个格式,如 json。

样例:

QQ_1745051616418

3.docker volume ls

功能:列出卷

语法:
docker volume ls [OPTIONS]  关键参数 
--format:指定相应个格式,如 json、table。
--filter,-f:过滤。
-q:仅显示名称。

示例:

QQ_1745051773299

4.docker volume rm

功能:删除卷,需要容器不使用

语法:
docker volume rm [OPTIONS] VOLUME [VOLUME...]关键参数:
-f,--force:强制删除。

QQ_1745051935699

QQ_1745051988885

5.docker volume prune

功能:删除不使用的本地卷

语法:
docker volume prune [OPTIONS]关键参数
--filter:过滤。
-f,--force:不提示是否删除。

示例:

QQ_1745052157852

方式二(-v 或者–mount 指定)

-v 和 -mount 都可以完成管理卷的创建。

1.-v参数

功能:完成目录映射

 语法docker run -v name:directory[:options] ... ...参数
○ 第一个参数:卷名称
○ 第二个参数:卷映射到容器的目录
○ 第三个参数:选项,如 ro 表示 readonly

示例一:不指定 ro 选项:

QQ_1745052743558

示例二:指定 ro 选项:

QQ_1745053068827

2.–mount 参数

功能:完成目录映射

语法:
--mount '<key>=<value>,<key>=<value>'关键参数
○ type : 类型表示 bind, volume, or tmpfs
○ source ,src :对于命名卷,这是卷的名称。对于匿名卷,省略此字段。
○ destination,dst,target:文件或目录挂载在容器中的路径
○ ro,readonly: 只读方式挂载
完成目录映射

示例:采用mount 创建 volume:

QQ_1745053919997

root@Nanyiroot:~# docker run -d --name mynginxvol4 --mount 'dst=/usr/share/nginx/html' a7be6198544f
ce6e662834a72bacdf7923185ad876b9ed17be7c4e4220e2688b3a60cd54a2bfroot@Nanyiroot:~# docker inspect mynginxvol4

QQ_1745054180715

docker inspect mynginxvol3

QQ_1745054350102

QQ_1745054373370

方式三(Dockerfile 匿名卷)

通过 Dockerfile 的 VOLUME 可以创建 docker 管理卷。也可以通过 dockerfile 的 VOLUME 指令在镜像中创建 Data Volume,这样只需要通过该镜像创建的容器都会存在挂载点,但值得注意的是通过 VOLUME 指令创建的挂载点,无法指定主机上对应的目录,而是由 docker 随机生成的。

操作案例

案例一、Docker命令创建管理卷

1.命令创建管理卷

QQ_1745214929328

2.查看其中一个管理卷

可以看到对应的宿主机目录如下:

QQ_1745214972475

"Mountpoint": "/var/lib/docker/volumes/test1/_data",
容器里挂载这个卷后,数据实际上是被保存到 宿主机的这个路径。
举个例子:你在容器里写了一个文件 /data/hello.txt,如果 /data 是挂载的卷,那么这个文件实际上存在于宿主机的:

3.进入宿主机目录

docker run -d \--name mynginx1 \           # 容器名为 mynginx1-p 8045:80 \                # 将本机的 8045 端口映射到容器内的 80 端口-v test1:/usr/share/nginx/html \  # 将 Docker 卷 test1 挂载到 nginx 默认网页目录a7be6198544f               # 使用的镜像 ID(你这里用的是一个具体 ID)

QQ_1745215116875

4.查看容器内容

可以看到具体的 mount 信息

QQ_1745215695661

QQ_1745215720890

5.修改 index.html

QQ_1745215932740

6.通过浏览器查看 – 可以看到宿主机和容器是同步的

QQ_1745215981873

案例二、Docker -v 创建管理卷

结论:指定 ro 的话宿主机可以修改,但是容器里面无法修改

1.-v 创建管理卷,并且启动容器

2.查看卷目录内容

QQ_1745216343903

3.修改 index.html

4.浏览器查看

QQ_1745216434500

QQ_1745216460032

5.容器中修改提升无法修改

QQ_1745216537295

案例三、Docker mount 创建管理卷

结论:mount 创建的卷数据也会完成同步

1.mount 创建管理卷,并且启动容器

2.查看卷创建成功

3.查看卷挂载点

QQ_1745217096077

4.浏览器查看

QQ_1745217109786

5.宿主机上修改文件内容

QQ_1745217186694

6.查看页面

QQ_1745217198466

7.清理释放空间

docker stop mynginx3
docker rm mynginx3

案例四、Docker 卷生命周期

1.-v 创建管理卷,并且启动容器

QQ_1745217696730

2.进入卷目录

注意:此时可以看到容器里面的内容自动的放到了宿主机里面,也就是说宿主机上没有容器会拷贝过去。

docker inspect mynginx4

QQ_1745217766672

QQ_1745217792400

3.修改index.html

QQ_1745217860380

4.浏览器查看

QQ_1745217887665

5.清理释放空间

QQ_1745217935535

6.进入卷目录查看

可以看到文件并没有被删除:

QQ_1745217985466

7.删除卷

可以看到我们的卷被删除掉了:

QQ_1745218045217

案例五、Docker 卷共享

1.-v 创建管理卷,并且启动 2 容器,指定同一个卷

QQ_1745218439494

2.进入卷目录

QQ_1745218491883

3.修改 index.html

QQ_1745218555895

4.浏览器查看

可以看到两个都是一样的首页:

QQ_1745218582635

QQ_1745218596445

5.清理释放空间

QQ_1745218641761

三、绑定卷

绑定卷 = 把宿主机的某个目录,或者 Docker 的卷,挂载到容器内部的某个目录

容器里对这个目录的操作,都会映射到你绑定的位置。

-v 和 -mount 都可以完成绑定卷的创建

1、创建卷

(1)-v 参数创建卷

功能:完成卷映射

语法
docker run -v name:directory[:options] .........参数
○ 第一个参数:宿主机目录,这个和管理卷是不一样的
○ 第二个参数:卷映射到容器的目录
○ 第三个参数:选项,如 ro 表示 readonly

示例

QQ_1745220295642

docker inspect mynginx7

QQ_1745221100975

QQ_1745221234449

(2)–mount 参数创建绑定卷

功能:完成目录映射

语法:
--mount '<key>=<value>,<key>=<value>'
关键参数
○ type : 类型表示 bind, volume, or tmpfs
○ source ,src :宿主机目录,这个和管理卷是不一样的。
○ destination,dst,target:文件或目录挂载在容器中的路径
○ ro,readonly: 只读方式挂载
示例:
docker run -d mynginx8 --mount type=bind,src=/cdd/testmountbind,dst=/usr/share/nginx/html/ a7be6198544f

2、操作案例

(1)mount 创建绑定卷

1.使用-mount 方式创建容器

创建 nginx 容器,并将宿主机/testbindmount1 目录挂载至容器/usr/share/nginx/html 目录,注意如果 webapp1 目录不存在会启动报错

QQ_1745221949558

2.查看挂载信息

提前创建好对应目录,并在宿主机上添加 index.html:

QQ_1745222024455

QQ_1745222044990

3.进入容器的终端,查看挂载点目录,然后查看宿主机上的文件,还是存在,说明容器删除并不影响 bind 映射

QQ_1745222094764

如果是第一种写法,则可以发现容器该目录本身存在的文件消失不见,这是 bind mount 模式和 volume 模 式最大的不同点

4.释放空间

QQ_1745222147631

(2)-v 创建绑定卷

1.使用-v 方式创建容器

创建 nginx 容器,并将宿主机 /testbindmount3 目录挂载至容器 /usr/share/nginx/html 目录。

注意:如果 testbindmount3 目录不存在,启动不会报错,这是 -v 和 --mount 方式的区别

QQ_1745222294345

2.查看挂载信息

QQ_1745222325748

3.进入容器的终端,查看挂载点目录,和在宿主机上查看里面都是没有文件

QQ_1745222396909

可以发现容器该目录本身存在的文件消失不见,这是 bind mount 模式和 volume 模式最大的不同点。

4.在宿主机上添加 1.txt

QQ_1745222563317

5.删除容器,然后查看宿主机上的文件,还是存在,说明容器删除并不影响 bind 映射

QQ_1745222576248

(3)绑定卷共享

1.启动两个绑定卷,都绑定到宿主机的同一个目录

QQ_1745222728078

2.修改 index.html

QQ_1745222780657

3.访问 2 个页面可以看到相应内容一样

QQ_1745222798118

QQ_1745222807461

可以看到我们实现了容器间的数据共享

4.清理空间

QQ_1745222849785

四、临时卷 tmpfs

临时卷数据位于内存中,在容器和宿主机之外。

tmpfs 局限性

• 不同于卷和绑定挂载,不能在容器之间共享 tmpfs 挂载。

• 这个功能只有在 Linux 上运行 Docker 时才可用。

1.创建卷

方式一:指定**–tmpfs** 创建

功能:完成临时卷映射。

语法:
--tmpfs /app当你使用 --tmpfs /某个路径,这个路径在容器启动后会变成一个 空的、驻留在内存中的目录,即使镜像中原本有内容,也会被“隐藏”类比一下:
想象原本 /usr/share/nginx/html 是一块写好的黑板(镜像内容)
你拿一块白板(tmpfs)贴在它前面 → 你再也看不到黑板内容了
但实际上黑板还在,只是你临时看不见

示例

docker run -d --name mynginx15 --tmpfs /test1 a7be6198544f

QQ_1745228252657

(2)方式二(–mount 指定参数创建)

功能:完成目录映射

语法:
--mount '<key>=<value>,<key>=<value>'关键参数type:类型表示 bind, volume, or tmpfs。
destination,dst,target:挂载在容器中的路径。
tmpfs-size:tmpfs 挂载的大小(以字节为单位),默认无限制。
tmpfs-mode:tmpfs 的八进制文件模式。例如,700 或 0770,默认为 1777 或全局可写。

样例

root@Nanyiroot:~# docker run -d --name mynginx16 --mount type=tmpfs,dst=/test2 a7be6198544f
857f57a348b0a11bb549f7bc2e57c798405ae37324c0c6e194a5f1cbdc4a26b6

2.操作案例

(1)tmpfs 参数创建临时卷

1.创建临时卷并启动容器

docker run -d \--tmpfs /usr/share/nginx/html/ \  # 把 nginx 默认网页目录挂载为内存盘--name mynginx17 \-p 8078:80 \a7be6198544f

QQ_1745228662188

2.进入容器 – 可以看到 nginx 里面的文件被覆盖了,也就是说 tmpfs 也会覆盖容器里面的文件。

QQ_1745228779150

3.添加一个首页

QQ_1745228857797

4.浏览器查看

QQ_1745228875573

5.停止容器并启动容器 再次进入 – 可以看到 tmpfs 的内容完全消失了,也就是说内容是存在内存里面的。

QQ_1745228957862

QQ_1745228970635

6.清理空间

root@Nanyiroot:~# docker stop mynginx17
dmynginx17
root@Nanyiroot:~# docker rm mynginx17
mynginx17
(2)mount 创建临时卷

1.创建临时卷并启动容器 – 指定大小1m

QQ_1745229144305

2.进入容器–可以看到 nginx 里面的文件被覆盖了,也就是说 tmpfs 也会覆盖容器里面的文件

QQ_1745229349785

3.添加一个首页

QQ_1745229402950

4.浏览器查看

QQ_1745229425705

5.拷贝一个大文件到容器里面

dockerdemo-1.0-SNAPSHOT.jar 约 17M。

docker cp dockerdemo-1.0-SNAPSHOT.jar mynginx18:/

6.拷贝文件到我们的卷目录 – 超过了限制,空间限制为了 1m,会提示没有空间

root@Nanyiroot:~# docker exec -it mynginx18 bash
root@bb464b31b069:/# cd /usr/share/nginx/html/
root@bb464b31b069:/usr/share/nginx/html# ls -l
total 4
-rw-r--r-- 1 root root 39 Aug 16 14:44 index.html
root@bb464b31b069:/usr/share/nginx/html# ls -l /
bin dev docker-entrypoint.sh 
etc lib media opt root sbin sys tmp var
boot docker-entrypoint.d dockerdemo-1.0-SNAPSHOT.jar home lib64 mnt proc run srv test usr
root@bb464b31b069:/usr/share/nginx/html# cp /dockerdemo-1.0-SNAPSHOT.jar .
cp: error writing './dockerdemo-1.0-SNAPSHOT.jar': No space left on device

7.重启容器,再次进入 – 可以看到 tmpfs 的内容完全消失了,也就是说内容是存在内存里面的。

QQ_1745229854006

(3)tmpfs失踪了

实战目的:掌握临时卷的创建方式,了解临时卷的特殊存储方式

实战步骤

1.创建一个普通的容器 + 在容器里面写入一个文件 tmplabelbyxuyinli.txt

QQ_1745233677097

2.在宿主机上查找文件 + 打印内容

文件被找到了,是因为他在容器的可写层

QQ_1745233755473

3.创建一个临时卷 + 进入容器在 /app 目录下创建 mynewlabel.txt

QQ_1745233980878

4.在宿主机上查找 mynewlabel.txt

可以发现,文件找不到:所以 tmpfs 的内容不是存储在我们的容器的可写层里面的

QQ_1745234034858

5.释放资源

docker stop mynginx19 mynginx20
docker rm mynginx19 mynginx20

五、综合实战-MySQL 灾难恢复

**实战目的:**掌握挂载卷的使用,将 mysql 的业务数据存储到外部

实战步骤

使用 MySQL 5.7 的镜像创建容器并创建一个普通数据卷 mysql-data 用来保存容器中产生的数据。需要在容器中连接 MySQL 服务, 并创建数据库 test, 并在在该数据库中创建一个简单的表并插入一些数据进来。

1.准备镜像 – 如果不存在该镜像,则输入命令:docker pull mysql:5.7

QQ_1745234592951

2.创建容器 + 查看容器挂在信息

docker run --name mysql2 -v /root/cdd/mysql2test:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123cdd -d mysql:5.7
-e 选项通过参数 MYSQL_ROOT_PASSWORD 来传递 MySQL 密码。

QQ_1745235206773

3.连接 MySQL 的 shell, 创建数据库,密码是123cdd

创建了一个 test 数据库,并在该数据库中创建一个 student 表,在表中插入了一条数据

QQ_1745234867294

QQ_1745234960424

4.在宿主机中查看 volume

可以看到容器中 MySQL 创建的数据库和表数据以及持久化到宿主机挂载的目录下:

QQ_1745235344042

5.有一天莫名其妙停电了,然后服务器重启了

这个时候 MySQL 没有起来,然后此时发现磁盘空间不多了,于是把所有停止的容器都删除了,结果我们的 Mysql 也没有了

QQ_1745235375804

6.幸好数据还在,此时该如何恢复呢 – 再次启动运行命令,确保目录映射一致就能找回我们的数据

7.通过 mysql 的客户端进去,再次查看数据

可以看到,之前的数据还在:

QQ_1745235578368

8.释放空间

docker stop mysql2new
docker rm mysql2new

六、常见问题

1.什么时候用 Volume,什么时候用 bind、tmpfs?

volume:volume 是 docker 的宿主机文件系统一部分,用于不需要规划具体目录的场景

bind:bind mount 完全是依赖于主机的目录结构和操作系统,用于目录需要提前规划,比如 mysql 的目录需要个空间大的,其他服务有不占用的时候,用 volume 就不太合适了

tmpfs:用于敏感文件存储,文件不想存储的宿主机和容器的可写层之中

七、扩展思考:存储卷在实际研发中带来了哪些问题

  1. 跨主机使用

docker 存储卷是使用其所在的宿主机上的本地文件系统目录,也就是宿主机有一块磁盘,这块磁盘并没有共享给其他的 docker 主机,容器在这宿主机上停止或删除,是可以重新再创建的,但是不能调度到其他的主机上,这也是 docker 本身没有解决的问题,所以 docker 存储卷默认就是 docker 所在主机的本地,但是自己搭建一个共享的 NFS来存储 docker 存储的数据,也可以实现,但是这个过程强依赖于运维人员的能力。所以未来应用的存储和数据往往分离,越来越多的分布式存储方案出现,如 s3 系列,nfs 等。

  1. 启动参数未知

容器有一个问题,一般与进程的启动不太一样,就是容器启动时选项比较多,如果下次再启动时,很容器会忘记它启动时的选项,所以最好有一个文件来保存容器的启动,这就是容器编排工具的作用。

一般情况下,是使用命令来启动操作 docker,但是可以通过文件来读,也就读文件来启动,读所需要的存储卷等,但是它也只是操作一个容器,如果要几十上百个容器操作,就需要专业的容器编排工具

这种一般像开源的 k8s,各个云厂商也有自己的企业版编排软件。

  1. 复杂场景仍然需要运维

对于有状态要持久的集群化组件,如 mysql 的主从。部署维护一个 Mysql 主从需要运维知识、经验整合进去才能实现所谓的部署,扩展或缩容,出现问题后修复,必须要了解集群的规模有多大,有多少个主节点,有多少个从节点,主节点上有多少个库,这些都要一清二楚,才能修复故障,这些就强依赖于运维经验

这种复杂的场景往往还是需要人力,很难有完美的工具出现。

相关文章:

【Docker-16】Docker Volume存储卷

Docker Volume(存储卷) 概念比喻镜像程序的光盘&#xff08;安装包&#xff09;容器安装并运行后的 App卷独立的文件夹或硬盘&#xff0c;用来保存数据宿主机装着 Docker 的电脑或服务器&#xff0c;是一切的基础 一、什么是存储卷? 存储卷就是将宿主机的本地文件系统中存在…...

后端如何生成验证码

目录 &#x1f510; 一、验证码类型与用途 &#x1f4f8; 二、图形验证码的原理&#xff08;Image Captcha&#xff09; &#x1f527; 核心流程 &#x1f6e0;️ 示例&#xff1a;用 Python Pillow 生成图形验证码 &#x1f4f1; 三、数字验证码&#xff08;短信/邮箱&a…...

微服务架构下数据库范式的失效与反范式设计的崛起

在传统单体应用中&#xff0c;关系型数据库范式设计被认为是数据库建模的黄金标准。然而&#xff0c;随着企业架构向分布式系统&#xff0c;特别是微服务架构演进&#xff0c;范式化数据库设计的有效性和适应性正受到前所未有的挑战。本文将深入剖析范式设计的设计哲学&#xf…...

Redis专题

前言 一&#xff1a;看到你的简历上写了你的项目里面用到了redis&#xff0c;为啥用redis&#xff1f; 因为传统的关系型数据库如Mysql,已经不能适用所有的场景&#xff0c;比如秒杀的库存扣减&#xff0c;APP首页的访问流量高峰等&#xff0c;都很容易把数据库打崩&#xff0…...

Vue的模板语法——指令语法

2025/4/21 向全栈工程师迈进&#xff01; 一、插值语法 之前通过插值语法&#xff0c;其显示的效果如下。 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widt…...

【Java面试笔记:基础】1.谈谈你对Java平台的理解?

前言 Java 是历史悠久且主流的编程语言&#xff0c;拥有庞大的开发者群体和广泛的应用领域。通过系统学习和实践&#xff0c;构建扎实的 Java 知识体系&#xff0c;提升面试成功率 笔记核心内容 1. Java 平台的核心特性 跨平台特性&#xff1a;Java 的核心特性之一是“Writ…...

NestJS-Knife4j

文章目录 前言✅ 一、什么是 Knife4j&#xff1f;✅ 二、Knife4j 与 Swagger 对比✅ 三、NestJS-Knife4j 集成1. 安装依赖2. 配置 Swagger 与 Knife4j3. 启动应用并访问接口文档 ✅ 四、功能增强1. **接口分组**2. **请求/响应示例**3. **接口文档的美化** ✅ 五、总结 前言 N…...

Linux环境准备(安装VirtualBox和Ubuntu,安装MySQL,MySQL启动、重启和停止)

目录 安装VirtualBox和Ubuntu 安装VirtualBox 安装Ubuntu 下载Ubuntu操作系统的镜像文件 创建虚拟机 虚拟机设置 启动虚拟机&#xff0c;安装Ubuntu系统 Ubuntu基础设置 设置系统为中文 设置中文输入法为拼音 修改分辨率 设置缩放比例 设置息屏时间 设置root用户…...

Nebula图数据库

Nebula 通常指 Nebula Graph&#xff0c;是一款开源的分布式图数据库系统1。以下是其相关介绍1&#xff1a; 特点 高性能&#xff1a;能处理千亿顶点和万亿边的超大规模数据集&#xff0c;提供毫秒级查询延迟&#xff0c;在处理大规模数据时&#xff0c;也能维持低时延的读写和…...

基于 Vue,使用Vuex 或事件总线实现跨组件通信

在基于 Vue Element UI 的 RuoYi 系统中&#xff0c;如果需要在一个界面&#xff08;界面 A&#xff09;执行某个操作后&#xff0c;通知另一个界面&#xff08;界面 B&#xff09;刷新&#xff0c;可以通过 Vuex 或事件总线&#xff08;Event Bus&#xff09;来实现跨组件通信…...

【C++篇】string类的终章:深浅拷贝 + 模拟实现string类的深度解析(附源码)

&#x1f4ac; 欢迎讨论&#xff1a;在阅读过程中有任何疑问&#xff0c;欢迎在评论区留言&#xff0c;我们一起交流学习&#xff01; &#x1f44d; 点赞、收藏与分享&#xff1a;如果你觉得这篇文章对你有帮助&#xff0c;记得点赞、收藏&#xff0c;并分享给更多对C感兴趣的…...

线性DP:最短编辑距离

Dp 状态表示 f&#xff08;i&#xff0c;j&#xff09; 集合所有将A[1~i]变成B[1~j]的操作方式属性min 状态计算 &#xff08;划分&#xff09; 增f(i,j)f(i,j-1)1//A[i]元素要增加&#xff0c;说明A前i位置与B前j-1相同删f(i,j)f(i-1,j)1//A[i]元素要删除&#xff0c;说明A前i…...

【全网最全】23种设计模式思维导图详解 | 含React/Vue/Spring实战案例

【全网最全】23种设计模式思维导图详解 | 含React/Vue/Spring实战案例 导图概述 本文通过高清思维导图系统梳理了23种设计模式&#xff0c;分为创建型、结构型、行为型三大类&#xff0c;并标注了各模式在主流框架&#xff08;如React、Vue、Spring&#xff09;中的典型应用场…...

8086微机原理与接口技术复习(1)存储器(2)接口

8086微机原理与接口技术复习&#xff08;1&#xff09;存储器&#xff08;2&#xff09;接口 存储器8086的存储空间存储器的拓展存储器的分类 接口8086I/O82558253串行通信 存储器 我们上的是嵌入式与接口技术这门课&#xff0c;存储器章节重点在于理解8086CPU的存储体结构&am…...

第 6 篇:衡量预测好坏 - 评估指标

第 6 篇&#xff1a;衡量预测好坏 - 评估指标 上一篇&#xff0c;我们小试牛刀&#xff0c;用朴素预测、平均法、移动平均法和季节性朴素预测这几种简单方法对未来进行了预测。我们还通过可视化将预测结果与真实值进行了对比。 但光靠眼睛看图来判断“哪个预测更好”往往是不…...

极刻AI搜v1.0 问一次问题 AI工具一起答

软件名&#xff1a;极刻AI搜 版本&#xff1a;v1.0 功能&#xff1a;囊括了互联网上比较好用的一些支持”搜索“的网站或者工具 开发平台&#xff1a;nodepythonweb 分类有&#xff1a; AI搜索&#xff08;支持智能问答的AI搜索引擎&#xff09; 常规搜索&#xff1a;&#xff…...

单片机 + 图像处理芯片 + TFT彩屏 进度条控件

进度条控件使用说明 概述 本进度条控件基于单片机 RA8889/RA6809 TFT开发&#xff0c;提供了简单易用的进度显示功能。控件支持多个进度条同时显示、自定义颜色、边框和标签等特性&#xff0c;适用于需要直观显示进度信息的各类应用场景。 特性 支持多个进度条同时显示可…...

RHCSA Linux系统 用户和组的管理

用户管理&#xff1a;增useradd 删userdel 改usermod 查id 组的管理&#xff1a;增groupadd 删groupdel 改groupmod 查groups /etc/default/useradd 即定义useradd默认参数&#xff0c;也定义了/etc/passwd &#xff0c;/etc/shadow&#xff0c;/etc/group&#…...

2025年pta团队设计天梯赛题解

题解不全&#xff0c;望见谅 L1-1 珍惜生命 题目 前辈工程师 Martin Golding 教育我们说&#xff1a;“Always code as if the guy who ends up maintaining your code will be a violent psychopath who knows where you live.”&#xff08;写代码的时候&#xff0c;总是要…...

Vue---vue2和vue3的生命周期

核心生命周期对比 生命周期阶段Vue 2 钩子Vue 3 Composition API​​初始化​​beforeCreate无&#xff08;使用 setup() 替代&#xff09;​​初始化完成​​created无&#xff08;使用 setup() 替代&#xff09;​​挂载前​​beforeMountonBeforeMount​​挂载完成​​moun…...

C#常用LINQ

在开发时发现别人的代码使用到了LINQ十分便捷且清晰&#xff0c;这里记录一下常用LINQ和对应的使用。参考链接&#xff1a;LINQ 菜鸟教程 使用的学生类和字符串用于测试 public class Student {public int StudentID;public string StudentName;public int Age; }Student[] st…...

Java--数组的应用

一、数组的地址值 数组的地址值表示数组在内存中的位置。 [I1eb44e46 [ &#xff1a;表示当前是一个数组I&#xff1a;表示当前数组是int类型&#xff1a;表示一个间隔符号&#xff08;固定格式&#xff09;1eb44e46&#xff1a;数组真正的地址值&#xff08;十六进制&#…...

PostgreSQL基础

一、PostgreSQL介绍 PostgreSQL是一个功能强大的 开源 的关系型数据库。底层基于C实现。 PostgreSQL的开源协议和Linux内核版本的开源协议是一样的。。BDS协议&#xff0c;这个协议基本和MIT开源协议一样&#xff0c;说人话&#xff0c;就是你可以对PostgreSQL进行一些封装&a…...

Linux系统管理与编程13:基于CentOS7.x的LAMP环境部署

兰生幽谷&#xff0c;不为莫服而不芳&#xff1b; 君子行义&#xff0c;不为莫知而止休。 一、实验目标 1.理解Apache服务器原理 2.掌握Apache服务器的配置文件 3.具备安装Mysql数据库能力 4.具备安装Apache服务器能力 5.具备PHP与数据库连接能力 6.具备Apache、Mysql、…...

浅谈AI致幻

文章目录 当前形势下存在的AI幻觉&#xff08;AI致幻&#xff09;什么是AI幻觉AI幻觉的类型为什么AI会产生幻觉AI幻觉的危害与影响当前应对AI幻觉的技术与方法行业与学术界的最新进展未来挑战与展望结论 当前形势下存在的AI幻觉&#xff08;AI致幻&#xff09; 什么是AI幻觉 …...

【架构】-- StarRocks 和 Doris 介绍与选型建议

StarRocks 和 Doris 的介绍 随着大数据分析需求的不断增长,企业对高性能、低延迟的分析型数据库提出了更高的要求。StarRocks 和 Apache Doris 是当前主流的开源 MPP(Massively Parallel Processing)数据库系统,广泛应用于实时分析、报表生成和数据仓库等场景。本文将从架…...

【SF顺丰】顺丰开放平台API对接(注册、API测试篇)

1.注册开发者账号 注册地址&#xff1a;顺丰企业账户中心 2.登录开发平台 登录地址&#xff1a;顺丰开放平台 3.开发者对接 点击开发者对接 4.创建开发对接应用 开发者应用中“新建应用”创建应用&#xff0c;最多创建应用限制数量5个 注意&#xff1a;需要先复制保存生产校验…...

C语言高频面试题——常量指针与指针常量区别

1. 常量指针&#xff08;Pointer to Constant&#xff09; 定义&#xff1a; 常量指针是指向一个常量数据的指针&#xff0c;即指针指向的内容不能通过该指针被修改。 语法&#xff1a; const int* ptr;或者&#xff1a; int const* ptr;解释&#xff1a; const修饰的是指…...

Novartis诺华制药社招入职综合能力测评真题SHL题库考什么?

一、综合能力测试 诺华制药的入职测评中&#xff0c;综合能力测试是重要的一部分&#xff0c;主要考察应聘者的问题解决能力、数值计算能力和逻辑推理能力。测试总时长为46分钟&#xff0c;实际作答时间为36分钟&#xff0c;共24题。题型丰富多样&#xff0c;包括图形变换题、分…...

网页下载的m3u8格式文件使用FFmpeg转为MP4

FFmpeg 是一个强大的开源音视频处理工具&#xff0c;可以直接将 M3U8 合并并转换为 MP4。 1.步骤&#xff1a; 下载 FFmpeg 官网&#xff1a;https://ffmpeg.org/ Windows 用户可以直接下载 静态构建版本&#xff08;Static Build&#xff09;&#xff0c;解压后即可使用。 2…...

Java 并发包核心机制深度解析:锁的公平性、异步调度、AQS 原理全解

&#x1f9e0; Java 并发包核心机制深度解析&#xff1a;锁的公平性、异步调度、AQS 原理全解 Java 并发编程的地基是 java.util.concurrent&#xff0c;但真正驱动这个系统的&#xff0c;是它背后隐藏的三根支柱&#xff1a; ReentrantLock 的公平/非公平调度策略Completabl…...

μC/OS 版本演进过程 | uC/OS-II 和 uC/OS-III 有什么区别?

uC/OS 系列是由 Jean J. Labrosse 开发的一套嵌入式实时操作系统&#xff08;RTOS&#xff09;&#xff0c;以其高质量源码和清晰的结构&#xff0c;在嵌入式教学和某些工业项目中有着广泛影响。该系统主要包含两个版本&#xff1a;uC/OS-II 和 uC/OS-III。 本文将带你了解这两…...

永磁同步电机参数辨识算法--递推最小二乘法辨识

一、原理介绍 最小二乘法大约是1795年高斯在其著名的星体运动轨道预报研究工作中提出的。后来&#xff0c;最小二乘法成为了估计理论的基石。最小二乘法由于原理简明、收敛较快、易于编程实现等特点&#xff0c;在系统参数估计中应用相当广泛。 其基本原理为&#xff1a; 改写…...

树莓派5+L298N控制电机

准备工作: 树莓派5开发板L298N 控制板电机1个12v的电池1个杜邦线若干L298N 引脚介绍 (1)图中标注的1和2都是都在输出引脚,可以各接入一个电机,电机不分正负极,随便接 (2)图中3这里是控制板的电源输入正负极,可以输入5v和12v,我这里输入的是12v电源,使用的时候应该把…...

UofTCTF-2025-web-复现

感兴趣朋友可以去我博客里看&#xff0c;画风更好看 UofTCTF-2025-web-复现 文章目录 scavenger-huntprismatic-blogscode-dbprepared-1prepared-2timeless scavenger-hunt 国外的一些ctf简单题就喜欢把flag藏在注释里&#xff0c;开源代码找到第一部分的flag 抓个包返回数据…...

记录seatunnel排查重复数据的案例分析

文章目录 背景分析检查现象检查B集群是否有异常&#xff0c;导致重复消费的分析同步任务 修复问题发现flink job 一直报异常修复问题 背景 使用seatunnel 同步数据从A 集群kafka 同步到B集群kafka,现象是发现两边数据不一致&#xff0c;每天10w级别会多几十条数据 分析 检查…...

技术速递|Agent 模式:对所有用户开放,并支持 MCP

作者&#xff1a;Isidor Nikolic 翻译/排版&#xff1a;Alan Wang Agent 模式正在向所有 VS Code 用户推广&#xff01;它充当一个自主的配对编程助手&#xff0c;能够根据你的指令执行多步编码任务&#xff0c;例如分析代码库、提出文件修改建议以及运行终端命令。它能够响应编…...

实验四 Java图形界面与事件处理

实验四 Java图形界面与事件处理 ###实验目的 掌握Java语言中AWT和Swing组件的基本用法掌握Java语言中的事件处理方法掌握Java语言中事件源、监视器和处理事件的接口的概念 ###实验内容 图形用户界面设计程序(ArtFont.java)&#xff08;90分&#xff09; 要求&#xff1a;设…...

day2 python训练营

浙大疏锦行 python训练营介绍...

Linux下 REEF3D及DIVEMesh 源码编译安装及使用

目录 软件介绍 基本依赖 一、源码下载 1、REEF3D 2、DIVEMesh 二、解压缩 三、编译安装 1、REEF3D 2、DIVEMesh 四、算例测试 软件介绍 REEF3D是一款开源流体动力学框架&#xff0c;提供计算流体力学及波浪模型。软件采用高效并行化设计&#xff0c;可以在大规模处理器…...

堡垒机和跳板机之区别(The Difference between Fortress and Springboard Aircraft)

堡垒机和跳板机之区别 在网络安全、安全运维领域&#xff0c;堡垒机和跳板机是两个常被提及且功能相似的概念&#xff0c;但它们在实际应用、功能定位以及技术实现上存在着明显的差异。本文将对堡垒机和跳板机进行详细的解析与比较&#xff0c;帮助读者更好地理解这两种网络安…...

《Android 应用开发基础教程》——第五章:RecyclerView 列表视图与适配器机制

目录 第五章&#xff1a;RecyclerView 列表视图与适配器机制 5.1 为什么要使用 RecyclerView&#xff1f; 5.2 基本结构图 5.3 RecyclerView 使用步骤 1️⃣ 添加 RecyclerView 依赖&#xff08;Android Studio&#xff09; 2️⃣ 布局文件&#xff08;activity_main.xml&…...

【第四章】19-匹配规则定义

在优化Web服务器性能与增强其功能性的过程中,深入理解Nginx的location匹配规则显得尤为关键。它不仅决定了如何高效地路由不同类型的客户端请求,而且是实现精准响应的基础。通过掌握精确匹配、前缀匹配及正则表达式匹配等规则,管理员能够灵活配置以支持复杂的业务需求,同时…...

[PTA]2025CCCC-GPLT天梯赛 现代战争

来源&#xff1a;L1-112 现代战争-Pintia题意&#xff1a;给定 n m n\times m nm 的矩阵&#xff0c;进行 k k k 次操作&#xff0c;每次操作清除矩阵当前最大值所在行和所在列的全部元素&#xff0c;求最终矩阵。关键词&#xff1a;模拟(签到)题解&#xff1a;非常水的模拟…...

操作系统期中复习

未完待续----后续补充全书完整板 一、计算机系统概述 1.1操作系统的基本概念 1.1.1操作系统的概念 操作系统&#xff1a;是指控制和管理整个计算机系统的硬件与软件资源&#xff0c;合理地组织、调度计算机的工作与资源的分配&#xff0c;进而为用户和其他软件提供方便接口…...

Linux 入门十一:Linux 网络编程

一、概述 1. 网络编程基础 网络编程是通过网络应用编程接口&#xff08;API&#xff09;编写程序&#xff0c;实现不同主机上进程间的信息交互。它解决的核心问题是&#xff1a;如何让不同主机上的程序进行通信。 2. 网络模型&#xff1a;从 OSI 到 TCP/IP OSI 七层模型&…...

车载软件架构 --- 二级boot设计说明需求规范

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 周末洗了一个澡,换了一身衣服,出了门却不知道去哪儿,不知道去找谁,漫无目的走着,大概这就是成年人最深的孤独吧! 旧人不知我近况,新人不知我过…...

在Ubuntu下用Chrony做主从机时间同步

主机 下载chrony sudo apt install chrony修改配置文件&#xff1a; sudo gedit /etc/chrony/chrony.conf# Welcome to the chrony configuration file. See chrony.conf(5) for more # information about usuable directives.# This will use (up to): # - 4 sources fro…...

开箱即用:一款带世界时钟简约好用在线时间戳转换工具源码

这款工具简直是为“时间管理大师”和“国际化玩家”量身定制!它不仅支持全球十大热门语言,还能无缝切换多时区,帮你轻松搞定时间戳和日期的转换。重点是,它完全前端实现,无需复杂后端,部署起来比泡杯咖啡还简单!开发人员可以在本地电脑运行来进行时间戳装换,还可以加Ad…...

代码随想录第22天:回溯算法4

一、全排列&#xff08;Leetcode 46&#xff09; 与组合问题不同&#xff0c;排列问题要注意2个特点&#xff1a; 每层都是从0开始搜索而不是startIndex需要used数组记录path里都放了哪些元素 class Solution:def permute(self, nums):result [] # 存储所有的排列self.back…...