109028e60SWang Qing.. SPDX-License-Identifier: GPL-2.0 209028e60SWang Qing 309028e60SWang Qing.. include:: ../disclaimer-zh_CN.rst 409028e60SWang Qing 5*47e44ed0SJonathan Corbet:Original: Documentation/filesystems/tmpfs.rst 609028e60SWang Qing 709028e60SWang Qingtranslated by Wang Qing<wangqing@vivo.com> 809028e60SWang Qing 909028e60SWang Qing===== 1009028e60SWang QingTmpfs 1109028e60SWang Qing===== 1209028e60SWang Qing 1309028e60SWang QingTmpfs是一个将所有文件都保存在虚拟内存中的文件系统。 1409028e60SWang Qing 1509028e60SWang Qingtmpfs中的所有内容都是临时的,也就是说没有任何文件会在硬盘上创建。 1609028e60SWang Qing如果卸载tmpfs实例,所有保存在其中的文件都会丢失。 1709028e60SWang Qing 1809028e60SWang Qingtmpfs将所有文件保存在内核缓存中,随着文件内容增长或缩小可以将不需要的 1909028e60SWang Qing页面swap出去。它具有最大限制,可以通过“mount -o remount ...”调整。 2009028e60SWang Qing 2109028e60SWang Qing和ramfs(创建tmpfs的模板)相比,tmpfs包含交换和限制检查。和tmpfs相似的另 2209028e60SWang Qing一个东西是RAM磁盘(/dev/ram*),可以在物理RAM中模拟固定大小的硬盘,并在 2309028e60SWang Qing此之上创建一个普通的文件系统。Ramdisks无法swap,因此无法调整它们的大小。 2409028e60SWang Qing 2509028e60SWang Qing由于tmpfs完全保存于页面缓存和swap中,因此所有tmpfs页面将在/proc/meminfo 2609028e60SWang Qing中显示为“Shmem”,而在free(1)中显示为“Shared”。请注意,这些计数还包括 2709028e60SWang Qing共享内存(shmem,请参阅ipcs(1))。获得计数的最可靠方法是使用df(1)和du(1)。 2809028e60SWang Qing 2909028e60SWang Qingtmpfs具有以下用途: 3009028e60SWang Qing 3109028e60SWang Qing1) 内核总有一个无法看到的内部挂载,用于共享匿名映射和SYSV共享内存。 3209028e60SWang Qing 3309028e60SWang Qing 挂载不依赖于CONFIG_TMPFS。如果CONFIG_TMPFS未设置,tmpfs对用户不可见。 3409028e60SWang Qing 但是内部机制始终存在。 3509028e60SWang Qing 3609028e60SWang Qing2) glibc 2.2及更高版本期望将tmpfs挂载在/dev/shm上以用于POSIX共享内存 3709028e60SWang Qing (shm_open,shm_unlink)。添加内容到/etc/fstab应注意如下: 3809028e60SWang Qing 3909028e60SWang Qing tmpfs /dev/shm tmpfs defaults 0 0 4009028e60SWang Qing 4109028e60SWang Qing 使用时需要记住创建挂载tmpfs的目录。 4209028e60SWang Qing 4309028e60SWang Qing SYSV共享内存无需挂载,内部已默认支持。(在2.3内核版本中,必须挂载 4409028e60SWang Qing tmpfs的前身(shm fs)才能使用SYSV共享内存) 4509028e60SWang Qing 4609028e60SWang Qing3) 很多人(包括我)都觉的在/tmp和/var/tmp上挂载非常方便,并具有较大的 4709028e60SWang Qing swap分区。目前循环挂载tmpfs可以正常工作,所以大多数发布都应当可以 4809028e60SWang Qing 使用mkinitrd通过/tmp访问/tmp。 4909028e60SWang Qing 5009028e60SWang Qing4) 也许还有更多我不知道的地方:-) 5109028e60SWang Qing 5209028e60SWang Qing 5309028e60SWang Qingtmpfs有三个用于调整大小的挂载选项: 5409028e60SWang Qing 5509028e60SWang Qing========= =========================================================== 5609028e60SWang Qingsize tmpfs实例分配的字节数限制。默认值是不swap时物理RAM的一半。 5709028e60SWang Qing 如果tmpfs实例过大,机器将死锁,因为OOM处理将无法释放该内存。 5809028e60SWang Qingnr_blocks 与size相同,但以PAGE_SIZE为单位。 5909028e60SWang Qingnr_inodes tmpfs实例的最大inode个数。默认值是物理内存页数的一半,或者 6009028e60SWang Qing (有高端内存的机器)低端内存RAM的页数,二者以较低者为准。 6109028e60SWang Qing========= =========================================================== 6209028e60SWang Qing 6309028e60SWang Qing这些参数接受后缀k,m或g表示千,兆和千兆字节,可以在remount时更改。 6409028e60SWang Qingsize参数也接受后缀%用来限制tmpfs实例占用物理RAM的百分比: 6509028e60SWang Qing未指定size或nr_blocks时,默认值为size=50% 6609028e60SWang Qing 6709028e60SWang Qing如果nr_blocks=0(或size=0),block个数将不受限制;如果nr_inodes=0, 6809028e60SWang Qinginode个数将不受限制。这样挂载通常是不明智的,因为它允许任何具有写权限的 6909028e60SWang Qing用户通过访问tmpfs耗尽机器上的所有内存;但同时这样做也会增强在多个CPU的 7009028e60SWang Qing场景下的访问。 7109028e60SWang Qing 7209028e60SWang Qingtmpfs具有为所有文件设置NUMA内存分配策略挂载选项(如果启用了CONFIG_NUMA), 7309028e60SWang Qing可以通过“mount -o remount ...”调整 7409028e60SWang Qing 7509028e60SWang Qing======================== ========================= 7609028e60SWang Qingmpol=default 采用进程分配策略 7709028e60SWang Qing (请参阅 set_mempolicy(2)) 7809028e60SWang Qingmpol=prefer:Node 倾向从给定的节点分配 7909028e60SWang Qingmpol=bind:NodeList 只允许从指定的链表分配 8009028e60SWang Qingmpol=interleave 倾向于依次从每个节点分配 8109028e60SWang Qingmpol=interleave:NodeList 依次从每个节点分配 8209028e60SWang Qingmpol=local 优先本地节点分配内存 8309028e60SWang Qing======================== ========================= 8409028e60SWang Qing 8509028e60SWang QingNodeList格式是以逗号分隔的十进制数字表示大小和范围,最大和最小范围是用- 8609028e60SWang Qing分隔符的十进制数来表示。例如,mpol=bind0-3,5,7,9-15 8709028e60SWang Qing 8809028e60SWang Qing带有有效NodeList的内存策略将按指定格式保存,在创建文件时使用。当任务在该 8909028e60SWang Qing文件系统上创建文件时,会使用到挂载时的内存策略NodeList选项,如果设置的话, 9009028e60SWang Qing由调用任务的cpuset[请参见Documentation/admin-guide/cgroup-v1/cpusets.rst] 9109028e60SWang Qing以及下面列出的可选标志约束。如果NodeLists为设置为空集,则文件的内存策略将 9209028e60SWang Qing恢复为“默认”策略。 9309028e60SWang Qing 9409028e60SWang QingNUMA内存分配策略有可选标志,可以用于模式结合。在挂载tmpfs时指定这些可选 9509028e60SWang Qing标志可以在NodeList之前生效。 9609028e60SWang QingDocumentation/admin-guide/mm/numa_memory_policy.rst列出所有可用的内存 9709028e60SWang Qing分配策略模式标志及其对内存策略。 9809028e60SWang Qing 9909028e60SWang Qing:: 10009028e60SWang Qing 10109028e60SWang Qing =static 相当于 MPOL_F_STATIC_NODES 10209028e60SWang Qing =relative 相当于 MPOL_F_RELATIVE_NODES 10309028e60SWang Qing 10409028e60SWang Qing例如,mpol=bind=staticNodeList相当于MPOL_BIND|MPOL_F_STATIC_NODES的分配策略 10509028e60SWang Qing 10609028e60SWang Qing请注意,如果内核不支持NUMA,那么使用mpol选项挂载tmpfs将会失败;nodelist指定不 10709028e60SWang Qing在线的节点也会失败。如果您的系统依赖于此,但内核会运行不带NUMA功能(也许是安全 10809028e60SWang Qingrevocery内核),或者具有较少的节点在线,建议从自动模式中省略mpol选项挂载选项。 10909028e60SWang Qing可以在以后通过“mount -o remount,mpol=Policy:NodeList MountPoint”添加到挂载点。 11009028e60SWang Qing 11109028e60SWang Qing要指定初始根目录,可以使用如下挂载选项: 11209028e60SWang Qing 11309028e60SWang Qing==== ==================== 11409028e60SWang Qing模式 权限用八进制数字表示 11509028e60SWang Qinguid 用户ID 11609028e60SWang Qinggid 组ID 11709028e60SWang Qing==== ==================== 11809028e60SWang Qing 11909028e60SWang Qing这些选项对remount没有任何影响。您可以通过chmod(1),chown(1)和chgrp(1)的更改 12009028e60SWang Qing已经挂载的参数。 12109028e60SWang Qing 12209028e60SWang Qingtmpfs具有选择32位还是64位inode的挂载选项: 12309028e60SWang Qing 12409028e60SWang Qing======= ============= 12509028e60SWang Qinginode64 使用64位inode 12609028e60SWang Qinginode32 使用32位inode 12709028e60SWang Qing======= ============= 12809028e60SWang Qing 12909028e60SWang Qing在32位内核上,默认是inode32,挂载时指定inode64会被拒绝。 13009028e60SWang Qing在64位内核上,默认配置是CONFIG_TMPFS_INODE64。inode64避免了单个设备上可能有多个 13109028e60SWang Qing具有相同inode编号的文件;比如32位应用程序使用glibc如果长期访问tmpfs,一旦达到33 13209028e60SWang Qing位inode编号,就有EOVERFLOW失败的危险,无法打开大于2GiB的文件,并返回EINVAL。 13309028e60SWang Qing 13409028e60SWang Qing所以'mount -t tmpfs -o size=10G,nr_inodes=10k,mode=700 tmpfs /mytmpfs'将在 13509028e60SWang Qing/mytmpfs上挂载tmpfs实例,分配只能由root用户访问的10GB RAM/SWAP,可以有10240个 13609028e60SWang Qinginode的实例。 13709028e60SWang Qing 13809028e60SWang Qing 13909028e60SWang Qing:作者: 14009028e60SWang Qing Christoph Rohland <cr@sap.com>, 1.12.01 14109028e60SWang Qing:更新: 14209028e60SWang Qing Hugh Dickins, 4 June 2007 14309028e60SWang Qing:更新: 14409028e60SWang Qing KOSAKI Motohiro, 16 Mar 2010 14509028e60SWang Qing:更新: 14609028e60SWang Qing Chris Down, 13 July 2020 147