使用RAID与LVM磁盘阵列技术

 前言:本博客仅作记录学习使用,部分图片出自网络,如有侵犯您的权益,请联系删除 

目录

一、RAID磁盘冗余阵列

1、部署磁盘整列

2、损坏磁盘阵列及修复

3、磁盘阵列+备份盘

4、删除磁盘阵列

二、LVM逻辑卷管理器

致谢


一、RAID磁盘冗余阵列

硬盘设备是计算机中比较容易故障的元器件之一,加之由于其需要存储数据的特殊性质,不能像CPU、内存、电源甚至主板故障后更换新的就好,所以生产环境中一定要未雨绸缪,提前做好数据的冗余及异地备份等工作

1988年,美国加利福尼亚大学伯克利分校首次提出并定义了Redundant Array of Independent Disks技术的概念,中文名称是磁盘冗余阵列,简称RAID。RAID技术通过多个硬盘设备组合成一个容量更大、安全性更好的磁盘阵列,并把数据切割成多个区段后分别存放在各个不同的物理硬盘设备上,然后利分散读写技术来提升磁盘阵列整体的性能,同时把多个重要的数据的副本同步到不同的物理邮硬盘设备上,从而起到数据冗余备份效果

目前已有的RAID磁盘阵列的方案至少有十几种,RAID 0,RAID 1,RAID 5与RAID 10这4种最常见的方案

RAID级别最少硬盘可用容量读写性能安全性特点
02nn追求最大容量和速度,任何一块盘损坏,数据全部异常
12n/2n追求最大安全性,只要阵列组中有一块硬盘可用,数据不受影响
53n-1n-1在控制成本的前提下,追求硬盘的最大容量、速度及安全性,允许有一块硬盘异常,数据不受影响
104n/2n/2综合RAID 1和RAID 0的优点,追求硬盘的速度和安全性,允许有一半硬盘异常(不可同组),数据不受影响

1、RAID 0

RAID 0技术把多块物理设备(至少两块)通过硬件或软件的方式串联在一起,组成一个大的卷组,并将数据依此写入到各个物理硬盘中。通俗来说,RAID 0技术能有效的提升硬盘数据的吞吐速度,但是不具备数据备份和错误修复能力。

数据被分别写入到不同的硬盘设备中,即硬盘A和硬盘B设备分别保存数据资料,最终实现提升读取、写入速度的效果

2、RAID 1

RAID 1技术把两块以上的硬盘设备进行绑定,在写入数据时,是将数据同时写入到多块硬盘设备上(可以将其视为数据的镜像或备份)。当其中的一块硬盘发生故障后,一般会立即自动以热交换的方式来恢复数据的正常使用

因为在多块硬盘设备中写入了相同的数据,因此硬盘设备的利用率下降,理论上说硬盘空间真实利用率只有50%,由三块硬盘设备组成的RAID 1磁盘阵列的可用率只有33%。无疑增大了系统计算功能的负载

3、RAID 5

RAID 5技术是把硬盘设备的数据奇偶校验信息保存到其他硬盘设备中。RAID 5磁盘阵列中数据的奇偶校验信息并不是单独保存到某一块硬盘设备中,而是存储到除自身以外的其他每一块硬盘设备上;图中parity部分存放的就是数据的奇偶校验信息,换句话说,就是RAID 5技术实际上没有备份硬盘中的真实数据信息,而是当硬盘设备出现问题后通过奇偶校验信息来尝试重建损坏的数据

RAID 5最少由三块硬盘组成,使用的是Disk Striping硬盘切割技术。比RAID 1级别好处在于保存的是奇偶校验信息而不是一模一样的内容,所以当重复写入某个文件时,RAID 5级别磁盘阵列只需要对应一个奇偶校验信息就可以,效率更高,存储成本也降低。

4、RAID 10

鉴于RAID 5对各方面有了妥协,但是大部分企业更在乎的是数据本身的价值而非硬盘价格,因此生产环境中主要使用RAID 10技术

