嵌入式linux内存池,Linux上的所有tmpfs实例都共享同一个内存池吗?

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

客户问为什么所有的易失性" RAM FS"材料不只有一个安装架。

问题:

是否从相同的公共源(缓存或任何其他资源)为所有tmpfs实例分配了物理内存,这样我们就不必手动管理它了?

当删除一个tmpfs装载上的文件时,该内存可以被其他装载重用吗?

是否有Linux风格(或配置选项)用于为tmpfs静态分配内存?

tmpfs是否在内核中分配虚拟内存空间或消耗其他与tmpfs定义大小成比例的宝贵资源?

来自man tmpfs的报价。

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

The [tmpfs] consumes only as much physical memory and swap space as is required to store the current contents of the filesystem.。

我真的不明白。我不知道在tmpfs /虚拟内存级别上的"静态分配"是什么意思。我猜您可以编写自己的内核,该内核不将指定的RAM模块添加到内存池中或仅为该RAM模块创建内存池,然后编写自己的内核驱动程序,该内核驱动程序将指定的RAM模块用于您的目的,然后模拟tmpfs。

--

4.1。是的,tmpfs驱动程序从内核分配虚拟内存。

4.2。 size=bytes Specify an upper limit on the size of the filesystem.。 tmpfs中只有最大的资源。您可以选择指定上限。我猜tmpfs内核驱动程序在加载时也会消耗一些内存,但这可以忽略不计。

由于开发人员和您计算机上的软件的细化,tmpfs的安装点并不只有一个。如果我编写了一个将大量文件存储在内存中的应用程序,则将为我的应用程序安装一个tmpfs。如果编写其他应用程序,则将仅为您的应用程序安装另一个tmpfs。这样,我们将不会一起写入同一文件夹,而对于不同的应用程序,我们可以使用相同的文件名。但是标准方法是使用/tmp目录作为文件的临时位置(POSIX.1-2008),并使用mktemp之类的功能在该目录中创建文件和文件夹,因此实际上一个或两个tmpf安装在电脑

如果您是指proc,sysfs,cgroup或类似devtmpfs(请参见udevd)等,则它们不是tmpfs,而是一个单独的主题。

因此,最重要的是,我可以告诉客户不要让我烦恼多个tmpfs,这可以吗?

是的XD。 我也可以猜到这些安装的90%不是tmpfs,而是proc,sys,dev和cgroup虚拟fs。

在此系统上,它们是/ tmp,/ run,/ dev / shm,/ var / user / something,/ media / tmp等。

他们都有不同的想法。 / tmp是系统范围的临时文件目录。 / dev / shm用于进程之间的共享内存。 gvfs使用/ run / user / 来自动挂载示例USB内存。 我第一次看到/ var / user目录。 / media / tmp不是标准的,也不知道。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值