centos5.5软件raid1+lvm逻辑卷标管理总结

本文涉及的产品
可视分析地图(DataV-Atlas),3 个项目,100M 存储空间
数据可视化DataV,5个大屏 1个月
简介:

 上次有台机器用来做了samba服务器,感觉软件很重要所以想了想在找了一块80g的硬盘做了raid1镜像,花费了一天的时间一边实验一边总结,自己做个笔记以免以后忘记。

1.[root@zh888 ~]# rpm -q mdadm//先查询是否有mdadm的软件包。

mdadm-2.6.9-3.el5//说明有了,如果没有请用yum -y install来安装即可。


2.[root@zh888 ~]# fdisk -l//查看分区

Disk /dev/hda: 40.0 GB, 40020664320 bytes
255 heads, 63 sectors/track, 4865 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hda1   *           1          13      104391   83  Linux
/dev/hda2              14         144     1052257+  82  Linux swap / Solaris
/dev/hda3             145        4865    37921432+  83  Linux

Disk /dev/hdb: 80.0 GB, 80026361856 bytes
16 heads, 63 sectors/track, 155061 cylinders
Units = cylinders of 1008 * 512 = 516096 bytes

Disk /dev/hdb doesn't contain a valid partition table

Disk /dev/hdd: 81.9 GB, 81964302336 bytes
16 heads, 63 sectors/track, 158816 cylinders
Units = cylinders of 1008 * 512 = 516096 bytes

Disk /dev/hdd doesn't contain a valid partition table

[root@zh888 ~]# fdisk /dev/hdb//分区为fd类型/dev/hdd也是同样的操作。
Device contains neither a valid DOS partition table, nor Sun, SGI or OSF disklabel
Building a new DOS disklabel. Changes will remain in memory only,
until you decide to write them. After that, of course, the previous
content won't be recoverable.


The number of cylinders for this disk is set to 155061.
There is nothing wrong with that, but this is larger than 1024,
and could in certain setups cause problems with:
1) software that runs at boot time (e.g., old versions of LILO)
2) booting and partitioning software from other OSs
   (e.g., DOS FDISK, OS/2 FDISK)
Warning: invalid flag 0x0000 of partition table 4 will be corrected by w(rite)

Command (m for help): n//new新分区
Command action
   e   extended
   p   primary partition (1-4)
p//主分区
Partition number (1-4): 1//第一个分区
First cylinder (1-155061, default 1): 回车
Using default value 1
Last cylinder or +size or +sizeM or +sizeK (1-155061, default 155061): 回车
Using default value 155061

Command (m for help): t//type类型
Selected partition 1
Hex code (type L to list codes): fd//fd类型
Changed system type of partition 1 to fd (Linux raid autodetect)

Command (m for help): w//保存写入
The partition table has been altered!

Calling ioctl() to re-read partition table.
Syncing disks.

3.[root@zh888 ~]# fdisk -l//在次查看硬盘类型

Disk /dev/hda: 40.0 GB, 40020664320 bytes
255 heads, 63 sectors/track, 4865 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hda1   *           1          13      104391   83  Linux
/dev/hda2              14         144     1052257+  82  Linux swap / Solaris
/dev/hda3             145        4865    37921432+  83  Linux

Disk /dev/hdb: 80.0 GB, 80026361856 bytes
16 heads, 63 sectors/track, 155061 cylinders
Units = cylinders of 1008 * 512 = 516096 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hdb1               1      155061    78150712+  fd  Linux raid autodetect//已经为linux raid了

Disk /dev/hdd: 81.9 GB, 81964302336 bytes
16 heads, 63 sectors/track, 158816 cylinders
Units = cylinders of 1008 * 512 = 516096 bytes

   Device Boot      Start         End      Blocks   Id  System
/dev/hdd1               1      158816    80043232+  fd  Linux raid autodetect

 

4.[root@zh888 ~]#mdadm --create --verbose /dev/md0 --level=1 --raid-devices=2 /dev/hdb1 /dev/hdd1 //创建raid1命令可以用简写如下:
   mdadm: array /dev/md0 started.
 //[root@zh888 ~]#mdadm -C /dev/md0 -l1 -n2 -c128 /dev/hd[bd]也可以用这种方法创建。
   mdadm: array /dev/md0 started.

5.[root@zh888 ~]# echo DEVICE /dev/hd[bd]>/etc/mdadm.conf
或cp /usr/share/doc/mdadm-2.5.4/mdadm.conf-example /etc/mdadm.conf
或echo DEVICE /dev/hd[bd]1 >>/etc/mdadm.conf

