Linux学习(十四)磁盘格式化、磁盘挂载、手动增加swap空间
一、磁盘格式化
分好去的磁盘需要格式化之后才可以使用。磁盘分区一般用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.9 (28-Dec-2013) 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=512 agcount=4, agsize=65536 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=0, sparse=0 data = bsize=4096 blocks=262144, imaxpct=25 = sunit=0 swidth=0 blks naming =version 2 bsize=4096 ascii-ci=0 ftype=1 log =internal log bsize=4096 blocks=2560, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0
通过实验,我们发现mkfs.xfs不支持-b(块的大小)选项,也不支持-m(预留空间百分比)和-i(每个inode大小)选项。但是mkfs.ext4是支持的:
[root@ruanwenwu02 ~]# mkfs.ext4 -b 2048 -m 0.1 /dev/sdb1 mke2fs 1.42.9 (28-Dec-2013) 文件系统标签= OS type: Linux 块大小=2048 (log=1) 分块大小=2048 (log=1) Stride=0 blocks, Stripe width=0 blocks 65536 inodes, 524288 blocks 524 blocks (0.10%) reserved for the super user 第一个数据块=0 Maximum filesystem blocks=268959744 32 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 Allocating group tables: 完成 正在写入inode表: 完成 Creating journal (16384 blocks): 完成 Writing superblocks and filesystem accounting information: 完成
用mke2fs方法也能实现,事实上mke2fs和mkfs.ext4基本上是等同的。默认的块大小是4096。
[root@ruanwenwu02 ~]# mke2fs -t ext4 /dev/sdb1 mke2fs 1.42.9 (28-Dec-2013) 文件系统标签= OS type: Linux 块大小=4096 (log=2) 分块大小=4096 (log=2) Stride=0 blocks, Stripe width=0 blocks 65536 inodes, 262144 blocks 13107 blocks (5.00%) reserved for the super user 第一个数据块=0 Maximum filesystem blocks=268435456 8 block groups 32768 blocks per group, 32768 fragments per group 8192 inodes per group Superblock backups stored on blocks: 32768, 98304, 163840, 229376 Allocating group tables: 完成 正在写入inode表: 完成 Creating journal (8192 blocks): 完成 Writing superblocks and filesystem accounting information: 完成
通过观察发现,如果默认一个块是4096byte,那么一个Inode是4个块。如果我们把每个Inode调成8192,那么看看:
[root@ruanwenwu02 ~]# mke2fs -i 8192 -b 4096 /dev/sdb1 mke2fs 1.42.9 (28-Dec-2013) 文件系统标签= OS type: Linux 块大小=4096 (log=2) 分块大小=4096 (log=2) Stride=0 blocks, Stripe width=0 blocks 131072 inodes, 262144 blocks 13107 blocks (5.00%) reserved for the super user 第一个数据块=0 Maximum filesystem blocks=268435456 8 block groups 32768 blocks per group, 32768 fragments per group 16384 inodes per group Superblock backups stored on blocks: 32768, 98304, 163840, 229376
发现节点数增加了,块数没有增加。
查看电脑上已经挂载的磁盘:
[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, 21474836480 字节,41943040 个扇区 Units = 扇区 of 1 * 512 = 512 bytes 扇区大小(逻辑/物理):512 字节 / 512 字节 I/O 大小(最小/最佳):512 字节 / 512 字节 磁盘标签类型:dos 磁盘标识符:0x00036cf2 设备 Boot Start End Blocks Id System /dev/sda1 * 2048 411647 204800 83 Linux /dev/sda2 411648 4507647 2048000 82 Linux swap / Solaris /dev/sda3 4507648 41943039 18717696 83 Linux 磁盘 /dev/sdb:4294 MB, 4294967296 字节,8388608 个扇区 Units = 扇区 of 1 * 512 = 512 bytes 扇区大小(逻辑/物理):512 字节 / 512 字节 I/O 大小(最小/最佳):512 字节 / 512 字节 磁盘标签类型:dos 磁盘标识符:0x2f45f776 设备 Boot Start End Blocks Id System /dev/sdb1 2048 2099199 1048576 83 Linux /dev/sdb2 6293504 7931903 819200 83 Linux /dev/sdb3 2099200 6293503 2097152 5 Extended /dev/sdb5 2101248 4198399 1048576 83 Linux /dev/sdb6 4200448 5838847 819200 83 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 17 04:46:42 2017 # # Accessible filesystems, by reference, are maintained under '/dev/disk' # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info # UUID=604bc673-7f8d-4355-919f-ed6740a8efc8 / xfs defaults 0 0 UUID=4d7f0a80-47f8-4b8a-a677-4c14b801d43e /boot xfs defaults 0 0 UUID=c1ce52b4-b264-4de0-a7d6-4f33d1ab4a2d swap swap defaults 0 0
文件内容每行被用空格分成5部分,每部分的意义:
uuid=604b... 的意思是磁盘id
xfs 磁盘文件系统
defaults : 挂载默认选项
0 : 备份(无意义)
0:0开启不检查磁盘,如果要检查的话,一般给/boot分区设置为1,其他设置为2
添加一个磁盘启动项:
# # /etc/fstab # Created by anaconda on Tue Oct 17 04:46:42 2017 # # Accessible filesystems, by reference, are maintained under '/dev/disk' # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info # UUID=604bc673-7f8d-4355-919f-ed6740a8efc8 / xfs defaults 0 0 UUID=4d7f0a80-47f8-4b8a-a677-4c14b801d43e /boot xfs defaults 0 0 UUID=c1ce52b4-b264-4de0-a7d6-4f33d1ab4a2d swap swap defaults 0 0 /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+0 的读入 记录了200+0 的写出 209715200字节(210 MB)已复制,4.59577 秒,45.6 MB/秒 [root@ruanwenwu02 ~]# ls -ld /tmp/testdisk -rw-r--r--. 1 root root 209715200 11月 4 09:33 /tmp/testdisk [root@ruanwenwu02 ~]# ls -ldh /tmp/testdisk -rw-r--r--. 1 root root 200M 11月 4 09:33 /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: 976 119 452 6 404 665 Swap: 1999 0 1999 [root@ruanwenwu02 ~]# swapon /tmp/testdisk swapon: /tmp/testdisk:不安全的权限 0644,建议使用 0600。 [root@ruanwenwu02 ~]# free -m total used free shared buff/cache available Mem: 976 119 452 6 404 664 Swap: 2199 0 2199 [root@ruanwenwu02 ~]# chmod 600 /tmp/testdisk [root@ruanwenwu02 ~]# free -m total used free shared buff/cache available Mem: 976 119 452 6 404 664 Swap: 2199 0 2199
如果要删除新增的空间,使用命令:
[root@ruanwenwu02 ~]# swapoff /tmp/testdisk [root@ruanwenwu02 ~]# free -m total used free shared buff/cache available Mem: 976 117 454 6 404 667 Swap: 1999 0 1999