tmpfs:一种基于内存的文件系统

简介: tmpfs是一种基于内存的文件系统,   tmpfs有时候使用rm(物理内存),有时候使用swap(磁盘一块区域)。根据实际情况进行分配。   rm:物理内存。real memery的简称? 真实内存就是电脑主板上那块内存条,叫做真实内存不为过。

tmpfs是一种基于内存的文件系统,

 

tmpfs有时候使用rm(物理内存),有时候使用swap(磁盘一块区域)。根据实际情况进行分配。

 

rm:物理内存。real memery的简称? 真实内存就是电脑主板上那块内存条,叫做真实内存不为过。

swap:交换分区。是硬盘上一块区域

 

 

tmpfs最大可使用的大小为什么是rm+swap。

 

SWAP就是LINUX下的虚拟内存分区,它的作用是在物理内存使用完之后,将磁盘空间(也就是SWAP分区)虚拟成内存来使用.  它和Windows系统的交换文件作用类似,但是它是一段连续的磁盘空间,并且对用户不可见。

 

 

疑惑:window操作系统经常叫的虚拟内存和linux操作系统中的交换分区(swap)有什么区别?

 

一听说,虚拟内存,我常常就知道含义了。因为在学校使用window,我们可以自己设置虚拟内存的大小。可以随时调。实际上虚拟内存就是window系统下的一个这样的文件,如下:

 

 

 

每次看到交换分区,就一时不知道什么东西了。

 

现在整理一下

 

实际上,在window系统上叫做虚拟内存。而在linux操作系统的概念中叫做交换分区。实际上本质都是一样,都是虚拟内存。

 

后来看资料说,两个操作系统对于什么时候使用虚拟内存,是不同的。明显,linux的性能更好。

window平时也会使用虚拟内存。而linux只有在内存不足的时候才会用到虚拟内存?

 

原理基本都是一样的 区别就是windows即使物理内存没有用完也会去用到虚拟内存而Linux不一样。

​Linux只有当物理内存用完的时候才会去动用虚拟内存(即swap分区)这就是两者的区别。。。

windows的虚拟内存是电脑自动设置的

Linux的swap分区是我们装系统的时候分好的区,大小是固定了的(难怪叫做交换区,把它当成一个分区的概念了)

 

看设计思想的不同:

 

Linux 只不过是把交换文件设计为可以用分区而已,Linux 也可以用文件的。他们的区别就是实现方式不同而已。
Windows 的虚拟内存文件好处是可以动态变动大小,这个归系统自己管理的。

Windows 的虚拟内存设置默认好像是 50%-100% 内存在 C 盘上动态分配。Linux 没有这个自动的设计,但分区时安装程序会根据习惯自动分区出一个适合大小的 SWAP 分区。

Windows 的虚拟内存交换文件坏处是混在系统分区里面使用,文件碎片问题和容量变动问题都会影响交换文件的效率,Linux 因为是独立的分区,所以没有文件碎片和容量变动的问题。

Windows 其实也可以借用 Linux 的 SWAP 理念,单独分一个分区,只用来放 Windows 的虚拟内存交换文件。

 

 

 

总结:虚拟内存和交换分区,本质都是同一个东西,都是解决内存不够用时候,把硬盘当内存来使用。怎么个使用机制,window和linux稍微有不同。

 

 

 

 

tmpfs 的另一个主要的好处是它闪电般的速度。因为典型的 tmpfs 文件系统会完全驻留在 RAM 中,读写几乎可以是瞬间的。即使用了一些交换分区,性能仍然是卓越的,当更多空闲的 VM 资源可以使用时,这部分 tmpfs 文件系统会被移动到 RAM 中去。让 VM 子系统自动地移动部分 tmpfs 文件系统到交换分区实际上对性能上是好的,因为这样做可以让 VM 子系统为需要 RAM 的进程释放空间。这一点连同它动态调整大小的能力,比选择使用传统的 RAM 磁盘可以让操作系统有好得多的整体性能和灵活性。

 

 

 

我可以这么理解:tmpfs是一种文件系统,这种文件系统的特殊性在于,其有时候使用ram,有时候使用vm(虚拟内存,磁盘上的交换分区)

 

 

mount -t 文件类型 -o option  哪个设备  挂节点

 

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

 

mount tmpfs /dev/shm -t tmpfs -o size=32m 

 

 

 

设备:就是将哪个设备挂接到linux某个目录去。这里是将tmpfs设备挂接到 /mnt/tmp中去。

这样操作/mnt/tmp目录实际上就是操作tmpfs设备了。

 

tmpfs为什么变成一个设备了呢?

 

vm子系统做管理工作。虚拟内存。

 

参考光盘文件的挂接加深理解:

光盘镜像文件的挂接(mount)
 #mkdir /mnt/vcdrom
 注:建立一个目录用来作挂接点(mount point)

#mount -o loop -t iso9660 /home/sunky/mydisk.iso /mnt/vcdrom
 注:使用/mnt/vcdrom就可以访问盘镜像文件mydisk.iso里的所有文件了。

 

可以这里理解挂节点:linux上的一个目录,就是挂节点,要把一个设备挂接到挂节点上。

 

 

 

目录
相关文章
|
缓存 Java API
分布式内存文件系统Alluxio(下)
分布式内存文件系统Alluxio(下)
579 0
分布式内存文件系统Alluxio(下)
|
Docker 容器
分布式内存文件系统Alluxio(上)
分布式内存文件系统Alluxio(上)
466 0
分布式内存文件系统Alluxio(上)
|
关系型数据库 Linux 数据库
linux 内存文件系统使用 - tmpfs, ramfs, shmfs
linux 内存文件系统使用 - tmpfs, ramfs, shmfs
2871 0
|
弹性计算 关系型数据库 Linux
linux 内存文件系统使用 - tmpfs, ramfs, shmfs
标签 PostgreSQL , hugetlbfs , hugepage , memory filesystem , ramfs , tmpfs , shmfs 背景 在做一些测试时,如果IO设备很烂的话,可以直接使用内存文件系统,避免IO上引入的一些开销影响测试结果。 用法很简单: tmpfs or shmfs mount a shmfs with a certain size
3044 0
|
Linux
Linux 更改共享内存tmpfs的大小
通过挂载的方式在原有目录或新建目录改造 如: [root@luozhonghua /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/vg_luozhonghua-lv_root 21G 4.
1520 0
|
Java C++
[LeetCode] Design In-Memory File System 设计内存文件系统
Design an in-memory file system to simulate the following functions: ls: Given a path in string format.
1861 0
|
存储 缓存 应用服务中间件
Infinispan's GridFileSystem--基于内存的网格文件系统,互联网营销
  Infinispan是JBoss Cache缓存框架的后续项目,它是一个开源的数据网格平台,用于访问分布式状态的群集节点。GridFileSystem(网格文件系统)是一个全新的实验性的API,这些API使Infinispan后端的网格数据像文件系统一样展示出来。
1281 0