码迷,mamicode.com
首页 > 系统相关 > 详细

30分钟玩转Linux磁盘分区信息管理之步步高深【必知必会常识】

时间:2016-03-16 01:25:09      阅读:429      评论:0      收藏:0      [点我收藏+]

标签:文件系统创建   磁盘分区   mbr   gpt   

我们看看在Linux系统中磁盘是如何分区的

磁盘分区:

fdisk:是Linux的一个操作磁盘分区表的常用工具:

    常用的格式:fdisk -l列出使用的磁盘设备

[root@linux ~]# fdisk -l

Disk /dev/sda: 214.7 GB, 214748364800 bytes, 419430400 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk label type: dos
Disk identifier: 0x00029f42

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048     1026047      512000   83  Linux
/dev/sda2         1026048    84912127    41943040   83  Linux
/dev/sda3        84912128   126855167    20971520   83  Linux
/dev/sda4       126855168   419430399   146287616    5  Extended
/dev/sda5       126859264   131055615     2098176   82  Linux swap / Solaris

下面我们根据实验一点点讲解Linux磁盘的管理操作

0.创建主分区(MBR):

a)  Fdisk /dev/sda进入磁盘分区环境

[root@bogon ~]# fdisk /dev/sda

WARNING: DOS-compatible mode is deprecated. It‘s strongly recommended to
         switch off the mode (command ‘c‘) and change display units to
         sectors (command ‘u‘).

Command (m for help):

当然,执行在这的时候,你可以使用m便会列出命令选项:

Command (m for help): m
Command action
   a   toggle a bootable flag
   b   edit bsd disklabel
   c   toggle the dos compatibility flag
   d   delete a partition
   l   list known partition types
   m   print this menu
   n   add a new partition
   o   create a new empty DOS partition table
   p   print the partition table
   q   quit without saving changes
   s   create a new empty Sun disklabel
   t   change a partition‘s system id
   u   change display/entry units
   v   verify the partition table
   w   write table to disk and exit
   x   extra functionality (experts only)

Command (m for help):

b)  添加一个新的磁盘

Command (m for help): n
Command action
   e   extended
   p   primary partition (1-4)

e:表示扩展分区,p:表示主分区(1-4)

[延伸]我们之后主分区的数量是由分区表限制的,64的分区表最多只能分为4个主分区,或者三个主分区一个扩展分区或者其他,常见的window中的就是一个主分区一个扩展分区(明白了吗)

Command action
   e   extended
   p   primary partition (1-4)
p
Partition number (1-4): 3
First cylinder (7859-15665, default 7859):

c)  回车选择默认的起始扇区

Partition number (1-4): 3
First cylinder (7859-15665, default 7859): 
Using default value 7859

这里我们直接回车表示使用的是起始的柱面(在系统版本的不同,有的是根据柱面,有的是扇区,不过呢,也没啥大碍)

d)  输入格式为”+[M,G]”磁盘空间大小

Last cylinder, +cylinders or +size{K,M,G} (7859-15665, default 15665): +10G

根据我们自己个人定制,使用括号里面的单位,或者你也可以选择使用柱面表示,但是前面有一个加号

e)  w保存退出

Command (m for help): w
The partition table has been altered!

Calling ioctl() to re-read partition table.

WARNING: Re-reading the partition table failed with error 16: Device or resource busy.
The kernel still uses the old table. The new table will be used at
the next reboot or after you run partprobe(8) or kpartx(8)
Syncing disks.

这一切的操作其实都是在内存中完成,只有使用w才是保存下来,下面我们来验证一下

f)  ls /dev/sda*或者cat /proc/partitions查看是否有新创建的分区

[root@bogon ~]# ls /dev/sda*
/dev/sda  /dev/sda1  /dev/sda2
[root@bogon ~]# cat /proc/partitions 
major minor  #blocks  name

   8        0  125829120 sda
   8        1     204800 sda1
   8        2   62914560 sda2
 253        0   20971520 dm-0
 253        1    2097152 dm-1
 253        2   10485760 dm-2
 253        3   20971520 dm-3
[root@bogon ~]#

奇怪,这是怎么回事呢?难道没有成功?不是的,这是因为没有同步到内核罢了