6.[root@zh888 ~]# mdadm --detail --scan>>/etc/mdadm.conf
或mdadm -Ds >>/etc/mdadm.conf

7.[root@zh888 ~]# cat /etc/mdadm.conf//查看mdadm.conf文件如下:
DEVICE /dev/hdb /dev/hdd
ARRAY /dev/md0 level=raid1 num-devices=2 metadata=0.90 UUID=57319c2a:090717a6:92042ec3:e00720c4

8.[root@zh888 ~]# mkfs.ext3 /dev/md0//格式化raid1.
mke2fs 1.39 (29-May-2006)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
9781248 inodes, 19537664 blocks
976883 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=0
597 block groups
32768 blocks per group, 32768 fragments per group
16384 inodes per group
Superblock backups stored on blocks: 
        32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 
        4096000, 7962624, 11239424

Writing inode tables: done                            
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done

This filesystem will be automatically checked every 21 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.


9.[root@zh888 ~]# mount /dev/md0 /home/samba/software/ //挂载/dev/md0设备到/home/samba/software目录中。
 [root@zh888 ~]# mount//查看挂载的目录。
/dev/hda3 on / type ext3 (rw)
proc on /proc type proc (rw)
sysfs on /sys type sysfs (rw)
devpts on /dev/pts type devpts (rw,gid=5,mode=620)
/dev/hda1 on /boot type ext3 (rw)
tmpfs on /dev/shm type tmpfs (rw)
none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
/dev/md0 on /home/samba/software type ext3 (rw)//已经挂载上/dev/md0


10.[root@zh888 ~]# cat /proc/mdstat //查看mdstat状态。
Personalities : [raid1] 
md0 : active raid1 hdd[1] hdb[0]
      78150656 blocks [2/2] [UU]
      [======>..............]  resync = 30.0% (23462656/78150656) finish=31.6min speed=28792K/sec
      
unused devices: <none>//正在同步设备。

11.[root@zh888 ~]# mdadm --detail /dev/md0//查看状态可以是-D参数
/dev/md0:
        Version : 0.90
  Creation Time : Thu Sep  1 18:01:12 2011
     Raid Level : raid1
     Array Size : 740263618 (74.53 GiB 74.53 GB)
   Raid Devices : 2
  Total Devices : 2
Preferred Minor : 0
    Persistence : Superblock is persistent

    Update Time : Thu Sep  1 18:01:12 2011
          State : clean
 Active Devices : 2
Working Devices : 2
 Failed Devices : 0
  Spare Devices : 0

     Chunk Size : 128K

           UUID : a55d24d1:f8be2ab8:e606decc:41c96122
         Events : 0.1

    Number   Major   Minor   RaidDevice State
       0       3       64        0      active sync   /dev/hdb
       1      22       64        1      active sync   /dev/hdd

11.创建LVM

lvm就是逻辑卷管理器

步骤分为:
1 创建pv(物理卷)
2 创建vg(卷组)
3 创建lv(逻辑卷)

好处,为文件系统提供一个透明的磁盘接口,利于扩容之类的。

12.[root@zh888 ~]# pvcreate /dev/md0//创建pv物理卷
  Physical volume "/dev/md0" successfully created


13.[root@zh888 ~]# vgcreate datavg /dev/md0//常见datavg
  Volume group "datavg" successfully created


14.[root@zh888 ~]# vgdisplay -v//显示datavg信息
    Finding all volume groups
    Finding volume group "datavg"
  --- Volume group ---
  VG Name               datavg
  System ID             
  Format                lvm2
  Metadata Areas        1
  Metadata Sequence No  1
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                0
  Open LV               0
  Max PV                0
  Cur PV                1
  Act PV                1
  VG Size               74.53 GB
  PE Size               4.00 MB
  Total PE              19079
  Alloc PE / Size       0 / 0   
  Free  PE / Size       19079 / 74.53 GB
  VG UUID               IfweOP-2jnU-4VME-25Dp-Uy2x-Bbfn-IDbjvH
   
  --- Physical volumes ---
  PV Name               /dev/md0     
  PV UUID               2kshX3-T60n-DWwV-DjTF-DxLI-mrzz-Z6He7k
  PV Status             allocatable
  Total PE / Free PE    19079 / 19079

   
从上面显示的卷信息得知,datavg卷只有74.53 GB可用。