RAID 10就是RAID 1+RAID 0技术的一个“组合体”。RAID 10技术至少需要4块硬盘来组建,其中分别两两制作成RAID 1磁盘阵列,以保证数据的安全性;然后再对两个RAID 1磁盘阵列实施RAID 0技术,进一步提高硬盘设备的读写速度。

1、部署磁盘整列

首先在虚拟机中添加4块硬盘设备来制作一个RAID 10磁盘阵列,SCSI或SATA接口类型

这些硬盘是模拟出来的,当前生产环境中用到的服务器一般都配备RAID阵列卡,我们学习阶段没必要单独去购买一台服务器,而是学会用mdadm命令在Linux系统中创建和管理软件RAID磁盘阵列。

1.1、mdadm命令

mdadm命令用于创建、调整、监控和管理RAID设备,语法:"mdadm 参数 硬盘名称"

参数作用
-a检测设备名称
-n指定设备数量
-l指定RAID级别
-C创建
-v显示过程
-f模拟设备损坏
-r移除设备
-Q查看摘要信息
-D查看详细信息
-S停止RAID磁盘阵列

接下来,使用mdadm命令创建RAID 10,名称为"/dev/md0"

前面讲过,udev是Linux系统内核中用来给硬件命名的服务,其命名规则也非常简单。可以猜测到第二个SCSI存储设备的名称会是/dev/sdb,以此类推。mdadm命令中的参数-C代表创建一个RAID阵列卡-v参数显示创建的过程,同时在后面追加一个设备名称/dev/md0,这样/dev/mdo就是创建后的RAID磁盘阵列的名称;-n 4参数代表使用4块硬盘来部署这个RAID磁盘阵列;而-l 10参数则代表RAID 10方案;最后再加上4块硬盘设备的名称就OK了

 [root@linuxprobe ~]# mdadm -Cv /dev/md0 -n 4 -l 10 /dev/sdb /dev/sdc /dev/sdd /dev/sdemdadm: layout defaults to n2mdadm: layout defaults to n2mdadm: chunk size defaults to 512Kmdadm: size set to 20954112Kmdadm: Defaulting to version 1.2 metadatamdadm: array /dev/md0 started.

初始化过程使用-D参数进行查看,也可以用-Q参数查看简要信息

 [root@linuxprobe ~]# mdadm -Q /dev/md0/dev/md0: 39.97GiB radi10 4 devices, 0 spares. Use mdadm --detail for more detail.

四块20G大小的硬盘组成的磁盘阵列可用空间只有39.97了,RAID 10技术通过两两一组硬盘组成的RAID 1保证了数据的可靠性,每一份数据都被保存两次,50%的使用率

把制作好的RAID磁盘阵列格式化为ext4格式

 [root@linuxprobe ~]# mkfs.ext4 /dev/md0...

创建挂载点后把硬盘设备进行挂载操作:

 [root@linuxprobe ~]# mkdir /RAID[root@linuxprobe ~]# mount /dev/md0 /RAID[root@linuxprobe ~]# df -h.../dev/md0            40G     49M     38M     1%      /RAID

查看/dev/md0磁盘阵列组设备的详细信息,确认下RAID级别(Raid Level)、大小(Array Size)和总硬盘数(Total Devices)是否正确;

 [root@linuxprobe ~]# mdadm -D /dev/md0/dev/md0:...

最后想让创建好的RAID磁盘阵列能够一直为我们服务,不会因每次的重启操作而取消,记得将信息添加到/etc/fstab文件中:

 [root@linuxprobe ~]# echo "/dev/md0 /RAID ext4 defaults 0 0" >> /etc/fstab[root@linuxprobe ~]# cat /etc/fstab.../dev/md0                /RAID       ext4        defaults        0   0

2、损坏磁盘阵列及修复

首先确认有一块物理硬盘设备出现损坏后不能再继续正常使用后,使用mdadm命令来予以移除之后查看下RAID磁盘阵列组的状态已经被改变

 [root@linuxprobe ~]# mdadm /dev/md0 -f /dev/sdbmdadm: set /dev/sdb faulty in /dev/md0[root@linuxprobe ~]# mdadm -D /dev/md0/dev/md0:...0       8       16      -       faulty      /dev/sdb

