技术流ken

运维拯救世界

Linux的tmpfs文件系统–技术流ken

tmpfs简介

总的来说tmpfs(temporary file system)是一种虚拟内存文件系统,正如这个定义它最大的特点就是它的存储空间在VM里面,这里提一下VM(virtual memory),VM是由linux内核里面的vm子系统管理的东东,现在大多数操作系统都采用了虚拟内存管理机制。

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呢?

[root@ken3 ~]# mount -t tmpfs -o size=200M tmpfs /mnt/ken
[root@ken3 ~]# df -h
文件系统             容量  已用  可用 已用% 挂载点
/dev/mapper/cl-root  274G  1.2G  273G    1% /
devtmpfs              63G     0   63G    0% /dev
tmpfs                 63G     0   63G    0% /dev/shm
tmpfs                 63G   25M   63G    1% /run
tmpfs                 63G     0   63G    0% /sys/fs/cgroup
/dev/sda1           1014M  141M  874M   14% /boot
tmpfs                 13G     0   13G    0% /run/user/0
tmpfs                200M     0  200M    0% /mnt/ken

 

上面这条命令分配了上限为200m的VM到/mnt/ken目录下,用df命令查看一下,确实/mnt/ken挂载点显示的大小是200m,但是tmpfs一个优点就是它的大小是随着实际存储的容量而变化的,换句话说,假如/mnt/ken目录下什么也没有,tmpfs并不占用VM。上面的参数200m只是告诉内核这个挂载点最大可用的VM为200m,如果不加上这个参数,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了。

发表评论

电子邮件地址不会被公开。