Linux上的所有tmpfs实例都共享同一个内存池吗?

时间:2018-09-17 12:04:23

标签: linux tmpfs

我有嵌入式Linux系统,并且在fstab中定义了多个tmpfs挂载。其中一些坐骑与systemd有关。

客户问为什么所有易失的“ RAM FS”物品不只有一个安装架。

问题:

  1. 是否从同一公共源(缓存或其他任何资源)为所有tmpfs实例分配了物理内存,所以我们不必手动对其进行管理?
  2. 删除一个tmpfs挂载上的文件时,该内存可以被其他挂载重用吗?
  3. 是否存在Linux风味(或配置选项),其中tmpfs的内存是静态分配的?
  4. tmpfs是否在内核中分配虚拟内存空间或消耗其他与tmpfs定义大小成比例的宝贵资源?

1 个答案:

答案 0 :(得分:1)

来自man tmpfs的语录。

  1. The tmpfs [...] contents reside in virtual memory. Virtual memory是一个大话题,您可以在网上进行浏览。物理内存的来源可能是RAM(我不知道您是否将单独的RAM模块视为不同的来源),也可以是swap或其他任何来源(如果您为其编写驱动程序)。虚拟内存建立在此之上。内存可以“即时” zswap进行压缩,并且具有更多的功能(例如删除重复KSM等),因此,虚拟内存中的5MB不是物理内存中的5MB。我猜每个tmpfs挂载点都有它自己的虚拟内存地址空间,但我认为这实际上取决于实现。

  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之类的功能在此处创建文件和文件夹,因此实际上有一两个将tmpfs安装在PC上。

  6. 如果您指的是procsysfscgroup或类似devtmpfs(请参阅udevd)等,则它们不是tmpfs并且是一个单独的主题。