15.[root@zh888 ~]# lvcreate datavg --name=datalv --size=74G
  Logical volume "datalv" created

16.[root@zh888 ~]# vgdisplay -v
Finding all volume groups
    Finding volume group "datavg"
  --- Volume group ---
  VG Name               datavg
  System ID             
  Format                lvm2
  Metadata Areas        1
  Metadata Sequence No  2
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                1
  Open LV               0
  Max PV                0
  Cur PV                1
  Act PV                1
  VG Size               74.53 GB
  PE Size               4.00 MB
  Total PE              19079
  Alloc PE / Size       18944 / 74.00 GB
  Free  PE / Size       135 / 540.00 MB
  VG UUID               IfweOP-2jnU-4VME-25Dp-Uy2x-Bbfn-IDbjvH
   
  --- Logical volume ---
  LV Name                /dev/datavg/datalv
  VG Name                datavg
  LV UUID                Ndzr97-yxOn-HP4P-CNZg-1jpG-RaS2-4EBgkh
  LV Write Access        read/write
  LV Status              available
  # open                 0
  LV Size                74.00 GB
  Current LE             18944
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     256
  Block device           253:0
   
  --- Physical volumes ---
  PV Name               /dev/md0     
  PV UUID               2kshX3-T60n-DWwV-DjTF-DxLI-mrzz-Z6He7k
  PV Status             allocatable
  Total PE / Free PE    19079 / 135

17.[root@zh888 ~]# mkfs -t ext3 /dev/datavg/datalv//格式化datalv逻辑卷
mke2fs 1.39 (29-May-2006)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
9699328 inodes, 19398656 blocks
969932 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=0
592 block groups
32768 blocks per group, 32768 fragments per group
16384 inodes per group
Superblock backups stored on blocks: 
        32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 
        4096000, 7962624, 11239424

Writing inode tables: done                            
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done

This filesystem will be automatically checked every 22 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.


18. [root@zh888 ~]# lvdisplay 查看lv逻辑卷然后 /dev/datavg/datalv         /home/samba/software  ext3 default 0 0 写入/etc/fstab中让系统开机启动挂载。
  --- Logical volume ---
  LV Name                /dev/datavg/datalv
  VG Name                datavg
  LV UUID                Ndzr97-yxOn-HP4P-CNZg-1jpG-RaS2-4EBgkh
  LV Write Access        read/write
  LV Status              available
  # open                 0
  LV Size                74.00 GB
  Current LE             18944
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     256
  Block device           253:0

 raid1和raid0测试速度。

19.[root@zh888 software]# dd if=/dev/zero of=file bs=1024k count=1k//测试raid0的速度
1024+0 records in
1024+0 records out
1073741824 bytes (1.1 GB) copied, 15.3735 seconds, 69.8 MB/s
写了1.1G的数据花费了15.3秒,

20.[root@zh888 software]# dd if=/dev/zero of=file bs=1024k count=1k//raid1的速度
1024+0 records in
1024+0 records out
1073741824 bytes (1.1 GB) copied, 29.8514 seconds, 36.0 MB/s

有一些特殊的设备文件。例如/dev/zero文件代表一个永远输出 0的设备文件,使用它作输入可以得到全为空的文件。因此可用来创建新文件和以覆盖的方式清除旧文件。下面使用dd命令将从zero设备中创建一个10K大小(bs决定每次读写1024字节,count定义读写次数为10次),但内容全为0的文件。

# dd if=/dev/zero of=file count=10 bs=1024

  10+0 records in

  10+0 records out

  10240 bytes transferred in 0.001408 secs (7267903 b ytes/sec)

可以通过使用dd if=/dev/zero of=/file 来测试磁盘的纯写入性能

使用dd if=/file of=/dev/null 来测试磁盘的纯读取性能

使用dd if=/file1 of=/file2 来测试磁盘的读写性能


21.补充点mdadm的知识点

dadm有7中模式,下面列出了7种模式的命令格式,详细的选项,请参考man手册。
ASSEMBLE MODE :madam --assemble md-device options-and-component-devices
               mdadm --assembel --scan md-devices-and-options
               mdamd --assembel --scan options
BUILD MODE:    mdadm --build device --chunk=X --level=Y --raid-devices=Z devices
CREATE MODE:   mdadm --create device --chunk=X --level=Y --raid-devices=Z devices
MANAGE MODE:   mdadm device options devices
MISC MODE:     mdadm options ... devices ...
MONITOR MODE:  mdadm --monitor options... devices...
GROW MODE:    

