分区表
- MBR
- 管理的磁盘最大不能超过2TB
- 主分区加扩展分区不能超过四个,可以在扩展分区上创建逻辑分区,逻辑分区的个数没有限制,逻辑上是多个分区,但是物理分区还是在同一块
- GPT
- 管理磁盘的大小可以达到18EB
- 分区个数不受限
管理分区
- 列出磁盘块
lsblk
- 创建分区命令
fdisk 管理MBR分区
gdisk 管理GPT分区
parted 高级分区操作
fdisk工具
管理磁盘分区
fdisk [磁盘名称]
fdisk命令中的参数以及作用
参数 | 作用 |
---|---|
m | 查看全部可用的参数 |
n | 添加新的分区 |
d | 删除某个分区信息 |
l | 列出所有可用的分区类型 |
t | 改变某个分区的类型 |
p | 查看分区信息 |
w | 保存并退出 |
q | 不保存直接退出 |
首先关闭虚拟机,添加一块磁盘
fdisk /dev/sdb
操作完成添加完分区就可以通过lsblk查看到自己新建的分区了
但是分区完成后还要进行格式化操作
格式化分区:
mkfs.ext4 /dev/sdb1
mkfs.ext4 /dev/sdb2
修改挂载的配置文件
vim /etc/fstab
<需要挂载的设备> <挂载的目录> <文件系统> defaults 0 0
/dev/sdb1 /data1 ext4 defaults 0 0
创建挂载目录
可以重启实现加载配置文件,挂载设备,或者使用mount -a挂载
gdisk工具
- 类似fdisk的GPT分区工具
mkfs工具
- 全称为make file system,命令用于在特定分区上建立linux文件系统
实例
mkfs.xfs /dev/sdb1
磁盘管理
文件=元数据+数据内容
元数据包括文件的inode号以及文件属性等
挂载硬件设备
- mount
mount 文件系统 挂载目录
-a:挂载所有在/etc/fstab中定义的文件系统
-t:指定文件系统的类型
mount -a
临时挂载文件:系统在重启后挂载就会失效
mount /dev/sdb1 /data1
mount /dev/sdb2 /data2
如果想让硬件设备和目录永久地进行自动关联,就必须把挂载信息按照指定的填写格式“设备文件 挂载目录 格式类型 权限选项 是否备份 是否自检”,写入到/etc/fstab文件中。
实例,挂载分区 /dev/sdb1 到 /mnt/volume1 下,并且设置为永久自动挂载
[root@localhost ~]# mkdir -p /mnt/volume1
[root@localhost ~]# mount /dev/sdb1 /mnt/volume1
[root@localhost ~]# df -h
文件系统 容量 已用 可用 已用% 挂载点
/dev/mapper/centos-root 47G 995M 46G 3% /
devtmpfs 979M 0 979M 0% /dev
tmpfs 991M 0 991M 0% /dev/shm
tmpfs 991M 8.5M 982M 1% /run
tmpfs 991M 0 991M 0% /sys/fs/cgroup
/dev/sda1 1014M 133M 882M 14% /boot
tmpfs 199M 0 199M 0% /run/user/0
/dev/sdb1 9.1G 37M 8.6G 1% /mnt/volume1
[root@localhost ~]# vim /etc/fstab
# 最后一行加上
/dev/sdb1 /mnt/volume1 ext4 defaults 0 0
[root@localhost ~]# mount -a
# 测试是否正确配置
- umount,撤销已经挂载的设备文件 umount [挂载点/设备文件]
umount 挂载点
umount 设备文件
umount /data1
umount /dev/sdb2
du命令
查看文件数据占用量
du [选项] [文件]
du -sh /etc
添加硬盘设备
fdisk
fdisk 磁盘名称 管理磁盘分区
m:查看全部可用参数
n:添加新的分区
d:删除某个分区
l:列出所有可用的分区类型
p:查看分区信息
t:改变某个分区的类型
w:保存并退出
q:直接退出
blkid:查看设备的uuid
- 挂载磁盘的步骤
- 添加一块磁盘
- 使用fdisk对磁盘进行分区
- 使用mkfs对分区进行格式化
- 创建挂载点
- 使用mount命令进行挂载
df
查看某一个文件系统的挂载使用情况
-T:列出文件系统
-h:展示单位
du
查看某一个具体目录的大小
du 选项 文件
du -sh /*
添加交换分区
SWAP分区是一种通过在硬盘中预先划分的一定的空间,类似于虚拟内存,然后把内存中暂时不常用的数据临时存放到硬盘中,以便腾出物理内存空间让更活跃的程序服务来使用的技术
在生产环境中,交换分区的大小一般为真实物理内存的1.5~2倍
umount /dev/sdb2
mkswap /dev/sdb2
swapon /dev/sdb2 #挂载的作用
free -h #查看交换空间变大了
修改交换分区的配置文件/etc/fstab
vim /etc/fstab
/dev/sdb2 swap swap defaults 0 0
磁盘容量配额
quota命令还有软限制和硬限制的功能。
- 软限制:当达到软限制时会提示用户,但仍允许用户在限定的额度内继续使用
- 硬限制:当达到硬限制时会提示用户,且强制终止用户的操作
[root@localhost ~]# vim /etc/fstab
#
# /etc/fstab
# Created by anaconda on Fri Apr 12 04:20:38 2019
#
# 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
#
/dev/mapper/centos-root / xfs defaults 0 0
UUID=ff13d896-a59e-430d-8d14-3997d19f5de9 /boot xfs defaults,uquota 0 0
/dev/mapper/centos-swap swap swap defaults 0 0
/dev/sdb1 /data1 ext4 defaults 0 0
/dev/sdb2 swap swap defaults 0 0
[root@localhost ~]# reboot
[root@localhost ~]# mount | grep boot
/dev/sda1 on /boot type xfs (rw,relatime,seclabel,attr2,inode64,usrquota)
[root@localhost ~]# useradd test
[root@localhost ~]# chmod -Rf o+w /boot
由于/boot目录对其他用户有w的限制,对/boot 加入w权限
xfs_quota
专门针对XFS文件系统来管理quota磁盘容量配额服务
xfs_quota [参数] 配额 文件系统
参数:
-c参数用于以参数的形式设置要执行的命令
-x参数是专家模式
硬盘使用量的软限制和硬限制分别为3MB和6MB;创建文件数量的软限制和硬限制分别为3个和6个。
xfs_quota -x -c "limit bsoft=3m bhard=6m isoft=3 ihard=6 test" /boot
xfs_quota -x -c report /boot
[root@localhost ~]# su - test
[test@localhost ~]$ dd if=/dev/zero of=/boot/tom bs=5M count=1
1+0 records in
1+0 records out
5242880 bytes (5.2 MB) copied, 0.00350676 s, 1.5 GB/s
#if=文件名:输入文件名,默认为标准输入。即指定源文件。
#of=文件名:输出文件名,默认为标准输出。即指定目的文件。
#bs=bytes:同时设置读入/输出的块大小为bytes个字节。
#count=blocks:仅拷贝blocks个块,块大小等于ibs指定的字节数。
[test@localhost ~]$ dd if=/dev/zero of=/boot/tom bs=8M count=1
dd: 写入"/boot/tom" 出错: 超出磁盘限额
记录了1+0 的读入
记录了0+0 的写出
4194304字节(4.2 MB)已复制,0.0103877 秒,404 MB/秒
[test@localhost boot]$ touch file6
touch: 无法创建"file6": 超出磁盘限额
edquota
用于编辑用户的quota配额限制
edquota [参数] [用户]
参数:
-u:要针对哪个用户进行设置
-g:要针对哪个用户组进行设置
把用户test的硬盘使用量的硬限额从5MB提升到8MB
[root@localhost ~]# yum install -y quota
[root@localhost ~]# edquota -u test
Disk quotas for user test (uid 1001):
Filesystem blocks soft hard inodes soft hard
/dev/sda1 4096 3072 8192 1 3 6
[root@localhost ~]# su - test
Last login: Fri Apr 12 06:01:13 EDT 2019 on pts/0
[test@localhost ~]$ dd if=/dev/zero of=/boot/tom bs=8M count=1
1+0 records in
1+0 records out
8388608 bytes (8.4 MB) copied, 0.019578 s, 428 MB/s
[test@localhost ~]$ dd if=/dev/zero of=/boot/tom bs=10M count=1
dd: 写入"/boot/tom" 出错: 超出磁盘限额
记录了1+0 的读入
记录了0+0 的写出
8388608字节(8.4 MB)已复制,0.0130297 秒,644 MB/秒
软硬方式链接
在Linux系统中存在硬链接和软链接两种文件。
-
硬链接(hard link):
- 可以将它理解为一个“指向原始文件inode的指针”,系统不为它分配独立的inode和文件。所
以,硬链接文件与原始文件其实是同一个文件,只是名字不同。我们每添加一个硬链接,该文件的inode连接数就会增加1;而且只有当该文件的inode连接数为0时,才算彻底将它删除。换言之,由于硬链接实际上是指向原文件inode的指针,因此即便原始文件被删除,依然可以通过硬链接文件来访问。需要注意的是,由于技术的局限性,我们不能跨分区对目录文件进行链接。
- 可以将它理解为一个“指向原始文件inode的指针”,系统不为它分配独立的inode和文件。所
-
软链接(也称为符号链接[symbolic link]):
- 仅仅包含所链接文件的路径名,因此能链接目录文件,也可以跨越文件系统进行链接。但是,当原始文件被删除后,链接文件也将失效,从这一点上来说与Windows系统中的“快捷方式”具有一样的性质。
ln命令
用于创建链接文件
ln [选项] 目标
参数:
-s:创建"符号连接"(如果不带-s参数,则默认创建硬链接)
-f:强制创建文件或目录的链接
-i:覆盖前先询问
-v:显示创建链接的过程
- 软链接演示
echo "hello" > test
ln -s test testLink
cat testLink
ll #(两个文件大小不一样)
rm -f test
cat testLink
echo "test" > test
cat testLink
- 硬链接演示
rm testLink
ln test testHLink
ll #(大小一模一样)
rm test
cat testHlink