首页 > 代码库 > Linux的tmpfs文件系统

Linux的tmpfs文件系统

转载:http://blog.csdn.net/wxwsixis/article/details/5752186

前几天发现服务器的内存(ram)和swap使用率非常低,于是就想这么多的资源,不用岂不浪费了?google了一下,认识了tmpfs,总的来说tmpfs是一种虚拟内存文件系统,正如这个定义它最大的特点就是它的存储空间在VM里面,这里提一下VM(virtual memory),VM是由linux内核里面的vm子系统管理的东东,现在大多数操作系统都采用了虚拟内存管理机制?更详细的说明请参考<<UnderStanding The Linux Virtual Memory Manager>)。

linux下面VM的大小由RM(Real Memory)和swap组成,RM的大小就是物理内存的大小,而Swap的大小是由你自己决定的。Swap是通过硬盘虚拟出来的内存空间,因此它的读写速度相对RM(Real Memory)要慢许多,我们为什么需要Swap呢?当一个进程申请一定数量的内存时,如内核的vm子系统发现没有足够的RM时,就会把RM里面的一些不常用的数据交换到Swap里面,如果需要重新使用这些数据再把它们从Swap交换到RM里面。 如果你有足够大的物理内存,根本不需要划分Swap分区。


通过上面的说明,你该知道tmpfs使用的存储空间VM是什么了吧? 前面说过VM由RM+Swap两部分组成,因此tmpfs最大的存储空间可达(The size of RM + The size ofSwap)。但是对于tmpfs本身而言,它并不知道自己使用的空间是RM还是Swap,这一切都是由内核的vm子系统管理的。

怎样使用tmpfs呢?

#mount -t tmpfs -o size=20m tmpfs /mnt/tmp

上面这条命令分配了上限为20m的VM到/mnt/tmp目录下,用df命令查看一下,确实/mnt/tmp挂载点显示的大小是20m,但是tmpfs一个优点就是它的大小是随着实际存储的容量而变化的,换句话说,假如/mnt/tmp目录下什么也没有,tmpfs并不占用VM。上面的参数20m只是告诉内核这个挂载点最大可用的VM为20m,如果不加上这个参数,tmpfs默认的大小是RM的一半,假如你的物理内存是128M,那么tmpfs默认的大小就是64M,


tmpfs有没有缺点呢?

当然有,由于它的数据是在VM里面,因此断电或者你卸载它之后,数据就会立即丢失,这也许就是它叫tmpfs的原故。不过这其实不能说是缺点。那tmpfs到底有什么用呢?


tmpfs的用途

由于tmpfs使用的是VM,因此它比硬盘的速度肯定要快,因此我们可以利用这个优点使用它来提升机器的性能。


#mount -t tmpfs -o size=2m tmpfs /tmp

上面这条命令分配了最大2m的VM给/tmp。

由于/tmp目录是放临时文件的地方,因此我们可以使用tmpfs来加快速度,由于没有挂载之前/tmp目录下的文件也许正在被使用,因此挂载之后系统也许有的程序不能正常工作。没有关系,只要在/etc/fstab里面加上下面的语句

tmpfs /tmp tmpfs size=2m 0 0

重启电脑之后就一切OK了。


强列建议你看看下面这篇文章。

http://www-128.ibm.com/developerworks/cn/linux/filesystem/l-fs3/


另外还可以参考

2.6内核里面的Documentation/filesystems/tmpfs.txt

总结:tmpfs和aufs文件系统结合使用,可以实现对只读文件系统的写操作,同时能够提高写效率。linux安装光盘中允许对软件的安装就是一个很好的应用。

Linux的tmpfs文件系统