使用-f参数是让硬盘模拟损坏,为了能够彻底的将故障盘移除,还要再一步操作:

 [root@linuxprobe ~]# mdadm /dev/md0 -r /dev/sdbmdadm: hot removed /dev/sdb from /dev/md0

当RAID 1磁盘阵列中存在一个故障盘时并不影响RAID 10磁盘阵列的使用。更换硬盘后使用-a参数进行添加操作,默认会自动开始数据的同步工作,使用-D参数即可看到整个过程和百分比进度:

 [root@linuxprobe ~]# mdadm /dev/md0 -a /dev/sdbmdadm: added /dev/sdb[root@linuxprobe ~]# mdadm -D /dev/md0/dev/md0:...

3、磁盘阵列+备份盘

RAID 10磁盘阵列中最多允许50%的硬盘设备发生故障,但存在一个极端情况,即同一RAID 1磁盘阵列中的硬盘设备若全部损坏,也会导致数据丢失。怎么办呢,可以使用RAID备份盘技术来预防。该技术的核心理念就是准备一块足够大的硬盘,这块硬盘平时处于闲置状态一旦RAID磁盘阵列中有硬盘出现故障后则会马上顶替上去

示例:恢复虚拟机初始状态,现在看一下RAID 5的部署效果。部署RAID 5磁盘阵列时,至少需要用到3块硬盘,还需再加一块备份硬盘(也叫热备盘),所以总计需要在虚拟机中模拟4块硬盘设备:

现在创建一个RAID 5磁盘阵列+备份盘。

 # 参数-n 3代表创建这个RAID 5磁盘阵列所需的硬盘数# 参数-l 5代表RAID的级别# 参数-x 1则代表有一块备份盘[root@linuxprobe ~]# mdadm -Cv /dev/md0 -n 3 -l 5 -x 1 /dev/sdb /dev/sdc /dev/sdd /dev/sdemdadm: layout defaults to left-symmetricmdadm: layout defaults to left-symmetric...[root@linuxprobe ~]# mdadm -D /dev/md0...3   8   64  -   spare   /dev/sde

现将部署好的RAID 5磁盘阵列格式化为ext4文件格式,然后挂载到目录上,之后就使用了:

 [root@linuxprobe ~]# mkfs.ext4 /dev/md0...[root@linuxprobe ~]# mkdir /RAID[root@linuxprobe ~]# echo "/dev/md0 /RAID ext4 defaults 0 0" >> /etc/fstab  

由三块硬盘组成的RAID 5级别磁盘阵列,它对应的可用空间是n-1,也就是40G。热备盘的空间是不算入内的,平时完全就是在“睡觉”中,只有意外出现时才开始工作

 [root@linuxprobe ~]# mount -a[root@linuxprobe ~]# df -h.../dev/md0        40G     49M     38G     1%  /RAID

实验:我们把硬盘设备/dev/sdb溢出磁盘阵列,然后迅速查看/dev/md0磁盘阵列的状态,就会发现备份盘已经自动顶替上去并开始了数据同步。RAID中这种备份盘技术非常实用,可以在保证RAID磁盘阵列数据安全性的基础上进一步提高数据可靠性;

 [root@linuxprobe ~]# mdadm /dev/md0 -f /dev/sdbmdadm: set /dev/sdb faulty in /dev/md0[root@linuxprobe ~]# mdadm -D /dev/md0/dev/md0:...0       8       16      -       faulty      /dev/sdb

4、删除磁盘阵列

生产环境中,RAID磁盘阵列组部署后一般不会轻易被停用了,万一赶上了,还是需要知道怎么删除的。上面这种RAID 5+热备盘损坏的情况是比较复杂的,就以这种情况讲解:

首先需要将所有的磁盘都设置成停用状态:

 [root@linuxprobe ~]# umount /RAID[root@linuxprobe ~]# mdadm /dev/md0 -f /dev/sdcmdadm: set /dev/sdc faulty in /dev/md0[root@linuxprobe ~]# mdadm /dev/md0 -f /dev/sddmdadm: set /dev/sdd faulty in /dev/md0[root@linuxprobe ~]# mdadm /dev/md0 -f /dev/sdemdadm: set /dev/sde faulty in /dev/md0

