查询资料所录,有不足欢迎补充
目录
### 错误检测:磁盘的整体数据存储在超级区块中,但每个文件的容量记载于inode当中,可用df或du命令查看,详解如下:
### 错误解析:
- 文件系统已满:所有的inode或者磁盘块都被使用完
- 小文件占用大量空间:由于Linux文件系统存在块分配的最小单位(如1KB),即使文件很小,它也会占用一个完整的块
- 磁盘碎片:文件可能分散存储在不同的物理位置,导致看起来空间总和不足
- 未删除的文件:即使文件被删除,它们的索引节点仍然在文件系统中,直到新的文件写入覆盖
### 错误检测:磁盘的整体数据存储在超级区块中,但每个文件的容量记载于inode当中,可用df或du命令查看,详解如下:
-
df:列出文件系统的整体磁盘使用量;
-a:列出所有的文件系统,包括系统特有的/proc等文件系统
-h:以人们较易阅读的GBytes、Mbytes、KBytes等格式自行显示
-i:不用磁盘容量,而以inode的数量来显示
- du:查看文件系统的磁盘使用量(常用于在查看目录所占磁盘空间);
-a:列出所有的文件与目录容量
-h:以人们较易读的容量格式(G/M)显示
-s:仅列出总量,而不列出每个个别的目录占用容量
### 解决方向:
- 使用df -Th命令查看磁盘使用情况
文件系统 类型 容量 已用 可用 已用% 挂载点
Filesystem Type Size Used Avail Use% Mounted on
devtmpfs devtmpfs 476M 0 476M 0% /dev
tmpfs tmpfs 487M 0 487M 0% /dev/shm
tmpfs tmpfs 487M 7.7M 479M 2% /run
tmpfs tmpfs 487M 0 487M 0% /sys/fs/cgroup
/dev/sda3 xfs 10G 7.1G 2.9G 71% /
/dev/sr0 iso9660 9.5G 9.5G 0 100% /media
/dev/sda1 xfs 197M 110M 88M 56% /boot
tmpfs tmpfs 98M 0 98M 0% /run/user/0注: /dev/sr0代表光驱,是写受保护的,通常是只读的,所以使用率是100%代表这个挂载点被这个光驱设备占用了,因此没有剩余空间
除此之外可以看到根分区的文件系统/dev/sda3已使用71%
B
可通过block和inode的区别_inode和block的区别-CSDN博客查看二者区别
#### ① block已满
1、若显示磁盘已用100%则代表磁盘已无剩余空间,可以通过如下操作解决:
第一种:删除不常用文件--也可将不常用的压缩包删掉
#进入根目录
cd /
#查看根目录下各文件夹大小情况并过滤1M及以上的进行排序
du -sh *|grep [MGT]|sort
#可选择删除/tmp/下的将不再使用的文件或目录
#下面命令中的file指"不再使用"的文件,dir指"不再使用"的目录
rm -rf /tmp/file
或rm -rf /tmp/dir
第二种:扩展分区--确定好根分区挂载的磁盘分区之后是否已经有分区存在,若没有则可扩展分区
进入虚拟机,选中 设置->添加->硬盘->SCSI->创建新虚拟磁盘->最大磁盘大小(GB)(S):20.0、将虚拟磁盘拆分成多个文件->默认文件名->完成->确定
#查看扩容前分区情况
df -Th
#查看是否有刚刚添加的分区--见代码段下图
fdisk -l
#分区
fdisk /dev/sdb
######
Command (m for help): n # 输"n"新建分区
Command action
e extended
p primary partition (1-4)
Partition number(1-4): 1 # 分区号,输"1"
Last cylinder,+cylinders or +size{K,M,G} (1-1044,default 1044): +1G # 输入"+1G"定义该分区大小
#其余皆默认操作"Enter"即可
Command (m for help): t # 输"t"改变类型
Hex code (type L to list all codes): 8e #修改分区ID为LVM的分区代码
#默认操作"Enter"即可
Command (m for help): w # 保存操作
######
#加载到内核
partx /dev/sdb1 或 partprobe /dev/sdb1
#格式化
mkfs.xfs /dev/sdb1
#查看分区结果
fdisk -l
#将新加的硬盘创建为物理卷(PV)--可用"vgdisplay"命令查看最终扩展的卷组大小
pvcreate /dev/sdb1
#查看上条命令是否有效
pvdisplay
#创建卷组(VG)--可用"vgdisplay"命令查看卷组,VG Name为卷组命名,为下面命令中的"centos"
vgcreate centos /dev/sdb1
##若卷组之前创建过则使用下条命令将物理卷加入卷组
# vgextend centos /dev/sdb1
#创建逻辑卷(LV)--创建一个名为"1v1",大小为100MB的逻辑卷,小分区可减少执行时间,该逻辑卷使用上面创建的卷组的空间
lvcreate -L 100M -n 1v1 centos
#格式化和挂载逻辑卷
mkfs.ext4 /dev/centos/1v1
##创建挂载目录
mkdir /lvm-mount
#挂载
mount /dev/centos/1v1 /lvm-mount/
#查看VG大小
vgdisplay
# 将新加的硬盘创建为物理卷--可以使用fdisk -l查看新加的磁盘是/dev/sdb'
pvceate /dev/sdb1
# 把物理卷加到卷组里
vgextend centos /dev/sdb1
#扩容lv,并查看pv,vg和lv状态--"/dev/sda3" 为需要扩容的根分区的文件系统
lvextend -l +100%FREE /dev/sda3
##查看pv,vg和lv状态
命令分别为:pvs vgs lvs
#扩容根分区的文件系统
xfs_growfs /dev/sda3
#查看扩容后分区情况,查看变化
df -Th
第三种(避免方法):通过写脚本及定时任务定时处理不常用文件
可通过“journalctl ”查看系统启动日志,查看是否有日志被占用
#创建放置脚本的目录
mkdir /data
cd /data
#编辑脚本--我的日志文件大都存在于/var/log/下,大家可根据自己需要写出日志文件目录
#注:里面比较重要的文件有“/var/log/messages”、“/var/log/wtmp”等,其他不重要的日志可以删除--经过查阅的结果,"*.log结尾的"放心删^-^
vim cleanLog.sh
######
find /var/log/ -name "*.log" -type f -print -exec truncate -s 0 {} \;
######
#为脚本添加可执行权限
chmod +x cleanLog.sh
#添加服务器定时任务
##编辑定时任务
crontab -e
######每天0点10分执行
10 0 * * * /data/cleanLog.sh
######
#查看定时任务是否生效
crontab -l
#### ②inode已满
#查看inode节点是否用完
df -i
第一种: 见block已满的第二种扩展分区方法,在增加磁盘空间的同时inode节点数会增加
注:inode节点数与磁盘大小成正比
第二种:修改inode数量占用百分比(仅适用于xfs)
#查看xfs文件系统信息--"/dev/sda3"使用我上面提到的block已满的例子
xfs_info /dev/sda3
#修改inode数量占用百分比(m的值越大,inode数越大)
xfs-growfs -m 30 /dev/sda3
第三种(不建议):删除 /data/cache目录中的部分文件,释放出/data分区的一部分inode
# /var/spool/mail 是要删除的文件所在的目录 -type f这个参数限定find只查找普通文件(即不是管道文件,不是块文件,不是链接文件,不是目录等),防止误删除系统文件。
find /var/spool/mail -type f -print -exec rm -f {} \;
##原因分析:系统中有用户开启了cron,而cron中执行的程序有输出内容,输出内容会以邮件形式发给cron的用户,而sendmail没有启动所以就产生了这些文件;
#### ③已删除的文件占用进程
#使用lsof命令查找打开文件的进程:
lsof | grep deleted
######
进程名 PID USER FD 文件类型 大小(字节) 索引节点 文件名 [(状态)]
mysqld 925 mysql 6u REG 8,3 0 8388674 /tmp/ibVXtA8h (deleted)
######
#使用kill命令终止进程--加进程号PID
kill -9 PID
以上是我罗列的no space解决方法,欢迎技高者提点,我继续补充!