我正在查看我的 var 目录。符号链接的实际用途是什么?
lrwxrwxrwx 1 root root 9 апр 8 07:47 lock -> /run/lock/
链接锁定至 /run/lock/?
答案1
在这篇文章中可以找到关于这个主题的非常深入的讨论 “/run/lock”和“/run/shm”有什么用?。
以下是摘录的优秀 用户 ish 的回答。
简短回答:它们存储临时系统文件,包括设备锁和不同进程之间共享的内存段。不用担心,它们通常使用分数其“大小”
df
/run
一般来说,是驻留在 RAM 中的临时文件系统 (tmpfs)(又名“ramdisk”);它用于存储“临时”系统或状态文件,这些文件可能很关键,但不要需要在重启后保持持久性。
/run
实际上是一项相当新的创新,是在几年前添加的,用来用单个统一的根 tmpfs取代过去创建的多个 tmpfs(包括/var/lock
和)。/dev/shm
- 主要地点
/run
替换为:/var/run → /运行 /var/lock → /运行/锁 /dev/shm → /运行/shm [目前只有 Debian 计划这样做] /tmp → /run/tmp [可选; 目前只有 Debian 计划提供此功能]
/run/lock
(以前/var/lock
)包含锁文件,即指示共享设备或其他系统资源正在使用中并包含使用它的进程的标识(PID)的文件;这允许其他进程正确协调对共享设备的访问。
/run/shm
(以前/dev/shm
) 是临时的、全世界可写的共享内存。严格来讲,它旨在作为使用 POSIX 共享内存 API 的程序的存储。它促进了所谓的进程间通信 (国际专利分类),其中不同的进程可以通过一个公共内存区域共享和通信,在这种情况下,该内存区域通常是存储在“ramdisk”上的普通文件。当然,它也可以并且已经以其他创造性的方式使用 ;)不要对尺寸感到惊慌:重要的是,许多运行
df -h
并知道/run
由 RAM 支持的人都震惊于他们宝贵的内存被这些神秘文件夹“浪费”。就像Linux 吞噬了我的 RAM 神话但这种看法是错误的。
- 所示尺寸仅为最大限度可以使用
- 默认为物理 RAM 的 50%
- 只显示用过的列实际正在使用中,在上面的屏幕截图中,总计不到 1 兆字节
- 你可以使用该
ipcs -m
命令来验证实际使用的共享内存段是否与摘要匹配df
,还可以查看哪些 PID 正在使用它们- 就像您的常规 RAM 一样,
/run
最终也会由您的交换支持,因此如果您使用/run/shm
“更快”的编译时间,请记住这一点;)