Linux上的所有tmpfs实例是否共享相同的内存池?

问题描述 投票:0回答:1

我有嵌入式Linux系统,它在fstab中定义了几个tmpfs挂载。其中一些安装涉及systemd。

客户问为什么不存在所有易失性“RAM FS”的东西。

问题:

  1. 是否为来自相同公共源(缓存或其他)的所有tmpfs实例分配了物理内存,以便我们不必手动管理它?
  2. 当删除一个tmpfs挂载上的文件时,其他挂载可以重用内存吗?
  3. 有没有Linux风格(或配置选项)静态分配tmpfs的内存?
  4. tmpfs是否在内核中分配虚拟内存空间或使用与定义的tmpfs大小成比例的其他宝贵资源?
linux tmpfs
1个回答
2
投票

引自man tmpfs

  1. The tmpfs [...] contents reside in virtual memory. Virtual memory是一个很大的话题,你可以在网上浏览它。物理内存的来源可能是RAM(我不知道你是将不同的RAM模块作为不同的来源计算),还是来自swap或来自任何其他来源,如果你为它编写驱动程序。虚拟内存建立在其上。内存可以“动态”zswap压缩,并有更多的未来(如删除重复KSM等),所以它不像5MB的虚拟内存是5MB的物理内存。我想每个tmpfs mountpoint都有自己的虚拟内存地址空间,但我认为这取决于实现。
  2. The [tmpfs] consumes only as much physical memory and swap space as is required to store the current contents of the filesystem.
  3. 我真的不明白。我不知道tmpfs /虚拟内存级别的“静态分配”意味着什么。我想你可以编写自己的内核,它不会将指定的RAM模块添加到内存池中,或者只为该RAM模块创建一个内存池,并编写自己的内核驱动程序,它使用指定的RAM模块用于您的目的,然后模拟tmpfs。
  4. - 4.1。是的,tmpfs驱动程序从内核分配虚拟内存。 4.2。 size=bytes Specify an upper limit on the size of the filesystem.。只有tmpfs中的资源多。您可以选择指定上限。我想tmpfs内核驱动程序在加载时也会消耗一些内存,但这可以忽略不计。
  5. 由于开发人员和计算机上的软件的粒度,tmpfs的东西不仅有一个挂载点。如果我编写一个将大块文件存储在内存中的应用程序,我将为我的应用程序安装一个tmpfs。如果您编写另一个应用程序,则将为您的应用程序安装另一个tmpfs。这样我们就不会一起写到同一个文件夹,我们可以为不同的应用程序提供相同的文件名。但标准的方法是使用/tmp目录作为文件的临时位置(POSIX.1-2008)并使用像mktemp这样的函数在那里创建文件和文件夹,所以实际上在PC上安装了一个或两个tmpfs。
  6. 如果你指的是procsysfscgroup或者像devtmpfs(参见udevd)和其他人,他们不是tmpfs并且是一个单独的主题。
© www.soinside.com 2019 - 2024. All rights reserved.