AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 710398
Accepted
CMCDragonkai
CMCDragonkai
Asked: 2015-08-03 23:45:00 +0800 CST2015-08-03 23:45:00 +0800 CST 2015-08-03 23:45:00 +0800 CST

为数十万个 0 字节锁文件设置 tmpfs `/run/lock`,并处理 inode 限制

  • 772

我有一种情况,我需要创建数千个 0 字节锁定文件以进行并发控制。

我已经使用以下方法测试了创建它们:

for i in `seq 1 50000`; do touch "/run/lock/${i}.lock"; done

由于文件是 0 字节,因此它们不会占用分区中的任何空间。看着df -h:

Filesystem      Size  Used Avail Use% Mounted on
tmpfs            50M  344K   49M   1% /run
none            5.0M     0  5.0M   0% /run/lock
none            246M     0  246M   0% /run/shm
none            100M     0  100M   0% /run/user

该0%数字在行中根本没有变化/run/lock。

然而,每个锁文件的内存大小确实增加了大约 1KB。我通过比较free -h在内部创建 70,000 个锁定文件之前和之后发现了这一点/run/lock。这种内存增加反映在实际内存使用中(虚拟内存减去缓冲区/缓存)。

后来我发现这个 1KB 的增加很可能是由于 inode 造成的。所以我使用以下方法检查了 inode 使用情况df -i:

Filesystem      Inodes  IUsed   IFree IUse% Mounted on
tmpfs            62729    322   62407    1% /run
none             62729  50001   12728   80% /run/lock
none             62729      1   62728    1% /run/shm
none             62729      2   62727    1% /run/user

如您所见,锁定文件增加了/run/lock分区内的 inode。

我目前在 Ubuntu 上,/run安装并没有反映在/etc/fstab. 跑步mount给了我:

tmpfs on /run type tmpfs (rw,noexec,nosuid,size=10%,mode=0755)
none on /run/lock type tmpfs (rw,noexec,nosuid,nodev,size=5242880)
none on /run/shm type tmpfs (rw,nosuid,nodev)
none on /run/user type tmpfs (rw,noexec,nosuid,nodev,size=104857600,mode=0755)

我对此有几个问题(但第一个是最重要的):

  1. 如何永久增加 inode 限制/run/lock?所以这个限制在重启后仍然存在?
  2. 我创建自己的目录并在其上挂载 tmpfs 以用于此而不是使用会更好/run/lock吗?
  3. 每个分区的大小限制是否完全相互独立?那是存储文件/run似乎没有影响/run/lock,反之亦然。
  4. 1KB是从inode派生的吗?我注意到在创建非空文件时,每个文件的基本块是 4KB。
  5. 为什么/run给定文件系统类型tmpfsbut /run/lock,给文件系统类型“none” /run/shm,/run/user特别是因为它们都由 TMPFS 支持?为什么他们不都像列tmpfs中那样阅读Filesystem?
  6. 如果所有目录都受到独立约束,OOM 杀手如何处理存在多个完整 TMPFS 分区的情况,每个分区的大小为 RAM 的 50%,并且还有进程竞争 RAM。显然,不能使用超过 100% 的 RAM。根据https://www.kernel.org/doc/Documentation/filesystems/tmpfs.txt它提到系统将死锁。这是如何运作的?
ubuntu
  • 2 2 个回答
  • 1619 Views

2 个回答

  • Voted
  1. Best Answer
    sam_pan_mariusz
    2015-08-04T01:54:36+08:002015-08-04T01:54:36+08:00

    回答您的一些问题,按顺序:

    1. 您可以mount -o remount,nr_inodes=NUM /run/lock在应用程序启动脚本中使用(以防它以 uid=0 运行)。将相关行添加到/etc/fstab也应该是安全的,但尚未测试。
    2. 分离在这里是有意义的,因为在填充所有 inode 的情况下不会干扰系统的其余部分。
    3. 是的,完全独立。
    4. [...]
    5. 使用虚拟(基于非块设备)文件系统,您可以将任何内容作为设备放入 mount 命令,它只是重要的类型。
    6. [...]

    不确定您的应用程序是否通过打开它来创建空文件(以及持续多长时间),但您也可以考虑增加打开文件限制(检查ulimit)以避免耗尽。

    • 1
  2. Matthew Ife
    2015-08-04T00:20:28+08:002015-08-04T00:20:28+08:00

    你正朝着错误的方向前进。您可以使用文件系统语义来强制一致性。

    1. 当您想读取文件时,只需打开并读取它。您应该始终使用open, 永远不要access进行此操作。如果您使用 PHP 库来执行此操作,请检查它是否只是调用open而不是access在文件上 - 但fopen应该可以正常工作。

    2. 当您要刷新或创建新文件时,请执行以下操作:-

      • 使用临时文件创建机制创建新文件。如果不存在 - 创建一个不太可能存在的新文件名(filename.XXXXXX,其中 X 替换为随机字符)。确保在 O_EXCL 中打开。
      • 将相关数据写入文件。
      • 将文件重命名为旧文件的名称。

    这在操作上是安全的,因为重命名被定义为原子的。打开文件的阅读器将看到旧文件或新文件 - 但不会看到缓存中不存在的文件。

    在对每个文件进行许多并发检查的最坏情况下,许多写入者将短暂地相互覆盖。但这是一种方式——比对每个文件使用文件锁要便宜得多。

    或者,不要为每个文件都设置一个锁定文件 - 考虑实际上只是直接锁定每个单独的缓存对象。但是,我仍然认为这不会扩展。

    在这种情况下使用rename和link语义可以保证与缓存的一致性,并且比锁定文件更便宜。

    • 0

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

  • VirtualBox 上 Ubuntu 的访客优化技巧 [关闭]

  • 外部硬盘上的 virtualbox 虚拟硬盘驱动器(Vista 主机上的 ubuntu 客户机)

  • 如何在 Ubuntu 上挂载 LVM 分区?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve