Linux特种文件系统--tmpfs文件系统

news/2024/11/2 17:51:44/

tmpfs类似于RamDisk(只能使用物理内存),使用虚拟内存(简称VM)子系统的页面存储文件。tmpfs完全依赖VM,遵循子系统的整体调度策略。说白了tmpfs跟普通进程差不多,使用的都是某种形式的虚拟内存,至于数据存储在物理内存中还是在交换分区中,全权交由VM子系统。

tmpfs 文件系统

  • 定义tmpfs 是一个基于内存的文件系统,它在 RAM 中存储数据,因此访问速度非常快。

  • 用途tmpfs 通常用于存储临时文件,这些文件不需要永久保存,而且频繁读写。使用 tmpfs 可以减少对物理磁盘的磨损,并提高性能。

  • 示例路径:常见的 tmpfs 挂载点包括 /dev/shm/run/tmp 等。

  • 持久性:系统重启后,tmpfs 中的数据会被清空。

devtmpfs 文件系统

  • 定义devtmpfs 也是一种基于内存的文件系统,主要用于动态创建设备节点。

  • 用途devtmpfs 在系统启动时自动创建,用来存放动态设备文件。它减少了手动创建设备节点的需要,并且可以根据当前硬件自动创建所需的设备文件。

  • 示例路径devtmpfs 通常挂载在 /dev 目录下。

  • 持久性:与 tmpfs 类似,系统重启后,devtmpfs 中的设备文件也会重新创建

查看tmpfs文件系统挂载情况

使用mount或df命令来查看tmpfs挂载情况,mount可以看到挂在点的一些属性信息;df可以查看挂载点大小以及使用率等。

 mount | grep tmpfsdevtmpfs on /dev type devtmpfs (rw,nosuid,seclabel,size=930460k,nr_inodes=232615,mode=755)tmpfs on /dev/shm type tmpfs (rw,nosuid,nodev,seclabel)tmpfs on /run type tmpfs (rw,nosuid,nodev,seclabel,mode=755)tmpfs on /sys/fs/cgroup type tmpfs (ro,nosuid,nodev,noexec,seclabel,mode=755)tmpfs on /run/user/0 type tmpfs (rw,nosuid,nodev,relatime,seclabel,size=188216k,mode=700)​df -hTFilesystem     Type     Size Used Avail Use% Mounted ondevtmpfs       devtmpfs 909M     0 909M   0% /devtmpfs         tmpfs     920M     0 920M   0% /dev/shmtmpfs         tmpfs     920M   17M 903M   2% /runtmpfs         tmpfs     920M     0 920M   0% /sys/fs/cgroup/dev/sda3     xfs       14G 3.2G   11G 24% //dev/sda1     xfs     1014M 181M 834M 18% /boottmpfs         tmpfs     184M     0 184M   0% /run/user/0

使用tmpfs文件系统

创建tmpfs并挂在到/test-tmpfs,对使用内存大小未做限制,但是分配了一个920M大小,当向其拷贝大于920M的数据,并未动态扩展超过920M(虽未指定size,会有一个缺省值:刚好是我内存的50%),仍然会报错:No space left on device。

mount tmpfs /test-tmpfs -t tmpfs~]# dd if=/dev/zero of=/test-tmpfs/bigfile bs=1M count=1000
dd: error writing ‘/test-tmpfs/bigfile’: No space left on device
920+0 records in
919+0 records out
963661824 bytes (964 MB) copied, 0.788749 s, 1.2 GB/s

创建tmpfs并挂在到/test-tmpfs2,最大只能使用64m内存空间,很显然到存储文件大小超过64m时,报错:No space left on device

mount tmpfs /test-tmpfs2/ -t tmpfs -o size=64m~]# dd if=/dev/zero of=/test-tmpfs2/bigfile bs=1M count=65
dd: error writing ‘/test-tmpfs2/bigfile’: No space left on device
65+0 records in
64+0 records out
67108864 bytes (67 MB) copied, 0.10594 s, 633 MB/s

第一个试验,默认大小920M,且当超过920M时并没有动态扩展,那么是不是最大只能设置size=920M呢?显然不是!经过查资料,不设置size,则默认使用物理内存的50%(我擦,从这里我可以逆向推机器的物理内存大小了~~)

mount tmpfs /test-tmpfs3/ -t tmpfs -o size=2048m ~]# df -hT|grep test-tmpfs
tmpfs          tmpfs     2.0G     0  2.0G   0% /test-tmpfs3

