第十四章 文件系统和磁盘设备管理





14.1 文件系统和磁盘设备的管理与使用


磁盘设备

磁盘设备是支持随机读写数据的设备.


在物理机器上,设备文件默认都存放在/dev/目录下,第一个硬盘是/dev/sda,第二个硬盘是/dev/sdb,如此类推.第一个硬盘的第一个分区是/dev/sda1,第二个分区是/dev/sda2,如此类推.


在xen或kvm的虚拟机上,硬盘的名字则是/dev/xvda或/dev/vda等,如此类推


           有些存放数据的设备并不是直接硬件对应的设备文件,而是通过软件生成的块设备文件 例如lvm和软raid设备文件。




文件系统


建立在磁盘设备之上,让系统支持以文件、目录的形式访问设备的数据。



# df -h


# du /root


# du -sh /var/log




文件系统的挂载与卸载

要以目录、文件的形式访问设备上的数据,设备必须使用文件系统格式化。格式化后方等挂载使用。


# blkid 

# blkid /dev/vda1


挂载(server0)

# mount /dev/vdb1  /mnt/mydata

# mount UUID="xxxx"  /mnt/mydata


# cd /mnt/mydata

# umount /mnt/mydata 会失败,提示设备忙

# lsof /mnt/mydata

# cd 

# umount /mnt/mydata


练习:在server0上完成文件系统挂载



1) 执行lab fs setup 部署实验环境



2) 查看设备id

# blkid

/dev/vda1: UUID="9bf6b9f7-92ad-441b-848e-0257cbb883d1" TYPE="xfs" 

/dev/vdb1: UUID="72e49c5f-e0fe-4dfd-9245-9d93aac34d18" TYPE="xfs" 




3) 新建目录/mnt/newspace,

并且把其中一个设备挂载到此目录


# mkdir /mnt/newspace


# mount /dev/vdb1 /mnt/newspace

 

# df -h

文件系统        容量  已用  可用 已用% 挂载点

....

/dev/vdb1       509M   26M  483M    6% /mnt/newspace




4)进入到该目录并新建目录newdir,并在新建的目录下新建文件

# cd /mnt/newspace/

# mkdir newdir

# touch newdir/newfile

# cp /etc/fstab   /mnt/newspace/newdir/

# ls -l /mnt/newspace/newdir/

总用量 4

-rw-r--r--. 1 root root 313 1月  29 19:08 fstab

-rw-r--r--. 1 root root   0 1月  29 19:08 newfile



5) 退出挂载目录并且取消挂载


# umount /mnt/newspace/

umount: /mnt/newspace:目标忙。

        退出所在目录

(有些情况下通过 lsof(8) 或 fuser(1) 可以

 找到有关使用该设备的进程的有用信息)



# lsof /mnt/newspace/

COMMAND  PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME

bash    1633 root  cwd    DIR 253,17       19  128 /mnt/newspace

lsof    1956 root  cwd    DIR 253,17       19  128 /mnt/newspace

lsof    1957 root  cwd    DIR 253,17       19  128 /mnt/newspace


# cd 

# pwd

/root

# umount /mnt/newspace/





6) 强烈建议使用uuid进行挂载


# blkid

/dev/vda1: UUID="9bf6b9f7-92ad-441b-848e-0257cbb883d1" TYPE="xfs" 

/dev/vdb1: UUID="72e49c5f-e0fe-4dfd-9245-9d93aac34d18" TYPE="xfs"   获得uuid



# mount UUID="72e49c5f-e0fe-4dfd-9245-9d93aac34d18" /mnt/newspace




持久化挂载: 在RH134会讲到







14.2 管理链接文件



字符链接文件(软链接文件)


相当于windows的快捷方式文件


它是一个独立的文件,该文件指向另一个文件


它占用磁盘空间


可以跨文件系统创建


可以对目录建立字符链接文件


硬链接文件


相当于同一份数据多个名字,拥有原文件的一些属性,仅仅是路径不同。


它不会另外占用磁盘空间


起到文件数据冗余的作用


仅仅支持同一个文件系统的文件创建硬链接


不支持对目录创建



创建硬链接文件

# echo "Hello World" > newfile.txt

# ls -l newfile.txt



# ln newfile.txt /tmp/newfile-hlink.txt

# ls -l newfile.txt /tmp/newfile-hlink.txt



# rm -f newfile.txt

# ls -l /tmp/newfile-hlink.txt

# cat /tmp/newfile-hlink.txt



创建字符链接文件


# ln -s /tmp/newfile-hlink.txt /tmp/newfile-symlink.txt


# ls -l /tmp/newfile-hlink.txt /tmp/newfile-symlink.txt



# rm -f /tmp/newfile-hlink.txt


# ls -l  /tmp/newfile-symlink.txt


# cat /tmp/newfile-symlink.txt


# ln -s /etc /root/configfiles

# cd /root/configfiles

# pwd






查找文件



# updatedb  用于扫描系统的文件,并保存在一个文件中,   man update可以看到  放在/var/...中,所以查看很快,新下载的则不会,需要再次输入这个命令

