使用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.xdnf.cn/news/1474622.html

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

相关文章

1958.力扣每日一题7/7 Java(100%解)

博客主页&#xff1a;音符犹如代码系列专栏&#xff1a;算法练习关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 目录 思路 解题方法 时间复杂度 空间复杂度 Code 思路 首先将指定位…

反编译kasada

继续研究反编译 这次的网站是 一个航司网站 他有 akamai和 kasada 两种防护 akamai 没啥好说的 结构分析 最开始有个长字符串 处理成 一个十几万的数组 通过 r.W[0] 走什么分支 还有数据的存取 M是一个98个函数组成的数组 代表不同的执行逻辑 这里给他转成了 switch case…

Python3极简教程(一小时学完)中

异常 在这个实验我们学习 Python 的异常以及如何在你的代码中处理它们。 知识点 NameErrorTypeError异常处理&#xff08;try..except&#xff09;异常抛出&#xff08;raise&#xff09;finally 子句 异常 在程序执行过程中发生的任何错误都是异常。每个异常显示一些相关…

【持续集成_03课_Jenkins生成Allure报告及Sonar静态扫描】

1、 一、构建之后的配置 1、安装allure插件 安装好之后&#xff0c;可以在这里搜到已经安装的 2、配置allure的allure-commandline 正常配置&#xff0c;是要么在工具里配置&#xff0c;要么在系统里配置 allure-commandline是在工具里进行配置 两种方式进行配置 1&#xff…

动手RAG: ocr调研

对于rag应用来说&#xff0c;文档是第一步&#xff0c;对于部分扫描件的文件来讲&#xff0c;主要就需要OCR. OCR tesseractppocrmmocr 还有诸如 chineseocr_litedarknet-ocrhttps://blog.csdn.net/CHYabc123456hh/article/details/107846268easyocr OCR包含几类&#x…

【Unity小技巧】Unity字典序列化

字典序列化 在 Unity 中&#xff0c;标准的 C# 字典&#xff08;Dictionary<TKey, TValue>&#xff09;是不能直接序列化的&#xff0c;因为 Unity 的序列化系统不支持非 Unity 序列化的集合类型。可以通过手写字典实现 效果&#xff1a; 实现步骤&#xff1a; 继承ISe…

基于AOP的数据字典实现:实现前端下拉框的可配置更新

作者&#xff1a;后端小肥肠 创作不易&#xff0c;未经允许严禁转载。 目录 1. 前言 2. 数据字典 2.1. 数据字典简介 2.2. 数据字典如何管理各模块的下拉框 3. 数据字典核心内容解读 3.1. 表结构 3.2. 核心代码 3.2.1. 根据实体类名称获取下属数据字典 3.2.2. 数据字…

HackTheBox----Editorial

Editorial 测试过程 1 信息收集 NMAP端口扫描 nmap -sC -sV 10.10.11.20服务器开启了 22、80 端口 80 端口测试 服务器只开启了 22 和 80 端口&#xff0c;先从 80 端口开始进行测试 echo "10.10.11.20 editorial.htb" | sudo tee -a /etc/hostspublish with us…

电源纹波相关

什么是纹波&#xff1f;什么是噪声&#xff1f; 这种叠加在直流稳定量上的交流分量就称为纹波。 纹波的危害 电源纹波能影响设备性能和稳定性 纹波会导致电器上产生谐波&#xff0c;降低电源的使用效率&#xff1b; 高频电源纹波可能会产生浪涌电压或电流&#xff0c;影响设…

WAWA鱼曲折的大学四年回忆录

声明&#xff1a;本文内容纯属个人主观臆断&#xff0c;如与事实不符&#xff0c;请参考事实 前言&#xff1a; 早想写一下大学四年的总结了&#xff0c;但总是感觉无从下手&#xff0c;不知道从哪里开始写&#xff0c;通过这篇文章主要想做一个记录&#xff0c;并从现在的认…

thingsboard v3.7 win编译相关问题记录

遇到的问题总结 node\yarn 相关版本问题 3.7 开始需要 JDK17 ui-ngx 模块 yarn 相关问题报错 报错信息 [INFO] Downloading https://github.com/yarnpkg/yarn/releases/download/v1.22.10/yarn-v1.22.10.tar.gz to D:\soft\maven\com\github\eirslett\yarn\1.22.10\yarn-1.2…

STM32基础篇:GPIO

GPIO简介 GPIO&#xff1a;即General Purpose Input/Output&#xff0c;通用目的输入/输出。就是一种片上外设&#xff08;内部模块&#xff09;。 对于STM32的芯片来说&#xff0c;周围有一圈引脚&#xff0c;有时需要对引脚进行读写&#xff08;读&#xff1a;从外部输入一…

SLF4J的介绍与使用(有logback和log4j2的具体实现案例)

目录 1.日志门面的介绍 常见的日志门面 &#xff1a; 常见的日志实现&#xff1a; 日志门面和日志实现的关系&#xff1a; 2.SLF4J 的介绍 业务场景&#xff08;问题&#xff09;&#xff1a; SLF4J的作用 SLF4J 的基本介绍 日志框架的绑定&#xff08;重点&#xff09…

线程安全的原因及解决方法

什么是线程安全问题 线程安全问题指的是在多线程编程环境中&#xff0c;由于多个线程共享数据或资源&#xff0c;并且这些线程对共享数据或资源的访问和操作没有正确地同步&#xff0c;导致数据的不一致、脏读、不可重复读、幻读等问题。线程安全问题的出现&#xff0c;通常是…

Mac 系统如何将搜狗输入法设置为默认输入法

Mac 系统默认将自带的ABC输入法作为默认输入法&#xff0c;很不方便中文输入&#xff0c;想设置搜狗输入法为默认输入法如何设置呢&#xff1f;具体步骤如下&#xff1a; 1、打开&#xff1a;系统设置——键盘——文字输入&#xff0c;点击设置 2、点击左下角的 3、选择 其他…

数学系C++(六七)

目录 * &指针与地址 void指针 指针可以等于&#xff1a; const 指向常量的指针 const int *px 常指针 int * const px 指向常量的常指针const 类型标识符 * const 指针名 指针加减&#xff1a; 指针恒等式 函数指针【待续】 指针型函数&#xff1a; 指向函数的…

52-5 内网代理2 - LCX端口转发(不推荐使用LCX)

环境搭建: 本地开3台虚拟机:kali(必须)、windows2012与2008 (可换成其他windows虚拟机) kali - 网络配置成桥接模式 windows2012 - 设置两个网卡,NAT与桥接模式 注意:windows2012要关闭防火墙,要不然其他主机ping不通 关闭防火墙后再开启远程桌面连接 windwos20…

拉曼光谱入门:3.拉曼光谱的特征参数与定量定性分析策略

1.特征参数 1.1 退偏振率 退偏振率&#xff08;p&#xff09;是一个衡量拉曼散射光偏振状态的参数&#xff0c;它描述了拉曼散射光的偏振方向与入射光偏振方向之间的关系。退偏振率定义为垂直偏振方向的拉曼散射强度与平行偏振方向的拉曼散射强度之比。退偏振率&#xff08;p&…

Hi6602 恒压恒流SSR电源方案

Hi6602是一款针对离线式反激电源设计的高性能PWM控制器。Hi6602内集成有通用的原边恒流控制技术&#xff0c;可支持断续模式和连续模式工作&#xff0c;适用于恒流输出的隔离型电源应用中。Hi6602内部具有高精度65kHz开关频率振荡器&#xff0c;且带有抖频功能可优化EMI性能。H…

【全面介绍下如何使用Zoom视频会议软件!】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…