然后再逐一的移除出去:

[root@linuxprobe ~]# mdadm /dev/md0 -r /dev/sdb
mdadm: hot removed /dev/sdb from /dev/md0
[root@linuxprobe ~]# mdadm /dev/md0 -r /dev/sdc
mdadm: hot removed /dev/sdc from /dev/md0
[root@linuxprobe ~]# mdadm /dev/md0 -r /dev/sdd
mdadm: hot removed /dev/sdd from /dev/md0
[root@linuxprobe ~]# mdadm /dev/md0 -r /dev/sde
mdadm: hot removed /dev/sde from /dev/md0

着急的同学也可以用"mdadm /dev/md0 -f /dev/sdb -r /dev/sdb" 一条命令搞定。但由于这个命令在早期版本不能一起使用,保险还是一步一步执行。移除后查看磁盘阵列状态:

[root@linuxprobe ~]# mdadm -D /dev/md0
/dev/md0:...-		0 		0		0		removed-		0 		0		1		removed-		0 		0		2		removed

继续再停用整个RAID磁盘组:

[root@linuxprobe ~]# mdadm --stop /dev/md0
mdadm: stopped /dev/md0
[root@linuxprobe ~]# ls /dev/md0
ls: cannot access '/dev/md0': No Such file or directory

二、LVM逻辑卷管理器

前面的硬盘管理技术虽然能够有效地提高硬盘设备的读写速度以及数据的安全性,但是在硬盘分区好或者部署为RAID磁盘阵列后,再想修改硬盘分区大小就不容易了。这时需要另外一项非常普及的硬盘设备资源管理技术了—Ligical Volume Manager(逻辑卷管理器,简称LVM)。LVM允许用户对硬盘资源进行动态调整

逻辑卷管理器是Linux系统用于对硬盘分区进行管理的一种机制,理论性较强。LVM技术是在硬盘分区和文件系统之间添加了一个逻辑层,它提供了一个抽象的卷组,可以把多块硬盘进行卷组合并。这样一来,用户不必关心物理硬盘设备的底层架构和布局,就可以实现对硬盘分区的动态调整。LVM技术架构如下:

物理卷处于LVM中的最底层,可以将其理解为物理硬盘、硬盘分区或者RAID磁盘阵列。卷组建立在物理卷之上,一个卷组能够包含多个物理卷,而且在卷组创建之后也可以继续向其中添加新的物理卷。逻辑卷是用卷组中空闲的资源建立的,并且逻辑卷在建立以后可以动态地扩展或缩小空间。这就是LVM的核心理念。

1、部署逻辑卷

原先分配的硬盘分区不够用。通过部署LVM来解决。部署时需要逐个配置物理卷、卷组和逻辑卷,常用的部署命令如下:

功能/命令物理卷管理卷组管理逻辑卷管理
扫描pvscanvgscanlvscan
建立pvcreatevgcreatelvcreate
显示pvdisplayvgdisplaylvdisplay
删除pvremovevgremovelvremove
扩展vgextendlvextend
缩小vgreducelvreduce

示例:还原虚拟机,并重新添加两块新硬盘设备(更好的演示LVM理念中用户无需关心底层物理硬盘设备的特性)

第1步:让新添加的两块硬盘设备支持LVM技术:

 [root@linuxprobe ~]# pvcreate /dev/sdb /dev/sdcPhysical volume "dev/sdb" successfully created.Physical volume "dev/sdc" successfully created.

第2步:把两块硬盘设备加入到storage卷组中,然后查看卷组的状态:

 [root@linuxprobe ~]# vgcreate storage /dev/sdb /dev/sdcVolume group "storage" successfully created.[root@linuxprobe ~]# vgdisplay--- Volume group ---...Free PE / Size  10238 / 39.99 GiB

第3步:再切割出一个约为150MB的逻辑卷设备。

