理论+实践来认识/dev/shm(共享内存目录)
来源:互联网 发布:如何优化百度推广排名 编辑:程序博客网 时间:2024/05/21 08:39
一、/dev/shm理论
/dev/shm/是linux下一个非常有用的目录,因为这个目录不在硬盘上,而是在内存里。因此在linux下,就不需要大费周折去建ramdisk,直接使用/dev/shm/就可达到很好的优化效果。 /dev/shm/需要注意的一个是容量问题,在linux下,它默认最大为内存的一半大小,使用df -h /dev/shm/命令可以看到。但它并不会真正的占用这块内存,如果/dev/shm/下没有任何文件,它占用的内存实际上就是0字节;如果它最大为1G,里头放有 100M文件,那剩余的900M仍然可为其它应用程序所使用,但它所占用的100M内存,是绝不会被系统回收重新划分的,否则谁还敢往里头存文件呢?
默认系统就会加载/dev/shm ,它就是所谓的tmpfs,有人说就是ramdisk(虚拟磁盘),但不一样。象虚拟磁盘一样,tmpfs 可以使用您的 RAM,但它也可以使用您的交换分区来存储。而且传统的虚拟磁盘是个块设备,并需要一个 mkfs 之类的命令才能真正地使用它,tmpfs 是一个文件系统,而不是块设备;您只是安装它,它就可以使用了。
tmpfs有以下优势:
- 动态文件系统的大小。
- tmpfs 的另一个主要的好处是它闪电般的速度。因为典型的 tmpfs 文件系统会完全驻留在 RAM 中,读写几乎可以是瞬间的。
- tmpfs 数据在重新启动之后不会保留,因为虚拟内存本质上就是易失的。所以有必要做一些脚本做诸如加载,绑定的操作。
二、修改/dev/shm大小
默认的最大一半内存大小在某些场合可能不够用,并且默认的inode数量很低一般都要调高些,这时可以用mount命令来管理它。
#mount -o size=1500M -o nr_inodes=1000000 -o noatime,nodiratime -o remount /dev/shm
在2G的机器上,将最大容量调到1.5G,并且inode数量调到1000000,这意味着大致可存入最多一百万个小文件。
如果需要永久修改/dev/shm的值,需要修改/etc/fstab
tmpfs /dev/shm tmpfs defaults,size=1.5G 0 0
#mount -o remount /dev/shm
三、/dev/shm应用
首先在/dev/shm建个tmp文件夹,然后与实际/tmp绑定
#mkdir /dev/shm/tmp
#chmod 1777 /dev/shm/tmp
#mount –bind /dev/shm/tmp /tmp(–bind )
在使用mount –bind olderdir newerdir命令来挂载一个目录到另一个目录后,newerdir的权限和所有者等所有信息会发生变化。挂载后的目录继承了被挂载目录的所有属性,除了名称。Oracle 11g的amm内存管理模式就是使用/dev/shm,所以有时候修改MEMORY_TARGET或者MEMORY_MAX_TARGET会出现ORA-00845的错误。
注:以上一至三点来自:http://www.xifenfei.com/1605.html
四、/dev/shm速度测试
试想,如果使用dd命令测试硬盘写入速度,那么同样可以写入一个文件到/dev/shm/,vpsdog在自己的一个512M内存的VPS上简单做了个测试,使用如下命令写入一个200M文件到硬盘和/dev/shm/中:
- dd if=/dev/zero of=~/test bs=1M count=200
- rm -f ~/test
- dd if=/dev/zero of=/dev/shm/test bs=1M count=200
- rm -f /dev/shm/test
结果写入硬盘:343 MB/s;写入/dev/shm/:1.2 GB/s。这2个数值仅仅只能作为参考,但是可以肯定的是写入内存的速度是远远大于写入硬盘的速度。另外,可以写入到/dev/shm/最大的容量取决于df -h /dev/shm/命令所看到的大小(默认为内存的一半大小)。
- 理论+实践来认识/dev/shm(共享内存目录)
- 共享内存(shm)
- /dev/shm理论
- /dev/shm理论
- 对 /dev/shm 认识
- 对 /dev/shm 认识
- 对 /dev/shm 认识
- 认识/dev/shm
- /dev/shm目录
- 对/dev/shm的认识
- Linux下/dev/shm目录
- IPC-shm 共享内存
- shm创建共享内存
- 共享内存 shm
- 共享内存 shm
- linux shm共享内存
- linux shm共享内存
- IPC共享内存 shm
- 解决:Disk /dev/sd doesn't contain a valid partition table
- struts2服务器跳转和客户端跳转之区别
- MSP430 中断优先级
- c/c++软件开发的注意事项
- Java中堆和栈的区别
- 理论+实践来认识/dev/shm(共享内存目录)
- 二叉树的递归创建&遍历
- java break,continue,return 使用。【借鉴与改编】
- Oracle ASM 详解
- explicit关键字的作用
- 简单实现后台订单页面 上一单,下一单 的按钮
- Javascript之BOM详解
- Android之 MediaPlayer播放一般音频与SoundPool播放短促的音效
- Oracle Database 11g Release 2 RAC On Linux Using VMware Server 2