我们的服务在 Linux 申请的内存不会立刻从物理内存划分出来。系统数据修改时,才会发现物理内存没有分配,此时 CPU 会产生缺页中断,操作系统才会以 page 为单位把物理内存分配给程序。系统这么设计,主要是为了降低系统的内存碎片,并且减少内存的浪费。 不过系统分配的页很小,一般是 4KB,如果我们一次需要把 1G 的数据插入到内存中,写入数据到这块内存时就会频繁触发缺页中断,导致程序响应缓慢、服务状态不稳定的问题。 所以,当我们确认需要高并发读写内存时,都会先申请一大块内存并填 0,然后再使用,这样可以减少数据插入时产生的大量缺页中断。我额外补充一个注意事项,这种申请大内存并填 0 的操作很慢,尽量在服务启动时去做。
相关推荐
dovens1 小时前
SpringBoot集成MQTT客户端❀͜͡傀儡师1 小时前
Spring Boot 集成 RocksDB 实战:打造高性能 KV 存储加速层TeamDev1 小时前
如何在 DotNetBrowser 中使用本地 AI 模型Rust语言中文社区2 小时前
【Rust日报】2026-05-02 Temper - 用 Rust 编写的 Minecraft 服务器项目发布 0.1.0 版陈随易2 小时前
2年没用Nodejs了,Bun很香用户9416146933652 小时前
Python 实时监控 A 股行情并自动筛选强势股(REST + WebSocket 两种方案)Java编程爱好者2 小时前
吃透 ForkJoinPool:工作窃取底层原理,一次性讲透longxibo2 小时前
【Flowable 7.2 源码深度解析与实战】雨辰AI3 小时前
从 MySQL 迁移至人大金仓 V9 完整改造指南|分页 / 函数 / 语法兼容全部解决