这里需要注意切割单位的问题。在对逻辑卷进行切割时有两种计量单位。第一种是容量为单位,所使用参数为-L:使用-L 150M生成一个大小为150MB的逻辑卷。另外一种是以基本单元的个数为单位,所使用参数为-l,每个基本单元的大小默认是4MB:使用-l 37可以生成一个大小为37*4MB = 148MB的逻辑卷。

 [root@linuxprobe ~]# lvcreate -n vo -l 37 storageLogical volume "vo" created.[root@linuxprobe ~]# lvdisplay--- Logical volume ---...LV Size             148.00 MiB

第4步,把生成好的逻辑卷进行格式化,然后挂载使用:

Linux系统会把LVM中的逻辑卷设备存放在/dev设备目录中,实际上就是个快捷方式,同时会以卷名的名称来建立一个目录,其中保存了逻辑卷的设备映射文件,即/dev/卷组名称/逻辑卷名称

 [root@linuxprobe ~]# mkfs.ext4 /dev/storage/vomke2fs 1.44.3 (10-July-2018)...[root@linuxprobe ~]# mkdir  /linuxprobe[root@linuxprobe ~]# mount /dev/storage/vo /linuxprobe

第5步:查看挂载状态,并写入到配置文件,使其永久生效

 [root@linuxprobe ~]# df -h.../dev/mapper/storage-vo      140M 1.6M 128M 2% /linuxprobe[root@linuxprobe ~]# echo "/dev/storage/vo /linuxprobe ext4 defaults 0 0" >> /etc/fstab[root@linuxprobe ~]# cat /etc/fstab.../dev/storage/vo /linuxprobe ext4 defaults 0 0

2、扩容逻辑卷

前面实验中,卷组是由两块硬盘设备共同组成的,用户在使用存储设备时感知不到设备底层的架构和布局,只要卷中有足够的资源,就可以一直为逻辑卷扩容。扩展前请一定要记得卸载设备和挂载点的关联

[root@linuxprobe ~]# umount /linuxprobe

第1步:把上一个实验中的逻辑卷vo扩展至290M

[root@linuxprobe ~]# lvextend -L 290M /dev/storage/vo
Rounding size to boundary between physical extents: 290.00 MiB
...

第2步:检查硬盘的完整性,确认目录结构、内容和文件内容没有丢失,没有报错均为正常

[root@linuxprobe ~]# e2fsck -f /dev/storage/vo
e2fsck 1.44.3 (10-July-2018)
...
/dev/storage/vo: 11/38000 files (0.0% non-contiguous),

第3步:重置设备在系统中的容量,刚刚是对LV逻辑卷设备进行了扩容操作,但系统内核还没有同步到这部分新修改的信息,手动同步:

[root@linuxprobe ~]# resize2fs /dev/storage/vo

第4步:重新挂载硬盘设备并查看挂载状态

[root@linuxprobe ~]# mount -a
[root@linuxprobe ~]# df -h
...
/dev/mapper/storage-vo  279M 2.1M 259M 1% /linuxprobe

3、缩小逻辑卷

相比较与扩容,缩容风险更大,所以在执行前一定要提前备份好数据。另外Linux系统规定,在对LVM逻辑卷进行缩容操作前,要先检查文件系统的完整性。在执行缩容操作前记得把文件系统卸载掉:

[root@linuxprobe ~]# umount /linuxprobe

第1步:检查文件系统的完整性

 [root@linuxprobe ~]# e2fsck -f /dev/storage/vo

第2步:通知系统内核将逻辑卷vo的容量减小到120M

 [root@linuxprobe ~]# resize2fs /dev/storage/vo 120M

第3步:将LV逻辑卷的容量修改为120M

 [root@linuxprobe ~]# lvreduce -L 120M /dev/storage/vo

发现,步骤与扩容相反

第4步:重新挂载文件系统并查看系统状态

 [root@linuxprobe ~]# mount -1[root@linuxprobe ~]# df -h.../dev/mapper/storage-vo 113M 1.6M 103M   2% /Linuxprobe

4、逻辑卷快照

LVM还具有"快照卷"功能,该功能类似于虚拟机软件的还原时间点功能。特点:

  • 快照卷的容量必须等同于逻辑卷的容量
  • 快照卷仅一次有效,一旦执行还原操作后则会被立即自动删除