既然tmpfs存储在内存中,那么tmpfs占用的内存是哪一部分呢?答案是shared memory。

~]# free -m
           total        used        free      shared  buff/cache   available
Mem:   1838         162          72         920        1602         590
Swap:   1638          61        1577

~]# rm -rf /test-tmpfs/bigfile
~]# free -m
          total        used        free      shared  buff/cache   available
Mem:   1838         162         992           1         683        1509
Swap:   1638          61        1577

通过tmpfs赋能应用加速

给squid代理加速,据说可以将系统负载从12降低到0.3。

1、创建并挂在tmpfs

mkdir /squid_tmp
chmod 1777 /squid_tmp
~]# cat /etc/fstab |grep squid
tmpfs                   /squid_tmp              tmpfs   size=256m

2、修改squid代理配置

~]# cat /etc/squid/squid.conf|grep -i cache
# Only allow cachemgr access from localhost
# Uncomment and adjust the following to add a disk cache directory.
#cache_dir ufs /var/spool/squid 100 16 256
cache_dir ufs /squid_tmp 256 16 256

  • ufs,缓存存储机制,具体参考Squid的使用手册
  • /squid_tmp,就是一个tmpfs
  • 第一个256,指定缓存目录的大小,这是Squid可以使用的上限,可以根据实际情况酌情设定
  • 16和第二个256,针对ufs机制,Squid在缓存目录下创建二级目录树。分别指定了第一级和第二级目录的数量。默认就是16和256,可以根据具体情况酌情设定。如下图:一级目录刚好16个。

3、重启Squid服务

 systemctl restart squid

 


http://www.ppmy.cn/news/1543927.html

相关文章

git入门教程4:git工作流程

一、初始化仓库 新建或选择项目目录:首先,你需要在你的计算机上创建一个新的项目目录,或者选择一个已有的项目目录作为Git仓库的根目录。初始化仓库:打开终端(在Windows上可以是Git Bash),切换…

如何封装一个可取消的 HTTP 请求?

前言 你可能会好奇什么样的场景会需要取消 HTTP 请求呢? 确实在实际的项目开发中,可能会很少有这样的需求,但是不代表没有,比如: 假如要实现上述这个公告栏,每点击一个 tab 按钮就会切换展示容器容器中…

Java 集合一口气讲完!(中)d=====( ̄▽ ̄*)b

Java 队列 Java集合教程 - Java队列 队列是只能在其上执行操作的对象的集合两端的队列。 队列有两个末端,称为头和尾。 在简单队列中,对象被添加到尾部并从头部删除并首先删除首先添加的对象。 Java Collections Framework支持以下类型的队列。 简单…

9.4 PIN definitions

9.4 PIN定义 9.4.0 引言 第9.4节定义了UICC上应存在的PIN类型,即通用PIN和应用程序PIN,以及UICC/应用程序所需的其他类型的访问条件。 9.4.1 通用PIN 通用PIN是在多应用环境中使用的PIN,允许多个应用程序共享一个公共PIN。通用PIN是一个全局…

RabbitMQ的解耦、异步、削峰是什么?

RabbitMQ在分布式系统和微服务架构中起到了重要的作用,其特性可以实现解耦、异步以及削峰,下面是对这三个概念的详细解释: 1. 解耦 解耦是指使系统的不同组件间的依赖关系减少或消失。在使用RabbitMQ时,生产者(发送消…

【Java】设计模式——单例设计模式

1.什么是设计模式 设计模式是一种被广泛认可的、可复用的解决方案,用于在软件开发中解决常见的问题。它们是对软件设计中常见问题的总结与提炼,提供了一套可遵循的标准和最佳实践,帮助开发人员构建高效、可维护和灵活的系统。 2.设计模式的分…

计算机网络八股文个人总结

1.TCP/IP模型和OSI模型的区别 在计算机网络中,TCP/IP 模型和 OSI 模型是两个重要的网络协议模型。它们帮助我们理解计算机通信的工作原理。以下是它们的主要区别,以通俗易懂的方式进行解释: 1. 模型层数 OSI 模型:有 7 层&#…

【Spring】Spring Boot 配置文件(7)

本系列共涉及4个框架:Sping,SpringBoot,Spring MVC,Mybatis。 博客涉及框架的重要知识点,根据序号学习即可。 有什么不懂的都可以问我,看到消息会回复的,可能会不及时,请见谅!! 目录 本系列共…