g)  执行parted –a/dev/sda一次或多次直到显示创建的新的分区

[root@bogon ~]# partx -a /dev/sda
BLKPG: Device or resource busy
error adding partition 1
BLKPG: Device or resource busy
error adding partition 2
[root@bogon ~]# partx -a /dev/sda
BLKPG: Device or resource busy
error adding partition 1
BLKPG: Device or resource busy
error adding partition 2
BLKPG: Device or resource busy
error adding partition 3
[root@bogon ~]# fdisk -l

Disk /dev/sda: 128.8 GB, 128849018880 bytes
255 heads, 63 sectors/track, 15665 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x0004a6ba

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *           1          26      204800   83  Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2              26        7859    62914560   8e  Linux LVM
/dev/sda3            7859        9164    10489446   83  Linux

partx -a 其实就是通知(告诉)内核,磁盘信息变动了,你更新一下,一次没有显示,我们可以多执行一下看看结果,是不是10G的主分区就创建成功了。因此,这里特别留意两个命令partx 和fdisk

主分区我们创建了,可是我想创建一个交换分区,怎么创建呢?下面我们就来看看

大家知道swap分区就是内存空间,空间前后那就是不一样的了,我们先来查看一下内存空间

[root@bogon ~]# free -m
             total       used       free     shared    buffers     cached
Mem:           845        157        687          0         12         55
-/+ buffers/cache:         90        754 
Swap:         2047          0       2047

现在开始创建一个swap分区

[root@bogon ~]# mkswap /dev/sda4
mkswap: /dev/sda4: warning: don‘t erase bootbits sectors
        (dos partition table detected). Use -f to force.
Setting up swapspace version 1, size = 31463296 KiB
no label, UUID=c0c990f9-9d68-41d6-8e75-1eb41b08c4fc
[root@bogon ~]# mkswap -f /dev/sda4
Setting up swapspace version 1, size = 31463296 KiB
no label, UUID=5017d30a-1d96-4e47-b4ba-274d132afeb9
[root@bogon ~]# free -m
             total       used       free     shared    buffers     cached
Mem:           845        157        687          0         12         55
-/+ buffers/cache:         90        754 
Swap:         2047          0       2047 
[root@bogon ~]# swapon /dev/sda4
[root@bogon ~]# free -m
             total       used       free     shared    buffers     cached
Mem:           845        180        664          0         12         55
-/+ buffers/cache:        112        732 
Swap:        32773          0      32773 
[root@bogon ~]#


当然我们也是可以把一个已经创建的分区调整为swap分区

a)  Fdisk /dev/sda进入磁盘分区环境

b)  添加一个新的磁盘

c)  回车选择默认的起始扇区

d)  输入格式为”+[MG]”磁盘空间大小

e)  显示调整分区的系统ID,swap(82)

f)  调整分区

g)  输入调整的分区号

h)  输入要想调整的分区类型ID(82)

i)  查看分区调整的结果

j)  保存

k)  kpartx  -af /dev/sda重读一次或者两次,或者手动调整,使用kpartx –a /dev/sda#,#是调整的那个分区号,手动的添加一个分区

l)  fdisk –l /dev/sda 查看显示是否成功

下面是源码展示:步骤很清楚

[root@bogon ~]# fdisk /dev/sda

WARNING: DOS-compatible mode is deprecated. It‘s strongly recommended to
         switch off the mode (command ‘c‘) and change display units to
         sectors (command ‘u‘).

Command (m for help): n
First cylinder (9165-13081, default 9165): 
Using default value 9165
Last cylinder, +cylinders or +size{K,M,G} (9165-13081, default 13081): +100M