在操作前,先看看VG卷组中的容量是否够用:

 [root@linuxprobe ~]# vgdisplay...Free PE / Size      10208 / <39.88 GiB

通过卷组的输出信息可以看到,卷组中已经使用了120MB的容量,空闲容量还有39.88GB。接下来用重定向逻辑卷设备所挂载的目录中写入一个文件:

 [root@linuxprobe ~]# echo "Welcome to Linuxprobe.com" > /linuxprobe/readme.txt[root@linuxprobe ~]# ls -l /linuxprobe

第1步:使用-s参数生成一个快照卷,使用-L参数指定切割的大小,需要与要做快照的设备容量保持一致。另外还需要在命令后面写上是针对哪个逻辑卷执行的快照操作,稍后数据也会还原到这个对应的设备上:

[root@linuxprobe ~]# lvcreate -L 120M -s -n SNAP /dev/storage/vo
Logical volume "SNAP" created
[root@linuxprobe ~]# lvdisplay
...
LV Path						/dev/storage/SNAP
LV snapshot status          active destination for vo
LV Size						120.00 MiB

第2步:在逻辑卷所挂载的目录中创建一个100MB的垃圾文件,然后再查看快照卷的状态。发现存储空间占的用量上升了

[root@linuxprobe ~]# dd if =/dev/zero of=/linuxprobe/files  count=1 bs=100M
1+0 records in
...
[root@linuxprobe ~]# lvdisplay
...
Allocated to snapshot				83.71%

第3步:为了检验SNAP快照卷的效果,需要对逻辑卷进行快照还原操作。在此之前记得先卸载掉逻辑卷设备与目录的挂载

lvconvert命令用于管理逻辑卷的快照,语法:“lvconvert [参数] 快照卷名称”

使用lvconvert能够将逻辑卷的快照进行自动恢复,使用 “--merge”参数进行操作,系统会自动分辨设备的类型:

 [root@linuxprobe ~]# umount /linuxprobe[root@linuxprobe ~]# lvconvert --merge /dev/storgae/SNAP

第4步:快照卷会被自动删除掉,并且刚刚在逻辑卷设备呗执行快照操作后再创建出来的100MB的垃圾文件也被清除了

 [root@linuxprobe ~]# mount -a[root@linuxprobe ~]# cd /linuxprobe[root@linuxprobe linuxprobe]# lslost+found readme.txt[root@linuxprobe linuxprobe]# cat readme.txtWelcome to Linuxprobe.com

5、删除逻辑卷

当生产环境中想要重新部署LVM或者不再需要使用时,则需要执行LVM的删除操作;为此,需要提前备份好重要的数据信息,然后依次删除逻辑卷、卷组、物理卷设备,这个顺序不可颠倒!!

第1步:取消逻辑卷与目录的挂载关联,删除配置文件中永久生效的设备参数:

 [root@linuxprobe ~]# umount /linuxprobe[root@linuxprobe ~]# vim /etc/fstab.../dev/storage/vo             /linuxprobe     ext4    defaults    0 0(删除掉这行)

第2步:删除逻辑卷设备,需要输入y来确认操作:

 [root@linuxprobe ~]# lvremove /dev/storage/voDo you really want to remove active logical volume storage/vo? [y/n]: yLogical volume "vo" successfully removed

第3步:删除卷组,此处只写卷组名即可,不需要设备的绝对路径。

 [root@linuxprobe ~]# vgremove storgaeVolume group "storage" successfully removed

第4步:删除物理卷设备:

 [root@linuxprobe ~]# pvremove /dev/sdb /dev/sdcLabels on Physical volume "/dev/sdb" successfully wiped.Labels on Physical volume "/dev/sdc" successfully wiped.

上述操作执行完毕后,再执行display、vgdisplay、pvdisplay命令来查看LVM的信息时就不会再看到信息了。

致谢

在此,我要对所有为知识共享做出贡献的个人和机构表示最深切的感谢。同时也感谢每一位花时间阅读这篇文章的读者,如果文章中有任何错误,欢迎留言指正。 

