Linux——内存文件系统

Linux内存文件系统:可满足高IO的要求

  • ramdisk: 基于虚拟在内存中的其他文件系统(ex2fs)。
    • 挂载方式:mount /dev/ram /mnt/ramdisk
  • ramfs: 物理内存文件系统,只存在于物理内存中。其大小也不是固定的,而是随着所需要的空间动态得增减。
    • 挂载方式:mount -t ramfs none /mnt/ramfs -o maxsize=2000
  • tmpfs: 虚拟内存文件系统,不同于块设备形式实现的ramdisk, 也不同于真对物理内存实现的ramfs 文件系统。
    • tmpfs 可以使用物理内存,也能使用交换分区。
    • 挂载方式:mount tmpfs /mnt/tmpfs -t tmpfs -o size=32m

注意:最好有虚拟内存管理系统,用来分配内存中的文件系统空间。

关于tmpfs的使用:

tmpfs是一种虚拟内存文件系统正如这个定义它最大的特点就是它的存储空间在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 of Swap)。 但是对于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了。

测试过程:

 

[root@localhost shm]# df -h

Filesystem            Size  Used Avail Use% Mounted on

/dev/sda1             852G  325G 483G  41% /

tmpfs                  16G     0  16G   0% /dev/shm

/dev/md0              1.8T  506G 1.3T  30% /opt

[root@localhost shm]#

[root@localhost shm]# mount -t tmpfs -osize=2048M tmpfs /mnt/ram/

[root@localhost shm]#

[root@localhost shm]# df -h

Filesystem            Size  Used Avail Use% Mounted on

/dev/sda1             852G  325G 483G  41% /

tmpfs                  16G     0  16G   0% /dev/shm

/dev/md0              1.8T  506G 1.3T  30% /opt

tmpfs                 2.0G     0 2.0G   0% /mnt/ram

[root@localhost shm]#

[root@localhost shm]#

[root@localhost chairly]#cp codeblocks-8.02-src.tar.bz2 /mnt/ram/

[root@localhost ram]#

[root@localhost ram]# df -h

Filesystem            Size  Used Avail Use% Mounted on

/dev/sda1             852G  325G 483G  41% /

tmpfs                  16G     0  16G   0% /dev/shm

/dev/md0              1.8T  506G 1.3T  30% /opt

tmpfs                 2.0G  6.6M 2.0G   1% /mnt/ram

[root@localhost ram]#

[root@localhost ram]# free

            total       used       free    shared    buffers     cached

Mem:     32818744    3167792   29650952          0    128844    2710972

-/+ buffers/cache:     327976  32490768

Swap:    35005624          0   35005624

[root@localhost ram]#

[root@localhost ram]# rm *

rm: remove regular file`codeblocks-8.02-src.tar.bz2'? y

[root@localhost ram]#

[root@localhost ram]# free

            total       used       free    shared    buffers     cached

Mem:     32818744    3161160   29657584          0    128856    2704292

-/+ buffers/cache:     328012  32490732

Swap:    35005624          0   35005624

[root@localhost ram]#

 

 在/mnt/ram下无法使用dd命令测试硬盘读写速度。总是报dd: opening `/mnt/ram/write.dat': Invalid argument。

 

文章原地址:

https://www.cnblogs.com/xuyaowen/archive/2018/11/06/ram-fs.html

https://www.linuxidc.com/Linux/2011-09/42396.htm

你可能感兴趣的:(Linux,C语言,Linux,内存,文件系统,虚拟,挂载)