1.查看
MISC模式
#mdadm --detail /dev/md0
#mdadm -D /dev/md0
2.停止
MISC模式
#mdadm -S /dev/md0
3.启动
ASSEMBLE模式
#mdadm -A /dev/md0 /dev/sd[bcd]1
启动指定的RAID,可以理解为将一个raid重新装配到系统中。
如果在前面已经配置了/etc/mdadm.conf文件,可以使用:
#mdadm -As /dev/md0
4.添加删除磁盘
mdadm可以在Manage模式下,对运行中的阵列进行添加及删除磁盘。常用于标识failed磁盘,增加spare(冗余)磁盘,以及替换磁盘等。
# mdadm /dev/md0 --fail /dev/sdd --remove /dev/sdd

# mdadm -D /dev/md0

# mdadm /dev/md0 --add /dev/sdd

# mdadm -D /dev/md0

--fail指定坏磁盘,--remove移走。
需要注意的是,对于某些RAID级别,如RAID0,是不能用--fail --remove --add的。
5.监控
MONITOR模式
# nohup mdadm --monitor --mail root --delay 200 /dev/md0 &
每200秒监控一次,当RAID出现错误时,发送邮件给root用户。
6.增加spare磁盘
可以通过在创建的时候指定冗余磁盘
#mdadm --create --verbose /dev/md0 --level=3 --raid-devices=3 -x1 /dev/sdb1 /dev/sdc1 /dev/sdd1 /dev/sde1
-x(--spare-devices=)参数指定冗余磁盘的数量。另外,对于full的阵列(例如已经有2个磁盘的RAID1),则直接使用-add参数,mdadm会自动把冗余的磁盘作为spare disk。
7.删除RAID
#mdadm -S /dev/md0

#rm /dev/md0
删除/etc/mdadm.conf文件;去除/etc/fstab文件中相关的行。
最后,用fdisk对磁盘进行重新分区。



本文转自zh888 51CTO博客,原文链接:http://blog.51cto.com/zh888/656292,如需转载请自行联系原作者


相关实践学习
DataV Board用户界面概览
本实验带领用户熟悉DataV Board这款可视化产品的用户界面
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
Linux
CentOS卸载LVM磁盘的方法
CentOS卸载LVM磁盘的方法
197 0
|
关系型数据库 Linux 数据库连接
CentOS7下部署开源IT资产管理软件GLPI+FusionInventory
CentOS7下部署开源IT资产管理软件GLPI+FusionInventory
1659 0
CentOS7下部署开源IT资产管理软件GLPI+FusionInventory
|
Linux
CentOS7下对非LVM类型的根分区进行扩容
CentOS7下对非LVM类型的根分区进行扩容
720 0
CentOS7下对非LVM类型的根分区进行扩容
|
4月前
|
关系型数据库 MySQL Java
centos7安装mysql教程及Navicat平替软件
【8月更文挑战第17天】本教程详述CentOS 7上安装MySQL的过程。首先确保移除任何预装的MySQL组件,然后通过wget获取并安装MySQL的YUM源。可以选择安装特定版本如5.7或8.0。安装MySQL服务器后,启动服务并查找初始密码。登录MySQL后应立即更改密码,并可根据需要设置远程访问权限。此外,还推荐使用免费开源的DBeaver作为数据库管理工具,提供了安装步骤以方便管理和操作MySQL数据库。
156 3
|
4月前
|
Linux
centos安装与卸载软件
centos安装与卸载软件
47 1
|
Linux
Centos查看已经安装的软件或者包
Centos查看已经安装的软件或者包
322 0
|
4月前
|
前端开发 小程序 Unix
Centos安装前端开发常用软件
Centos安装前端开发常用软件
|
5月前
|
关系型数据库 MySQL Linux
Linux部署实战前言,MySQL在CentOS安装【单机软件】,MySQL的安装需要root权限,yum install mysql,systemctl enable mysqld开机自启的意思
Linux部署实战前言,MySQL在CentOS安装【单机软件】,MySQL的安装需要root权限,yum install mysql,systemctl enable mysqld开机自启的意思
|
5月前
|
SQL 关系型数据库 MySQL
MYSQL8.0在CentOS安装[单机软件]
MYSQL8.0在CentOS安装[单机软件]
|
Linux Windows
Centos7安装wps办公软件
Centos7安装wps办公软件
178 0