学习永无止境,让我们共同进步!!

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

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

相关文章

使用 PCA 可视化数据的分类能力

使用 PCA 探索数据分类的效果&#xff08;使用 Python 代码&#xff09; 「AI秘籍」系列课程&#xff1a; 人工智能应用数学基础人工智能Python基础人工智能基础核心知识人工智能BI核心知识人工智能CV核心知识 主成分分析 (PCA) 是数据科学家使用的绝佳工具。它可用于降低特征…

【QT】容器类控件

目录 概述 Group Box 核心属性 Tab Widget 核心属性 核心信号 核心方法 使用示例&#xff1a; 布局管理器 垂直布局 核心属性 使用示例&#xff1a; 水平布局 核⼼属性 (和 QVBoxLayout 属性是⼀致的) 网格布局 核心属性 使用示例&#xff1a; 示例&#x…

2024亚太杯中文赛数学建模B题word+PDF+代码

2024年第十四届亚太地区大学生数学建模竞赛&#xff08;中文赛项&#xff09;B题洪水灾害的数据分析与预测&#xff1a;建立指标相关性与多重共线性分析模型、洪水风险分层与预警评价模型、洪水发生概率的非线性预测优化模型&#xff0c;以及大规模样本预测与分布特征分析模型 …

python操作SQLite3数据库进行增删改查

python操作SQLite3数据库进行增删改查 1、创建SQLite3数据库 可以通过Navicat图形化软件来创建: 2、创建表 利用Navicat图形化软件来创建: 存储在 SQLite 数据库中的每个值(或是由数据库引擎所操作的值)都有一个以下的存储类型: NULL. 值是空值。 INTEGER. 值是有符…

Python 算法交易实验76 QTV200日常推进

说明 最近实在太忙&#xff0c; 没太有空推进这个项目&#xff0c;我想还是尽量抽一点点时间推进具体的工程&#xff0c;然后更多的还是用碎片化的时间从整体上对qtv200进行设计完善。有些结构的问题其实是需要理清的&#xff0c;例如&#xff1a; 1 要先基于原始数据进行描述…

浪潮信息元脑服务器支持英特尔®至强®6能效核处理器 展现强劲性能

如今&#xff0c;服务器作为数字经济的核心基础设施&#xff0c;正面临着前所未有的挑战和机遇。作为服务器领域的领军企业&#xff0c;浪潮信息始终站在行业前沿&#xff0c;不断推陈出新&#xff0c;以满足客户日益增长的需求。近日&#xff0c;浪潮信息再次展现技术实力&…

基于GWO-CNN-BiLSTM数据回归预测(多输入单输出)-灰狼优化算法优化CNN-BiLSTM

基于GWO-CNN-BiLSTM数据回归预测(多输入单输出)-灰狼优化算法优化CNN-BiLSTM 1.数据均为Excel数据&#xff0c;直接替换数据就可以运行程序。 2.所有程序都经过验证&#xff0c;保证程序可以运行。 3.具有良好的编程习惯&#xff0c;程序均包含简要注释。 获取方式 https:/…

筛选Github上的一些优质项目

每个项目旁都有标签说明其特点&#xff0c;如今日热捧、多模态、收入生成、机器人、大型语言模型等。 项目涵盖了不同的编程语言和领域&#xff0c;包括人工智能、语言模型、网页数据采集、聊天机器人、语音合成、AI 代理工具集、语音转录、大型语言模型、DevOps、本地文件共享…

Matplotlib 学习

知识点 1.plot()&#xff1a;用于绘制线图和 散点图scatter() 函数&#xff1a;plot() 函数可以接受许多可选参数&#xff0c;用于控制图形的外观&#xff0c;例如&#xff1a;颜色: colorblue 控制线条的颜色。线型: linestyle-- 控制线条的样式&#xff0c;例如虚线。标记…

YoloV8改进策略:Block改进|轻量实时的重参数结构|最新改进|即插即用(全网首发)