Command (m for help): l

 0  Empty           24  NEC DOS         81  Minix / old Lin bf  Solaris        
 1  FAT12           39  Plan 9          82  Linux swap / So c1  DRDOS/sec (FAT-
 2  XENIX root      3c  PartitionMagic  83  Linux           c4  DRDOS/sec (FAT-
 3  XENIX usr       40  Venix 80286     84  OS/2 hidden C:  c6  DRDOS/sec (FAT-
 4  FAT16 <32M      41  PPC PReP Boot   85  Linux extended  c7  Syrinx         
 5  Extended        42  SFS             86  NTFS volume set da  Non-FS data    
 6  FAT16           4d  QNX4.x          87  NTFS volume set db  CP/M / CTOS / .
 7  HPFS/NTFS       4e  QNX4.x 2nd part 88  Linux plaintext de  Dell Utility   
 8  AIX             4f  QNX4.x 3rd part 8e  Linux LVM       df  BootIt         
 9  AIX bootable    50  OnTrack DM      93  Amoeba          e1  DOS access     
 a  OS/2 Boot Manag 51  OnTrack DM6 Aux 94  Amoeba BBT      e3  DOS R/O        
 b  W95 FAT32       52  CP/M            9f  BSD/OS          e4  SpeedStor      
 c  W95 FAT32 (LBA) 53  OnTrack DM6 Aux a0  IBM Thinkpad hi eb  BeOS fs        
 e  W95 FAT16 (LBA) 54  OnTrackDM6      a5  FreeBSD         ee  GPT            
 f  W95 Ext‘d (LBA) 55  EZ-Drive        a6  OpenBSD         ef  EFI (FAT-12/16/
10  OPUS            56  Golden Bow      a7  NeXTSTEP        f0  Linux/PA-RISC b
11  Hidden FAT12    5c  Priam Edisk     a8  Darwin UFS      f1  SpeedStor      
12  Compaq diagnost 61  SpeedStor       a9  NetBSD          f4  SpeedStor      
14  Hidden FAT16 <3 63  GNU HURD or Sys ab  Darwin boot     f2  DOS secondary  
16  Hidden FAT16    64  Novell Netware  af  HFS / HFS+      fb  VMware VMFS    
17  Hidden HPFS/NTF 65  Novell Netware  b7  BSDI fs         fc  VMware VMKCORE 
18  AST SmartSleep  70  DiskSecure Mult b8  BSDI swap       fd  Linux raid auto
1b  Hidden W95 FAT3 75  PC/IX           bb  Boot Wizard hid fe  LANstep        
1c  Hidden W95 FAT3 80  Old Minix       be  Solaris boot    ff  BBT            
1e  Hidden W95 FAT1

Command (m for help): t
Partition number (1-5): 5
Hex code (type L to list codes): 82
Changed system type of partition 5 to 82 (Linux swap / Solaris)

Command (m for help): p

Disk /dev/sda: 128.8 GB, 128849018880 bytes
255 heads, 63 sectors/track, 15665 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x0004a6ba

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *           1          26      204800   83  Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2              26        7859    62914560   8e  Linux LVM
/dev/sda3            7859        9164    10489446   83  Linux
/dev/sda4            9165       13081    31463302+   5  Extended
/dev/sda5            9165        9178      112423+  82  Linux swap / Solaris

Command (m for help): w
The partition table has been altered!

Calling ioctl() to re-read partition table.

WARNING: Re-reading the partition table failed with error 16: Device or resource busy.
The kernel still uses the old table. The new table will be used at
the next reboot or after you run partprobe(8) or kpartx(8)
Syncing disks.
[root@bogon ~]# kpartx -a /dev/sda
device-mapper: reload ioctl on sda1 failed: Invalid argument
create/reload failed on sda1
device-mapper: reload ioctl on sda2 failed: Invalid argument
create/reload failed on sda2
device-mapper: reload ioctl on sda3 failed: Invalid argument
create/reload failed on sda3
device-mapper: reload ioctl on sda4 failed: Invalid argument
create/reload failed on sda4
device-mapper: reload ioctl on sda5 failed: Invalid argument
create/reload failed on sda5

2.文件系统的创建

这里使用的是mkfs格式化工具,他可以把分区格式化为mkfs.cramfs   mkfs.ext2 mkfs.ext3     mkfs.ext4     mkfs.ext4dev  mkfs.msdos    mkfs.vfat这些文件系统例如:

[root@bogon ~]# mkfs.ext4 /dev/sda3
mke2fs 1.41.12 (17-May-2010)
Filesystem label=            
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
655776 inodes, 2622361 blocks
131118 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=2688548864
81 block groups
32768 blocks per group, 32768 fragments per group
8096 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632

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

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

a)  mkfs.ext2 /dev/sda#  格式化sda#分区成为ext2的文件系统类型(破坏已有的文件系统类型)

[root@bogon ~]# mkfs.ext2 /dev/sda3
mke2fs 1.41.12 (17-May-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
655776 inodes, 2622361 blocks
131118 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=2688548864
81 block groups
32768 blocks per group, 32768 fragments per group
8096 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632

Writing inode tables: done                            
Writing superblocks and filesystem accounting information: done

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

b)  blkid /dev/sda# 查看分区是否格式化成目标文件系统类型

[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="228c109c-b9f8-4339-90eb-b072c60b3433" TYPE="ext2"

3.创建一个xfs文件系统

a)  Lsmod | grep xfs 查看系统是否加载的有xfs,或者Mkfs.  TABTAB查看是否有xfs文件格式包没有就执行下一步或者跳下一步

[root@linux ~]# lsmod | grep xfs
xfs                   939662  3 
libcrc32c              12644  1 xfs
[root@linux ~]# mkfs.
mkfs.btrfs   mkfs.cramfs  mkfs.ext2    mkfs.ext3    mkfs.ext4    mkfs.fat     mkfs.minix   mkfs.msdos   mkfs.vfat    mkfs.xfs     
[root@linux ~]# mkfs.

b)  Yum install xfs-progs安装xfs包(省略)

c)  Mkfs.xfs –f /dev/sda# 强制把原来的格式转化为xfs格式的文件系统

[root@linux ~]# mkfs.xfs -f /dev/sda7
meta-data=/dev/sda7              isize=256    agcount=4, agsize=6400 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=0        finobt=0
data     =                       bsize=4096   blocks=25600, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=0
log      =internal log           bsize=4096   blocks=853, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
[root@linux ~]#

d)  Blkid /dev/sda#

