第1章 磁盘空间不足

实例1-1             no space left on device 原因 如何排查与解决

1.inode  df -i ; 找出系统中目录大小大于1M   确认之后 删除大量小文件

2.block  df -h ; du -sh 一层一层查找         确认之后 删除文件

第2章 文件属性

2.1 文件类型:

2.1.1 扩展名

.conf            配置文件

.sh               脚本

.tar.gz          压缩包

.py              python脚本

2.1.2 文件类型:

1.二进制文件(命令)

2.文本文件(text

3.数据文件(data)需要单独命令查看

f          file                 文件

d          dir                 目录

l           softlink          软连接

b    block       块设备

c    character         字符设备

p    pipe                 管道

s    socket              套接字

[root@oldboyedu50-lnb /tmp]# file  /bin/ls /etc/hosts /tmp/etc-pai.tar.gz

/bin/ls:             ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.18, stripped

/etc/hosts:          ASCII text

/tmp/etc-pai.tar.gz: gzip compressed data, from Unix, last modified: Fri Jul 20 02:39:55 2018

 [root@oldboyedu50-lnb /tmp]# ll  etc.tar.gz

-rw-r--r-- 1 root root 9734648 Jul 20 01:41 etc.tar.gz

[root@oldboyedu50-lnb /tmp]# mv etc.tar.gz etc.txt

[root@oldboyedu50-lnb /tmp]# ll etc.txt

-rw-r--r-- 1 root root 9734648 Jul 20 01:41 etc.txt

2.2 文件权限

r----read       可读     4

w----write      可写     2

x----execute    可执行   1

-                        0

2.2.1 权限的计算

-rw-    r--     r-- 2 root root 186 Jul 26 11:19 /etc/hosts

 420    400     400

 6      4       4

1.字符转换数字

-rw-r-----          640

-r--r--r--            444

-rw-r--r--           644

-rw-------          600

2.数字转换字符

644             -rw-r--r--

755             -rwxr-xr-x

400             -r--------

640             -rw-r-----

2.3 链接:

软连接(softlink  符号链接 symlink   硬链接  (hard link)

2.3.1 硬链接:

在同一个磁盘分区中,文件的inode号码相同,互为硬链接

1.特点  同一个分区中  inode相同的文件,互为硬链接

2.防止误删除

3.彻底删除一个文件条件:

 文件硬链接数为0rm

创建硬链接 ln命令创建

 [root@oldboyedu50-lnb /oldboy]# echo oldboyedu.com > oldboy.txt

[root@oldboyedu50-lnb /oldboy]# ll oldboy.txt

-rw-r--r-- 1 root root 14 Jul 27 21:49 oldboy.txt

[root@oldboyedu50-lnb /oldboy]# ln oldboy.txt  oldboy.txt-hard

[root@oldboyedu50-lnb /oldboy]# ll oldboy.txt

-rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt

[root@oldboyedu50-lnb /oldboy]# ll -i oldboy.txt oldboy.txt-hard

1046996 -rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt

1046996 -rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt-hard

2.3.2 软连接:

相当于windows快捷方式 存放的源文件的位置

创建软连接

[root@oldboyedu50-lnb /oldboy]# ln  -s   oldboy.txt   oldboy.txt-soft

[root@oldboyedu50-lnb /oldboy]# ls -l  oldboy.txt*

-rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt

-rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt-hard

lrwxrwxrwx 1 root root 10 Jul 27 22:09 oldboy.txt-soft -> oldboy.txt

[root@oldboyedu50-lnb /oldboy]# ls -l  oldboy.txt*

-rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt-hard

lrwxrwxrwx 1 root root 10 Jul 27 22:09 oldboy.txt-soft -> oldboy.txt

lrwxrwxrwx 1 root root 18 Jul 27 22:16 oldboy.txt-soft2 -> /oldboy/oldboy.txt

[root@oldboyedu50-lnb /oldboy]# mv alex.txt oldboy.txt

[root@oldboyedu50-lnb /oldboy]# ls -l  oldboy.txt*

-rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt

-rw-r--r-- 2 root root 14 Jul 27 21:49 oldboy.txt-hard

lrwxrwxrwx 1 root root 10 Jul 27 22:09 oldboy.txt-soft -> oldboy.txt

lrwxrwxrwx 1 root root 18 Jul 27 22:16 oldboy.txt-soft2 -> /oldboy/oldboy.txt

2.4 文件删除原理:

1.硬连接数为0    rm

2.进程调用数为0 是否有人使用

2.4.1 如何查看 被占用的文件                    

lsof |grep oldboy.txt           tail -f /oldboy/oldboy.txt

list open files    

[root@oldboyedu50-lnb /oldboy]# lsof |grep oldboy.txt

tail    3755   root    3r    REG      8,3      14   1046996    /oldboy/oldboy.txt

命令或服务名称                                 文件大小         inode号码 文件名

实例2-1             模拟 文件没有被彻底删除(i_link)0 进程调用数(i_count)不为0

seq 500000000 >>/var/log/messages

1.查看磁盘使用

[root@oldboyedu50-lnb /oldboy]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3        19G   17G  1.1G  95% /

tmpfs           931M     0  931M   0% /dev/shm

/dev/sda1       190M   40M  141M  22% /boot

/dev/sdc         73K   14K   55K  21% /app/logs

 

[root@oldboyedu50-lnb /oldboy]# du -sh /*|sort -h |tail -1

16G /var

[root@oldboyedu50-lnb /oldboy]# du -sh /var/*|sort -h|tail -1

16G /var/log

[root@oldboyedu50-lnb /oldboy]# du -sh /var/log/*|sort -h|tail -1

16G /var/log/messages

 

2.删除这个文件

[root@oldboyedu50-lnb /oldboy]# ll /var/log/messages

-rw------- 1 root root 16197811985 Jul 27 23:00 /var/log/messages

[root@oldboyedu50-lnb /oldboy]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3        19G   17G  1.1G  95% /

tmpfs           931M     0  931M   0% /dev/shm

/dev/sda1       190M   40M  141M  22% /boot

/dev/sdc         73K   14K   55K  21% /app/logs

[root@oldboyedu50-lnb /oldboy]# \rm -f /var/log/messages

 

3.磁盘空间不足  继续通过du -sh 排查

[root@oldboyedu50-lnb /oldboy]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3        19G   17G  1.1G  95% /

tmpfs           931M     0  931M   0% /dev/shm

/dev/sda1       190M   40M  141M  22% /boot

/dev/sdc         73K   14K   55K  21% /app/logs

[root@oldboyedu50-lnb /oldboy]# du -sh /* |sort -h |tail

du: cannot access `/proc/3800/task/3800/fd/4': No such file or directory

du: cannot access `/proc/3800/task/3800/fdinfo/4': No such file or directory

du: cannot access `/proc/3800/fd/4': No such file or directory

du: cannot access `/proc/3800/fdinfo/4': No such file or directory

376K   /root

7.6M   /bin

16M /sbin

27M /lib64

30M /etc

38M /boot

80M /var

114M   /tmp

214M   /lib

1.1G   /usr

 

4. 原因:文件没有被彻底删除

       找出这个被占用文件

[root@oldboyedu50-lnb /oldboy]# lsof |grep messages

rsyslogd  1412      root    4w      REG                8,3 16197811985     392705 /var/log/messages (deleted)

 

5.解决

#deleted  lsof标记  表示文件硬链接数为0  进程调用数不为0

#进程调用数为0 ==== 重启服务/软件

[root@oldboyedu50-lnb /oldboy]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3        19G   17G  1.1G  95% /

tmpfs           931M     0  931M   0% /dev/shm

/dev/sda1       190M   40M  141M  22% /boot

/dev/sdc         73K   14K   55K  21% /app/logs

[root@oldboyedu50-lnb /oldboy]# /etc/init.d/rsyslog restart

Shutting down system logger:                               [  OK  ]

Starting system logger:                                    [  OK  ]

[root@oldboyedu50-lnb /oldboy]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3        19G  1.6G   17G   9% /

tmpfs           931M     0  931M   0% /dev/shm

/dev/sda1       190M   40M  141M  22% /boot

/dev/sdc         73K   14K   55K  21% /app/logs

[root@oldboyedu50-lnb /oldboy]# lsof |grep messages

rsyslogd  3828      root    1w      REG                8,3      229     392660 /var/log/messages