摘要 本文使用重参数的Block替换YoloV8中的Bottleneck&#xff0c;GFLOPs从165降到了116&#xff0c;降低了三分之一&#xff1b;同时&#xff0c;map50-95从0.937涨到了0.947。 改进方法简单&#xff0c;只做简单的替换就行&#xff0c;即插即用&#xff0c;非常推荐&#xf…

C++_STL---list

list的相关介绍 list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代。 list的底层是带头双向循环链表结构&#xff0c;链表中每个元素存储在互不相关的独立节点中&#xff0c;在节点中通过指针指向其前一个元素和后一个元素。…

IDEA与通义灵码的智能编程之旅

1 概述 本文主要介绍在IDEA中如何安装和使用通义灵码来助力软件编程,从而提高编程效率,创造更大的个人同企业价值。 2 安装通义灵码 2.1 打开IDEA插件市场 点击IDEA的设置按钮,下拉选择Plugins,如下: 2.2 搜索通义灵码 在搜索框中输入“通义灵码”,如下: 2.3 安…

使用ifconfig命令获取当前服务器的内网IP地址

如何使用ifconfig命令获取当前服务器的内网IP地址呢&#xff1f; ifconfig eth0 | grep inet | awk {print $2}

什么是五级流水?银行眼中的“好流水”,到底是什么样的?

无论是按揭买房还是日常贷款&#xff0c;银行流水都是绕不开的一环。规划好你的流水&#xff0c;不仅能让你在申请贷款时更有底气&#xff0c;还可能帮你省下不少冤枉钱。今天&#xff0c;咱们就来一场深度剖析&#xff0c;聊聊如何在按揭贷款、个人经营抵押贷款前&#xff0c;…

代码随想录 数组部分+代码可在本地编译器运行

代码随想录 数组部分&#xff0c;代码可在本地编译器运行 文章目录 数组理论基础704.二分查找题目&#xff1a;思路二分法第一种写法二分法第二种写法 代码 27.移除元素题目&#xff1a;思路-双指针法代码 977.有序数组的平方题目思路-双指针代码 209.长度最小的子数组题目&am…

ChatGPT4深度解析:探索智能对话新境界

大模型chatgpt4分析功能初探 目录 1、探测目的 2、目标变量分析 3、特征缺失率处理 4、特征描述性分析 5、异常值分析 6、相关性分析 7、高阶特征挖掘 1、探测目的 1、分析chat4的数据分析能力&#xff0c;提高部门人效 2、给数据挖掘提供思路 3、原始数据&#xf…

科研绘图系列:R语言径向柱状图(Radial Bar Chart)

介绍 径向柱状图(Radial Bar Chart),又称为雷达图或蜘蛛网图(Spider Chart),是一种在极坐标系中绘制的柱状图。这种图表的特点是将数据点沿着一个或多个从中心向外延伸的轴来展示,这些轴通常围绕着一个中心点均匀分布。 特点: 极坐标系统:数据点不是在直角坐标系中展…

【后端面试题】【中间件】【NoSQL】MongoDB查询优化3(拆分、嵌入文档,操作系统)

拆分大文档 很常见的一种优化手段&#xff0c;在一些特定的业务场景中&#xff0c;会有一些很大的文档&#xff0c;这些文档有很多字段&#xff0c;而且有一些特定的字段还特别的大。可以考虑拆分这些文档 大文档对MongoDB的性能影响还是很大的&#xff0c;就我个人经验而言&…

ASCII码对照表【2024年汇总】

&#x1f37a;ASCII相关文章汇总如下&#x1f37a;&#xff1a; &#x1f388;ASCII码对照表&#xff08;255个ascii字符汇总&#xff09;&#x1f388;&#x1f388;ASCII码对照表&#xff08;Unicode 字符集列表&#xff09;&#x1f388;&#x1f388;ASCII码对照表&#x…

Day05-04-持续集成总结

Day05-04-持续集成总结 1. 持续集成2. 代码上线目标项目 1. 持续集成 git 基本使用, 拉取代码,上传代码,分支操作,tag标签 gitlab 用户 用户组 项目 , 备份,https,优化. jenkins 工具平台,运维核心, 自由风格工程,maven风格项目,流水线项目, 流水线(pipeline) mavenpom.xmlta…