来自公众号:运维研习社
在Linux运维过程中,经常会遇到某个应用的存储目录跑满,提前又没有做任何规划,目录或磁盘无法扩容,这个时候,我们常用的解决方法是做软链接,通过ln,将原先存储的目录软链接到另外大的磁盘中的目录下,以此达到目的。
软链的弊端就是,多层软链之后,会被绕晕,很容易造成误操作,今天再介绍一种方法
mount命令运维小伙伴应该很熟悉,不做过多介绍
先来看下man里面的介绍
通过mount --bind可以将文件目录结构重新挂载,连接两个目录,它是将前一个目录挂载到后一个目录上,所有对后一个目录的访问其实都是对前一个目录的访问
通过例子看下,分别创建两个不同的目录,并在两个不同的目录下创建不同的文件
查看文件的inode
通过mount --bind将test1挂载到test2上,重新查看inode和目录下内容
可以看到,inode号和文件,都是test1的
然后对test2目录下的文件访问修改,实际上改动的就是test1目录,我们测试下,在test2目录创建文件
然后接触mount之后,我们再查看下两个目录下的内容
可以看到,test1目录保持修改后的状态,test2目录文件仍然存在,且保持原来的不变
以mount --bind test1 test2为例,当mount --bind命令执行后,Linux将会把被挂载目录的目录项(也就是该目录文件的block,记录了下级目录的信息)屏蔽,即test2的下级路径被隐藏起来了(注意,只是隐藏不是删除,数据都没有改变,只是访问不到了)。同时,内核将挂载目录(test1)的目录项记录在内存里的一个s_root对象里,在mount命令执行时,VFS会创建一个vfsmount对象,这个对象里包含了整个文件系统所有的mount信息,其中也会包括本次mount中的信息,这个对象是一个HASH值对应表(HASH值通过对路径字符串的计算得来),表里就有 /test1 到 /test2 两个目录的HASH值对应关系
命令执行完后,当访问 /test2下的文件时,系统会告知 /test2 的目录项被屏蔽掉了,自动转到内存里找VFS,通过vfsmount了解到 /test2 和 /test1 的对应关系,从而读取到 /test1 的inode,这样在 /test2 下读到的全是 /test1 目录下的文件
两个目录的对应关系是存在于内存中的,一旦重启,挂载关系就没有了,所以需要将挂载关系,写入/etc/fstab中
以上就是mount --bind的简单介绍,更多使用方法,各位小伙伴可以自行尝试。
---END---