[root@linux ~]# blkid /dev/sda7
/dev/sda7: UUID="6655205a-6c44-49a3-a9cc-e2587458c1c1" TYPE="xfs" 
[root@linux ~]#

4.了解一些专业的ext文件系统创建工具

a)  Mke2fs 选项 device

l -t {ext2|ext3|ext4}指明要创建的文件系统的类型

[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="228c109c-b9f8-4339-90eb-b072c60b3433" TYPE="ext2" 
[root@bogon ~]# mke2fs -t ext3 /dev/sda3
......
[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="347239a7-720e-429a-b381-9e92d7e47f49" SEC_TYPE="ext2" TYPE="ext3"

Mkfs.ext4=mkfs –text4=mke2fs –t ext4

l -b {1024|2048|4096}指明块的大小

l -L 指明或修改卷标lable

l -m 指定预留空间百分比

[root@bogon ~]# mke2fs -t ext4 -b 2048 -L juanbiao1 -m 3 /dev/sda3 
mke2fs 1.41.12 (17-May-2010)
Filesystem label=juanbiao1
OS type: Linux
Block size=2048 (log=1)
Fragment size=2048 (log=1)
Stride=0 blocks, Stripe width=0 blocks
657408 inodes, 5244722 blocks
157341 blocks (3.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=543162368
321 block groups
16384 blocks per group, 16384 fragments per group
2048 inodes per group
Superblock backups stored on blocks: 
	16384, 49152, 81920, 114688, 147456, 409600, 442368, 802816, 1327104, 
	2048000, 3981312

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.
[root@bogon ~]#

l -j 创建有日志功能的文件系统ext3

Mkfs.ext3=mkfs –text3=mke2fs –j=mke2fs –O has_journal /dev/sda3

[root@bogon ~]# mke2fs -j /dev/sda3
mke2fs 1.41.12 (17-May-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
655776 inodes, 2622361 blocks
131118 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=2688548864
81 block groups
32768 blocks per group, 32768 fragments per group
8096 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632

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

This filesystem will be automatically checked every 35 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.
[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="33eb2e59-f7fc-4bc8-bb8a-824460614f2d" SEC_TYPE="ext2" TYPE="ext3"

例子:mke2fs –t ext4 –b 2048 –L juanbiao/dev/sda#

5.专业ext文件系统更改卷标

a)  E2lable查看或者设定文件系统的卷标

e2lable /dev/sda# 或者blkid /dev/sda#查看卷标

e2lable /dev/sda# juanbiao 设定文件系统卷标

[root@bogon ~]# e2label /dev/sda3 juanbiao2
[root@bogon ~]# e2label /dev/sda3
juanbiao2
[root@bogon ~]#

6.查看或修改ext系列文件系统的某些[超级块]属性[块大小创建后不能修改]

a)  Tune2fs –l /dev/sda# 查看文件系统中超级块的信息

[root@bogon ~]# tune2fs -l /dev/sda3
tune2fs 1.41.12 (17-May-2010)
Filesystem volume name:   juanbiao2
Last mounted on:          <not available>
Filesystem UUID:          33eb2e59-f7fc-4bc8-bb8a-824460614f2d
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      has_journal ext_attr resize_inode dir_index filetype sparse_super large_file
Filesystem flags:         signed_directory_hash 
Default mount options:    (none)
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              655776
Block count:              2622361
Reserved block count:     131118
Free blocks:              2542628
Free inodes:              655765
First block:              0
......

b)  –j 无损将ext2升级为ext3

1.  tune2fs –j /dev/sda# 文件系统改为ext3

[root@bogon ~]# mke2fs -t ext2 /dev/sda3
mke2fs 1.41.12 (17-May-2010)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
655776 inodes, 2622361 blocks
131118 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=2688548864
81 block groups
32768 blocks per group, 32768 fragments per group
8096 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632

Writing inode tables: done                            
Writing superblocks and filesystem accounting information: done

This filesystem will be automatically checked every 32 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.
[root@bogon ~]# tune2fs -j /dev/sda3
tune2fs 1.41.12 (17-May-2010)
Creating journal inode: done
This filesystem will be automatically checked every 32 mounts or
180 days, whichever comes first.  Use tune2fs -c or -i to override.
[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="c58a8365-b94b-4da4-b6c3-7e95e543b18b" SEC_TYPE="ext2" TYPE="ext3"

2.  -L 指明或修改卷标lable

3.  -m 指定预留空间百分比

[root@bogon ~]# tune2fs -L nihao -m 3 /dev/sda3
tune2fs 1.41.12 (17-May-2010)
Setting reserved blocks percentage to 3% (78670 blocks)
[root@bogon ~]# e2label /dev/sda3
nihao
[root@bogon ~]#

4.  -O 关闭或启动某种特性

a)  Tune2fs –O ^has_journal/dev/sda3关闭该文件系统的日志功能

b)  Tune2fs –o ^mount_options/dev/sda3关闭该文件系统的默认挂载选项

c)  Tune2fs –o acl /dev/sda3访问控制列表

