一、磁盘格式化
分好去的磁盘需要格式化之后才可以使用。磁盘分区一般用mke2fs命令或者mkfs.filesystemtype。这个filesystemtype分为ext4,ext3,xfs等等。xfs是centos7自带的文件系统格式。
那么怎么查看当前磁盘支持的文件系统呢?
[root@ruanwenwu02 ~]# cat /etc/filesystems
xfs
ext4
ext3
ext2
nodev proc
nodev devpts
iso9660
vfat
hfs
hfsplus
*
再看看已经挂载后的磁盘:
[root@ruanwenwu02 ~]# mount|grep "\/dev\/sd*"
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev,seclabel)
/dev/sda3 on / type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
/dev/sda1 on /boot type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
mke2fs有几个参数:-b指定块大小,-m指定预留百分比,-i指定每个inode节点大小。
现在我们使用mke2fs格式化xfs:
[root@ruanwenwu02 ~]# mke2fs -t xfs /dev/sdb1
mke2fs 1.42. (-Dec-) Your mke2fs.conf file does not define the xfs filesystem type.
Aborting...
[root@ruanwenwu02 ~]# find / -type f -name "mke2fs.conf"
/etc/mke2fs.conf
[root@ruanwenwu02 ~]# ^C
[root@ruanwenwu02 ~]# vim /etc/mke2fs.conf
失败,根据提示查看配置文件,发现配置文件中没有xfs文件系统的配置。
其实除了mke2fs命令可以格式化磁盘,另一个命令mkfs.xfs也可以,想对应的还有mkfs.ext4,mkfs.ext3等等:
[root@ruanwenwu02 ~]# mkfs.xfs /dev/sdb1
mkfs.xfs: /dev/sdb1 appears to contain an existing filesystem (ext4).
mkfs.xfs: Use the -f option to force overwrite.
[root@ruanwenwu02 ~]# mkfs.xfs -f /dev/sdb1
meta-data=/dev/sdb1 isize= agcount=, agsize= blks
= sectsz= attr=, projid32bit=
= crc= finobt=, sparse=
data = bsize= blocks=, imaxpct=
= sunit= swidth= blks
naming =version bsize= ascii-ci= ftype=
log =internal log bsize= blocks=, version=
= sectsz= sunit= blks, lazy-count=
realtime =none extsz= blocks=, rtextents=
通过实验,我们发现mkfs.xfs不支持-b(块的大小)选项,也不支持-m(预留空间百分比)和-i(每个inode大小)选项。但是mkfs.ext4是支持的:
[root@ruanwenwu02 ~]# mkfs.ext4 -b -m 0.1 /dev/sdb1
mke2fs 1.42. (-Dec-)
文件系统标签=
OS type: Linux
块大小= (log=)
分块大小= (log=)
Stride= blocks, Stripe width= blocks
inodes, blocks
blocks (0.10%) reserved for the super user
第一个数据块=
Maximum filesystem blocks=
block groups
blocks per group, fragments per group
inodes per group
Superblock backups stored on blocks:
, , , , , , Allocating group tables: 完成
正在写入inode表: 完成
Creating journal ( blocks): 完成
Writing superblocks and filesystem accounting information: 完成
用mke2fs方法也能实现,事实上mke2fs和mkfs.ext4基本上是等同的。默认的块大小是4096。
[root@ruanwenwu02 ~]# mke2fs -t ext4 /dev/sdb1
mke2fs 1.42. (-Dec-)
文件系统标签=
OS type: Linux
块大小= (log=)
分块大小= (log=)
Stride= blocks, Stripe width= blocks
inodes, blocks
blocks (5.00%) reserved for the super user
第一个数据块=
Maximum filesystem blocks=
block groups
blocks per group, fragments per group
inodes per group
Superblock backups stored on blocks:
, , , Allocating group tables: 完成
正在写入inode表: 完成
Creating journal ( blocks): 完成
Writing superblocks and filesystem accounting information: 完成
通过观察发现,如果默认一个块是4096byte,那么一个Inode是4个块。如果我们把每个Inode调成8192,那么看看:
[root@ruanwenwu02 ~]# mke2fs -i -b /dev/sdb1
mke2fs 1.42. (-Dec-)
文件系统标签=
OS type: Linux
块大小= (log=)
分块大小= (log=)
Stride= blocks, Stripe width= blocks
inodes, blocks
blocks (5.00%) reserved for the super user
第一个数据块=
Maximum filesystem blocks=
block groups
blocks per group, fragments per group
inodes per group
Superblock backups stored on blocks:
, , ,
发现节点数增加了,块数没有增加。
查看电脑上已经挂载的磁盘:
[root@ruanwenwu02 ~]# mount | grep "\/dev\/sd*"
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev,seclabel)
/dev/sda3 on / type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
/dev/sda1 on /boot type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
二、磁盘挂载
磁盘需要挂载之后才可以读写。挂载需要找一个挂载点,比如/,/boot/这都是挂载点。我们先看看机器上有哪些磁盘是可以挂载的:
[root@ruanwenwu02 ~]# fdisk -l 磁盘 /dev/sda:21.5 GB, 字节, 个扇区
Units = 扇区 of * = bytes
扇区大小(逻辑/物理): 字节 / 字节
I/O 大小(最小/最佳): 字节 / 字节
磁盘标签类型:dos
磁盘标识符:0x00036cf2 设备 Boot Start End Blocks Id System
/dev/sda1 * Linux
/dev/sda2 Linux swap / Solaris
/dev/sda3 Linux 磁盘 /dev/sdb: MB, 字节, 个扇区
Units = 扇区 of * = bytes
扇区大小(逻辑/物理): 字节 / 字节
I/O 大小(最小/最佳): 字节 / 字节
磁盘标签类型:dos
磁盘标识符:0x2f45f776 设备 Boot Start End Blocks Id System
/dev/sdb1 Linux
/dev/sdb2 Linux
/dev/sdb3 Extended
/dev/sdb5 Linux
/dev/sdb6 Linux
/dev/sdb上的分区都没有挂载,那我们现在挂载一下/dev/sdb1/:
[root@ruanwenwu02 ~]# mount /dev/sdb1 /mnt
[root@ruanwenwu02 ~]# mount |grep "\/dev\/sd*"
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev,seclabel)
/dev/sda3 on / type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
/dev/sda1 on /boot type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
/dev/sdb1 on /mnt type ext2 (rw,relatime,seclabel)
查看磁盘属性:
[root@ruanwenwu02 ~]# blkid
/dev/sda1: UUID="4d7f0a80-47f8-4b8a-a677-4c14b801d43e" TYPE="xfs"
/dev/sda2: UUID="c1ce52b4-b264-4de0-a7d6-4f33d1ab4a2d" TYPE="swap"
/dev/sda3: UUID="604bc673-7f8d-4355-919f-ed6740a8efc8" TYPE="xfs"
/dev/sdb1: UUID="0f8ee81b-d2df-48d3-adcd-ee79965ca313" TYPE="ext2"
/dev/sr0: UUID="2016-12-05-13-55-45-00" LABEL="CentOS 7 x86_64" TYPE="iso9660" PTTYPE="dos"
卸载磁盘:
[root@ruanwenwu02 ~]# umount /dev/sdb1
[root@ruanwenwu02 ~]# !moun
mount |grep "\/dev\/sd*"
tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev,seclabel)
/dev/sda3 on / type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
/dev/sda1 on /boot type xfs (rw,relatime,seclabel,attr2,inode64,noquota)
新加入的磁盘要加入开机自动挂载的方法:
vim /etc/fstab
#
# /etc/fstab
# Created by anaconda on Tue Oct ::
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(), findfs(), mount() and/or blkid() for more info
#
UUID=604bc673-7f8d--919f-ed6740a8efc8 / xfs defaults
UUID=4d7f0a80-47f8-4b8a-a677-4c14b801d43e /boot xfs defaults
UUID=c1ce52b4-b264-4de0-a7d6-4f33d1ab4a2d swap swap defaults
文件内容每行被用空格分成5部分,每部分的意义:
uuid=604b... 的意思是磁盘id
xfs 磁盘文件系统
defaults : 挂载默认选项
0 : 备份(无意义)
0:0开启不检查磁盘,如果要检查的话,一般给/boot分区设置为1,其他设置为2
添加一个磁盘启动项:
#
# /etc/fstab
# Created by anaconda on Tue Oct ::
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(), findfs(), mount() and/or blkid() for more info
#
UUID=604bc673-7f8d--919f-ed6740a8efc8 / xfs defaults
UUID=4d7f0a80-47f8-4b8a-a677-4c14b801d43e /boot xfs defaults
UUID=c1ce52b4-b264-4de0-a7d6-4f33d1ab4a2d swap swap defaults
/dev/sdb1 xfs defaults
查看帮助使用命令:man fstab:
defaults
use default options: rw, suid, dev, exec, auto, nouser, and async.
三、手动增加swap空间
一般我们不会用到比较大的swap空间。如果内存为4G,我们最多分配8G的swap空间。如果某些应用程序要求使用那么大的空间,我们可以进行手动扩容。
步骤:
1.创建虚拟磁盘:
[root@ruanwenwu02 ~]# dd if=/dev/zero of=/tmp/testdisk bs=1M count=
记录了200+ 的读入
记录了200+ 的写出
209715200字节( MB)已复制,4.59577 秒,45.6 MB/秒
[root@ruanwenwu02 ~]# ls -ld /tmp/testdisk
-rw-r--r--. root root 11月 : /tmp/testdisk
[root@ruanwenwu02 ~]# ls -ldh /tmp/testdisk
-rw-r--r--. root root 200M 11月 : /tmp/testdisk
[root@ruanwenwu02 ~]# mkswap /tmp/testdisk
正在设置交换空间版本 1,大小 = 204796 KiB
这里面有几点需要说明一下。
dd命令的 if参数的意思是:数据源从哪里来。/dev/zero是个造零器。of的意思是到那里去。bs是块的大小。count是多少块。
mkswap是将造的空间转换成swap空间。
2.将虚拟磁盘的空间增加到swap:
[root@ruanwenwu02 ~]# free -m
total used free shared buff/cache available
Mem:
Swap:
[root@ruanwenwu02 ~]# swapon /tmp/testdisk
swapon: /tmp/testdisk:不安全的权限 ,建议使用 。
[root@ruanwenwu02 ~]# free -m
total used free shared buff/cache available
Mem:
Swap:
[root@ruanwenwu02 ~]# chmod /tmp/testdisk
[root@ruanwenwu02 ~]# free -m
total used free shared buff/cache available
Mem:
Swap:
如果要删除新增的空间,使用命令:
[root@ruanwenwu02 ~]# swapoff /tmp/testdisk
[root@ruanwenwu02 ~]# free -m
total used free shared buff/cache available
Mem:
Swap: