page cache回写的几种触发方式

2023-10-07 07:32

本文主要是介绍page cache回写的几种触发方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.通过写入proc文件系统节点操作

echo 3 > /proc/sys/vm/drop_caches

drop_caches通过传入不同的数值表示不同的含义,其中写入3表示回收内核中的clean cache和slab object。它是不会对脏页做处理的,因此为了更大限度的回收cache,可以先执行sync,之后在执行该操作。

2.sysctl设置系统参数

配置flushd进程把脏页写回到磁盘的是时间间隔,单位是1/100秒,因此如下配置为5s的间隔:

vm.dirty_writeback_centisecs = 500

配置内存中脏页的驻留时间,如果脏页超过该时间,flushd会在下一次执行时写入磁盘

vm.dirty_expire_centisecs = 3000

配置脏页占总物理内存百分比,比如当超过10%以上,触发flushd把脏数据写回磁盘

vm.dirty_background_ratio = 10

3.sync系统调用

用户进程调用sync、fsync、fdatasync系统调用时,内核会执行相应的写回操作。

4.内存回收时
在执行直接内存回收时,try_to_free_pages最后会执行wakeup_flusher_threads唤醒flusher线程,处理脏页的回写功能。

__alloc_pages_direct_reclaim-->__perform_reclaim-->try_to_free_pages-->do_try_to_free_pages-->shrink_zones + wakeup_flusher_threads

5.write系统调用

write系统调用有两种方式,一种叫做write back,另一种叫做write through。从名字定义上也可以大致猜出它们的含义,write back指的是把write操作把数据写入到page cache后就返回,这些脏的page cache写入到文件系统可能并不是同时发生的,而是由pdflushd在合适的时机写入的。write through指的是在write写入到page cache的同时更新数据到底层,对于write through这种方式,通过在 open 打开⽂件时,传⼊ O_SYNC 这个flag即可实现。

6.direct io写入

对于direct io的方式写入文件,它和上面介绍的write back和write through不同的地方在于direct io是会直接跳过page cache的方式通过直接与更底层交互来实现。一般数据库都会采用这种方式,跳过内核中的页缓存机制,而由应用层的缓存代替。通过在 open 打开⽂件时,传⼊ O_DIRECT 这个flag即可实现。


https://www.0xffffff.org/2017/05/01/41-linux-io/

这篇关于page cache回写的几种触发方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/156966

相关文章

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

【即时通讯】轮询方式实现

技术栈 LayUI、jQuery实现前端效果。django4.2、django-ninja实现后端接口。 代码仓 - 后端 代码仓 - 前端 实现功能 首次访问页面并发送消息时需要设置昵称发送内容为空时要提示用户不能发送空消息前端定时获取消息,然后展示在页面上。 效果展示 首次发送需要设置昵称 发送消息与消息展示 提示用户不能发送空消息 后端接口 发送消息 DB = []@ro

脏页的标记方式详解

脏页的标记方式 一、引言 在数据库系统中,脏页是指那些被修改过但还未写入磁盘的数据页。为了有效地管理这些脏页并确保数据的一致性,数据库需要对脏页进行标记。了解脏页的标记方式对于理解数据库的内部工作机制和优化性能至关重要。 二、脏页产生的过程 当数据库中的数据被修改时,这些修改首先会在内存中的缓冲池(Buffer Pool)中进行。例如,执行一条 UPDATE 语句修改了某一行数据,对应的缓

Java 多线程的基本方式

Java 多线程的基本方式 基础实现两种方式: 通过实现Callable 接口方式(可得到返回值):

JVM内存调优原则及几种JVM内存调优方法

JVM内存调优原则及几种JVM内存调优方法 1、堆大小设置。 2、回收器选择。   1、在对JVM内存调优的时候不能只看操作系统级别Java进程所占用的内存,这个数值不能准确的反应堆内存的真实占用情况,因为GC过后这个值是不会变化的,因此内存调优的时候要更多地使用JDK提供的内存查看工具,比如JConsole和Java VisualVM。   2、对JVM内存的系统级的调优主要的目的是减少

前端form表单+ifarme方式实现大文件下载

// main.jsimport Vue from 'vue';import App from './App.vue';import { downloadTokenFile } from '@/path/to/your/function'; // 替换为您的函数路径// 将 downloadTokenFile 添加到 Vue 原型上Vue.prototype.$downloadTokenF