[root@bogon ~]# tune2fs -o acl /dev/sda3
tune2fs 1.41.12 (17-May-2010)
[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="c58a8365-b94b-4da4-b6c3-7e95e543b18b" SEC_TYPE="ext2" TYPE="ext3" LABEL="nihao" 
[root@bogon ~]# tune2fs -l /dev/sda3
tune2fs 1.41.12 (17-May-2010)
Filesystem volume name:   nihao
Last mounted on:          <not available>
Filesystem UUID:          c58a8365-b94b-4da4-b6c3-7e95e543b18b
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      has_journal ext_attr resize_inode dir_index filetype sparse_super large_file
Filesystem flags:         signed_directory_hash 
Default mount options:    acl-------------<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<-------------
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux

7.显示文件系统属性信息

a)  Dumpe2fs /dev/sda# 显示文件系统的详细信息以及每一个块组的详细信息

由于版面太长不予显示了

b)  Dumpe2fs –h /dev/sda#与Tune2fs –l /dev/sda#的结果相似

[root@bogon ~]# dumpe2fs -h /dev/sda3
dumpe2fs 1.41.12 (17-May-2010)
Filesystem volume name:   nihao
Last mounted on:          <not available>
Filesystem UUID:          c58a8365-b94b-4da4-b6c3-7e95e543b18b
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      has_journal ext_attr resize_inode dir_index filetype sparse_super large_file
Filesystem flags:         signed_directory_hash 
Default mount options:    acl
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              655776
Block count:              2622361
Reserved block count:     78670

