zoukankan      html  css  js  c++  java
  • Linux把内存挂载成硬盘提高读写速度

    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.linuxidc.com/Linux/2011-09/42396.htm

  • 相关阅读:
    SpringBoot校验(validation)
    序列化/反序列化
    全面的整理了原生js
    apache commons工具类简介
    刚从git上download的代码,有个工具类中某个类找不到
    Hadoop(三)手把手教你搭建Hadoop全分布式集群
    Hadoop(一)之初识大数据与Hadoop
    Hadoop(二)搭建伪分布式集群
    Git(一)之基本操作详解
    Git(二)Git几个区的关系与Git和GitHub的关联
  • 原文地址:https://www.cnblogs.com/djoker/p/8822376.html
Copyright © 2011-2022 走看看