# locate passwd


# locate -i messages

  不区分大小写

# locate -n 5 snow.png




# find / -name sshd_config


# find / -iname '*.txt'


# find /etc/ -name '*pass*'


# find / -iname '*messages*'



# find /home/student  -user student

# find /home/student -group student


# find /home/student -gid 1000

# find /  -user root -group mail


# find /home -perm 764  完全匹配权限

# find /home -perm -324 拥有者至少有011(-wx),组010(-w-),其他人100(r--)


# find /home -perm /442 拥有者至少有r,或者组成员至少由r,或者其他人至少有w权限



# find /home/student -size 10M  等于10M

# find /home/student -size +10G 大于10G


# find /home/student -size -10k 少于10k



# find / -mmin 120  离修改时间刚好是120分钟


# find / -mmin +200 已经修改超过200分钟

# find / -mmin -150 离修改时间少于150分钟



# find /etc -type d


# find /etc -type l


# find /dev -type b


# find /usr -type f -links +1 查找所有硬链接数超过1的文件



把查找到满足条件的文件进一步处理


# mkdir /tmp/bin


# find /usr/bin -size +50k -exec cp {} /tmp/bin \;























=========================================================================================


[root@localhost Desktop]# df -h

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda1        10G  3.1G  7.0G  31% /

devtmpfs        475M     0  475M   0% /dev

tmpfs           490M  140K  490M   1% /dev/shm

tmpfs           490M  832K  490M   1% /run

tmpfs           490M     0  490M   0% /sys/fs/cgroup



14.2

[root@localhost Desktop]# ls -li /

total 32

     781 lrwxrwxrwx.   1 root root    7 May  7  2014 bin -> usr/bin  你访问他是访问文件他指向的文件,有自己的大小,权限宿主,空间。

     160 dr-xr-xr-x.   4 root root 4096 Jul 11  2014 boot

       3 drwxr-xr-x.  19 root root 3080 Jun 11 12:13 dev

     132 drwxr-xr-x. 133 root root 8192 Jun 11  2017 etc

25165973 drwxr-xr-x.   3 root root   20 Jul 11  2014 home

     785 lrwxrwxrwx.   1 root root    7 May  7  2014 lib -> usr/lib

     162 lrwxrwxrwx.   1 root root    9 May  7  2014 lib64 -> usr/lib64

     167 drwxr-xr-x.   2 root root    6 Mar 13  2014 media

 8388761 drwxr-xr-x.   3 root root   21 Jun 11 12:18 mnt

16818322 drwxr-xr-x.   3 root root   15 Jul 11  2014 opt

       1 dr-xr-xr-x. 488 root root    0 Jun 11  2017 proc

 8388737 dr-xr-x---.  14 root root 4096 Jun 11 12:15 root

    8547 drwxr-xr-x.  35 root root 1140 Jun 11 12:32 run

     786 lrwxrwxrwx.   1 root root    8 May  7  2014 sbin -> usr/sbin

25165974 drwxr-xr-x.   2 root root    6 Mar 13  2014 srv

       1 dr-xr-xr-x.  13 root root    0 Jun 11  2017 sys

16818305 drwxrwxrwt.  22 root root 4096 Jun 11 12:18 tmp

     158 drwxr-xr-x.  13 root root 4096 May  7  2014 usr

25165953 drwxr-xr-x.  22 root root 4096 Jun 11  2017 var

[root@localhost Desktop]# 



[root@localhost Desktop]# locate passwd   

/etc/passwd

/etc/passwd-

/etc/pam.d/passwd

/etc/security/opasswd

/usr/bin/gpasswd





locate -i message  不区分大小写



find 考试必考,

找一个文件 ,并属于哪个人,再CP一份到指定的目录







# find / -name sshd_config


 名

# find / -iname '*.txt'


不区分大小写

 # find /etc/ -name '*pass*'


这个文件的路径中包括pass都找出来

# find / -iname '*messages*'


不区分大小写


# find /home/student  -user student


 找属于student的文件


# find /home/student -group student


这个组有的文件 

# find /home/student -gid 1000

 按ID去找

# find /  -user root -group mail


写多个条件去查找


# find /home -perm 764  完全匹配权限


  按照文件权限模式用-perm选项,按文件权限模式来查找文件的话。。


# find /home -perm -324 拥有者至少有011(-wx),组010(-w-),其他人100(r--)


# find /home -perm /442 拥有者至少有r,或者组成员至少由r,或者其他人至少有w权限



# find /home/student -size 10M  等于10M

# find /home/student -size +10G 大于10G


# find /home/student -size -10k 少于10k



# find / -mmin 120  离修改时间刚好是120分钟


# find / -mmin +200 已经修改超过200分钟

# find / -mmin -150 离修改时间少于150分钟



# find /etc -type d


# find /etc -type l


# find /dev -type b


# find /usr -type f -links +1 查找所有硬链接数超过1的文件



把查找到满足条件的文件进一步处理



# mkdir /tmp/bin


# find /usr/bin -size +50k -exec cp {} /tmp/bin \;





















  找到并执行cp命令