8.文件系统检测

a)  因进程意外终止或系统崩溃等原因导致写入操作非正常终止时,可能会在造成文件损坏,此时应该检测并修复文件系统,但是建议文件系统离线[不要挂载或者别人正在使用写入的时候]操作

Ext系列文件系统检测专用e2fsck

      -y 对所有的交互式询问自动回答yes

      -f 即使文件系统处于clean状态,也要强制进行检测

[root@bogon ~]# e2fsck -yf /dev/sda3
e2fsck 1.41.12 (17-May-2010)
Pass 1: Checking inodes, blocks, and sizes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
nihao: 11/655776 files (0.0% non-contiguous), 79733/2622361 blocks
[root@bogon ~]#

   通用fsck工具(检测和修复文件系统)

      -f fstype 指明文件系统的类型fsck –t ext4=fsck.ext4

      -a 不用交互自动修复所有错误(不建议使用)

      -r 交互式修复

[root@bogon ~]# fsck -fr /dev/sda3
fsck from util-linux-ng 2.17.2
e2fsck 1.41.12 (17-May-2010)
Pass 1: Checking inodes, blocks, and sizes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
nihao: 11/655776 files (0.0% non-contiguous), 79733/2622361 blocks
[root@bogon ~]#

10定位设备

   Blkid device

   Blkid –L lable 根据卷标定位设备

   Blkid –U UUID 根据UUID定位设备

[root@bogon ~]# blkid -L nihao
/dev/sda3
[root@bogon ~]# blkid /dev/sda3
/dev/sda3: UUID="c58a8365-b94b-4da4-b6c3-7e95e543b18b" SEC_TYPE="ext2" TYPE="ext3" LABEL="nihao" 
[root@bogon ~]# blkid -U c58a8365-b94b-4da4-b6c3-7e95e543b18b
/dev/sda3
[root@bogon ~]#


11、创建一个GPT分区

   简单了解一下什么是GPT分区?

   GPT全局唯一标识分区表(GUID Partition Table),与传统的MBR分区表相比,存在着很大的差异性,比如:

分区数量:

   MBR熟知的最多只能分为4个主分区,对于GPT来说,对分区是没有限制的,只是再window上支持128个分区罢了,但是在管理硬盘大小上来说,还是处于可管理18EB的优先地位,而NTFS只是256TB的大小空间。

下面我们体验一下Linux下GPT分区:

一个GPT分区的范例:

[root@bogon ~]# parted /dev/sda3
GNU Parted 2.1
Using /dev/sda3
Welcome to GNU Parted! Type ‘help‘ to view a list of commands.
(parted) mklabel                                                          
New disk label type? gpt                                                  
Warning: The existing disk label on /dev/sda3 will be destroyed and all data on this disk will be lost. Do you want to continue?
Yes/No? Yes                                                               
Warning: WARNING: the kernel failed to re-read the partition table on /dev/sda3 (Invalid argument).  As a result, it may not reflect all of your changes until after
reboot.
(parted) p                                                                
Model: Unknown (unknown)
Disk /dev/sda3: 10.7GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt

Number  Start  End  Size  File system  Name  Flags

(parted) mkpart                                                           
Partition name?  []? mydisk1
File system type?  [ext2]?                                                
Start? 100M                                                               
End? 200M                                                                 
Warning: WARNING: the kernel failed to re-read the partition table on /dev/sda3 (Invalid argument).  As a result, it may not reflect all of your changes until after
reboot.
(parted) P                                                                
Model: Unknown (unknown)
Disk /dev/sda3: 10.7GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt

Number  Start   End    Size   File system  Name     Flags
 1      99.6MB  200MB  101MB               mydisk1

(parted) quit

以上仅供参考,谢谢指点


本文出自 “Jasonforcto” 博客,请务必保留此出处http://xuelong.blog.51cto.com/10573089/1751545

30分钟玩转Linux磁盘分区信息管理之步步高深【必知必会常识】

标签:文件系统创建   磁盘分区   mbr   gpt   

原文地址:http://xuelong.blog.51cto.com/10573089/1751545

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!