162306a36Sopenharmony_ci.. SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci
362306a36Sopenharmony_ci.. include:: ../disclaimer-zh_CN.rst
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci:Original: Documentation/filesystems/tmpfs.rst
662306a36Sopenharmony_ci
762306a36Sopenharmony_citranslated by Wang Qing<wangqing@vivo.com>
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci=====
1062306a36Sopenharmony_ciTmpfs
1162306a36Sopenharmony_ci=====
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ciTmpfs是一个将所有文件都保存在虚拟内存中的文件系统。
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_citmpfs中的所有内容都是临时的,也就是说没有任何文件会在硬盘上创建。
1662306a36Sopenharmony_ci如果卸载tmpfs实例,所有保存在其中的文件都会丢失。
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_citmpfs将所有文件保存在内核缓存中,随着文件内容增长或缩小可以将不需要的
1962306a36Sopenharmony_ci页面swap出去。它具有最大限制,可以通过“mount -o remount ...”调整。
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci和ramfs(创建tmpfs的模板)相比,tmpfs包含交换和限制检查。和tmpfs相似的另
2262306a36Sopenharmony_ci一个东西是RAM磁盘(/dev/ram*),可以在物理RAM中模拟固定大小的硬盘,并在
2362306a36Sopenharmony_ci此之上创建一个普通的文件系统。Ramdisks无法swap,因此无法调整它们的大小。
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci由于tmpfs完全保存于页面缓存和swap中,因此所有tmpfs页面将在/proc/meminfo
2662306a36Sopenharmony_ci中显示为“Shmem”,而在free(1)中显示为“Shared”。请注意,这些计数还包括
2762306a36Sopenharmony_ci共享内存(shmem,请参阅ipcs(1))。获得计数的最可靠方法是使用df(1)和du(1)。
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_citmpfs具有以下用途:
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci1) 内核总有一个无法看到的内部挂载,用于共享匿名映射和SYSV共享内存。
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci   挂载不依赖于CONFIG_TMPFS。如果CONFIG_TMPFS未设置,tmpfs对用户不可见。
3462306a36Sopenharmony_ci   但是内部机制始终存在。
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci2) glibc 2.2及更高版本期望将tmpfs挂载在/dev/shm上以用于POSIX共享内存
3762306a36Sopenharmony_ci   (shm_open,shm_unlink)。添加内容到/etc/fstab应注意如下:
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci	tmpfs	/dev/shm	tmpfs	defaults	0 0
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci   使用时需要记住创建挂载tmpfs的目录。
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci   SYSV共享内存无需挂载,内部已默认支持。(在2.3内核版本中,必须挂载
4462306a36Sopenharmony_ci   tmpfs的前身(shm fs)才能使用SYSV共享内存)
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci3) 很多人(包括我)都觉的在/tmp和/var/tmp上挂载非常方便,并具有较大的
4762306a36Sopenharmony_ci   swap分区。目前循环挂载tmpfs可以正常工作,所以大多数发布都应当可以
4862306a36Sopenharmony_ci   使用mkinitrd通过/tmp访问/tmp。
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci4) 也许还有更多我不知道的地方:-)
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_citmpfs有三个用于调整大小的挂载选项:
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci=========  ===========================================================
5662306a36Sopenharmony_cisize       tmpfs实例分配的字节数限制。默认值是不swap时物理RAM的一半。
5762306a36Sopenharmony_ci           如果tmpfs实例过大,机器将死锁,因为OOM处理将无法释放该内存。
5862306a36Sopenharmony_cinr_blocks  与size相同,但以PAGE_SIZE为单位。
5962306a36Sopenharmony_cinr_inodes  tmpfs实例的最大inode个数。默认值是物理内存页数的一半,或者
6062306a36Sopenharmony_ci           (有高端内存的机器)低端内存RAM的页数,二者以较低者为准。
6162306a36Sopenharmony_ci=========  ===========================================================
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci这些参数接受后缀k,m或g表示千,兆和千兆字节,可以在remount时更改。
6462306a36Sopenharmony_cisize参数也接受后缀%用来限制tmpfs实例占用物理RAM的百分比:
6562306a36Sopenharmony_ci未指定size或nr_blocks时,默认值为size=50%
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci如果nr_blocks=0(或size=0),block个数将不受限制;如果nr_inodes=0,
6862306a36Sopenharmony_ciinode个数将不受限制。这样挂载通常是不明智的,因为它允许任何具有写权限的
6962306a36Sopenharmony_ci用户通过访问tmpfs耗尽机器上的所有内存;但同时这样做也会增强在多个CPU的
7062306a36Sopenharmony_ci场景下的访问。
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_citmpfs具有为所有文件设置NUMA内存分配策略挂载选项(如果启用了CONFIG_NUMA),
7362306a36Sopenharmony_ci可以通过“mount -o remount ...”调整
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci======================== =========================
7662306a36Sopenharmony_cimpol=default             采用进程分配策略
7762306a36Sopenharmony_ci                         (请参阅 set_mempolicy(2))
7862306a36Sopenharmony_cimpol=prefer:Node         倾向从给定的节点分配
7962306a36Sopenharmony_cimpol=bind:NodeList       只允许从指定的链表分配
8062306a36Sopenharmony_cimpol=interleave          倾向于依次从每个节点分配
8162306a36Sopenharmony_cimpol=interleave:NodeList 依次从每个节点分配
8262306a36Sopenharmony_cimpol=local               优先本地节点分配内存
8362306a36Sopenharmony_ci======================== =========================
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ciNodeList格式是以逗号分隔的十进制数字表示大小和范围,最大和最小范围是用-
8662306a36Sopenharmony_ci分隔符的十进制数来表示。例如,mpol=bind0-3,5,7,9-15
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci带有有效NodeList的内存策略将按指定格式保存,在创建文件时使用。当任务在该
8962306a36Sopenharmony_ci文件系统上创建文件时,会使用到挂载时的内存策略NodeList选项,如果设置的话,
9062306a36Sopenharmony_ci由调用任务的cpuset[请参见Documentation/admin-guide/cgroup-v1/cpusets.rst]
9162306a36Sopenharmony_ci以及下面列出的可选标志约束。如果NodeLists为设置为空集,则文件的内存策略将
9262306a36Sopenharmony_ci恢复为“默认”策略。
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ciNUMA内存分配策略有可选标志,可以用于模式结合。在挂载tmpfs时指定这些可选
9562306a36Sopenharmony_ci标志可以在NodeList之前生效。
9662306a36Sopenharmony_ciDocumentation/admin-guide/mm/numa_memory_policy.rst列出所有可用的内存
9762306a36Sopenharmony_ci分配策略模式标志及其对内存策略。
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci::
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci	=static		相当于	MPOL_F_STATIC_NODES
10262306a36Sopenharmony_ci	=relative	相当于	MPOL_F_RELATIVE_NODES
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci例如,mpol=bind=staticNodeList相当于MPOL_BIND|MPOL_F_STATIC_NODES的分配策略
10562306a36Sopenharmony_ci
10662306a36Sopenharmony_ci请注意,如果内核不支持NUMA,那么使用mpol选项挂载tmpfs将会失败;nodelist指定不
10762306a36Sopenharmony_ci在线的节点也会失败。如果您的系统依赖于此,但内核会运行不带NUMA功能(也许是安全
10862306a36Sopenharmony_cirevocery内核),或者具有较少的节点在线,建议从自动模式中省略mpol选项挂载选项。
10962306a36Sopenharmony_ci可以在以后通过“mount -o remount,mpol=Policy:NodeList MountPoint”添加到挂载点。
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci要指定初始根目录,可以使用如下挂载选项:
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci====	====================
11462306a36Sopenharmony_ci模式	权限用八进制数字表示
11562306a36Sopenharmony_ciuid	用户ID
11662306a36Sopenharmony_cigid	组ID
11762306a36Sopenharmony_ci====	====================
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_ci这些选项对remount没有任何影响。您可以通过chmod(1),chown(1)和chgrp(1)的更改
12062306a36Sopenharmony_ci已经挂载的参数。
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_citmpfs具有选择32位还是64位inode的挂载选项:
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci=======   =============
12562306a36Sopenharmony_ciinode64   使用64位inode
12662306a36Sopenharmony_ciinode32   使用32位inode
12762306a36Sopenharmony_ci=======   =============
12862306a36Sopenharmony_ci
12962306a36Sopenharmony_ci在32位内核上,默认是inode32,挂载时指定inode64会被拒绝。
13062306a36Sopenharmony_ci在64位内核上,默认配置是CONFIG_TMPFS_INODE64。inode64避免了单个设备上可能有多个
13162306a36Sopenharmony_ci具有相同inode编号的文件;比如32位应用程序使用glibc如果长期访问tmpfs,一旦达到33
13262306a36Sopenharmony_ci位inode编号,就有EOVERFLOW失败的危险,无法打开大于2GiB的文件,并返回EINVAL。
13362306a36Sopenharmony_ci
13462306a36Sopenharmony_ci所以'mount -t tmpfs -o size=10G,nr_inodes=10k,mode=700 tmpfs /mytmpfs'将在
13562306a36Sopenharmony_ci/mytmpfs上挂载tmpfs实例,分配只能由root用户访问的10GB RAM/SWAP,可以有10240个
13662306a36Sopenharmony_ciinode的实例。
13762306a36Sopenharmony_ci
13862306a36Sopenharmony_ci
13962306a36Sopenharmony_ci:作者:
14062306a36Sopenharmony_ci   Christoph Rohland <cr@sap.com>, 1.12.01
14162306a36Sopenharmony_ci:更新:
14262306a36Sopenharmony_ci   Hugh Dickins, 4 June 2007
14362306a36Sopenharmony_ci:更新:
14462306a36Sopenharmony_ci   KOSAKI Motohiro, 16 Mar 2010
14562306a36Sopenharmony_ci:更新:
14662306a36Sopenharmony_ci   Chris Down, 13 July 2020
147