linux 内存管理详解

linux 内存管理详解

内存管理概览

  • 物理页管理系统通过buddy算法提供(4kb...1024 * 4kb,,这里默认页大小为4kb)物理页申请,使用,释放功能。
  • MMU提供虚拟内存转化为物理内存的功能,LTB(这里的缓存是存在cpu中的一级,二级,三级缓存中)里存放的是多级页表的缓存,如果缓存没有命令,则需要重新从内存中加载。TLB表中有进程id的标识,这样就能保证不同进程可以独立使用完成的虚拟空间
  • 进程内存管理 用来控制当前进程的内存使用分布,可以通过brk,sbrk系统调用函数来调整进程堆空间的大小,可以使用mmap,ummap来申请指定大小的内存空间供应用程序使用。
  • 虚拟内存管理是基于mmap,ummap又加了一层内存管理模块,用来专门为应用层提供频繁进行内存申请与释放的高性能内存管理模块。因为每次调用mmap,ummap实际上都会触发进程内存管理,mmu,物理页管理系统运行,比较耗时,不利于频繁进程内存申请与释放。故先通过mmap提前申请一大块内存,然后在慢慢的使用。

1 linux 申请与访问过程

1.1 内存申请与访问过程

1.2 大页内存使用

使用大页内存可以明显提高内存访问的性能,主要是通过大幅度降低大页列表长度以及提高TLB缓存命令率方式。

shell 复制代码
# 查看CPU是否支持大页
$ grep -i huge /proc/cpuinfo
$ grep pdpe1gb /proc/cpuinfo  # 检查1GB大页支持

# 查看当前大页配置
$ cat /proc/meminfo | grep -i huge
HugePages_Total:       0      # 已配置大页总数
HugePages_Free:        0      # 空闲大页数
HugePages_Rsvd:        0      # 预留大页数
HugePages_Surp:        0      # 超额大页数
Hugepagesize:       2048 kB   # 大页大小

# 创建挂载点
$ sudo mkdir -p /mnt/huge
$ sudo mkdir -p /mnt/huge_1GB

# 挂载2MB大页文件系统
$ sudo mount -t hugetlbfs -o pagesize=2MB none /mnt/huge

# 挂载1GB大页文件系统
$ sudo mount -t hugetlbfs -o pagesize=1GB none /mnt/huge_1GB

# 永久挂载(/etc/fstab)
none    /mnt/huge    hugetlbfs   pagesize=2MB   0   0
none    /mnt/huge_1GB hugetlbfs   pagesize=1GB   0   0

# 验证挂载
$ mount | grep huge

匿名映射或文件映射使用大页内存
# 匿名映射
addr = mmap(NULL, SIZE,
                   PROT_READ | PROT_WRITE,
                   MAP_PRIVATE | MAP_ANONYMOUS,
                   -1, 0);
# 文件映射
addr = mmap(NULL, SIZE, PROT_READ | PROT_WRITE, 
                MAP_SHARED, fd, 0);

内存使用情况查看

查看当前系统页内存的使用情况

cat /proc/buddyinfo

后面11列分别表示页的个数(1,2,4, 8, 16,32,...1024)未使用的内存。

查看当前进程的堆空间使用情况

pmap {pid}

其中[anon]表示 堆空间的使用情况。

相关推荐
wangjialelele2 分钟前
C++11、C++14、C++17、C++20新特性解析(一)
linux·c语言·开发语言·c++·c++20·visual studio
蓝队云计算20 分钟前
蓝队云揭秘:如何利用云服务器高效养殖龙虾OpenClaw?
运维·服务器·人工智能·云服务器·openclaw
ZTLJQ23 分钟前
驾驭高并发:Python协程与 async/await 完全解析
服务器·数据库·python
²º²²এ松29 分钟前
vs code连接ubuntu esp项目
linux·数据库·ubuntu
浪客灿心34 分钟前
Linux进程信号
linux
一勺菠萝丶40 分钟前
芋道框架 - API 前缀区分机制
java·linux·python
浪游东戴河1 小时前
网线简介及分类
运维·服务器·网络
不知名。。。。。。。。1 小时前
仿muduo库实现高并发---请求HttpRequest模块 响应HttpResponse模块
服务器·c++
国冶机电安装1 小时前
自动化工程:推动工业智能化与效率提升的核心技术
运维·自动化
薛定谔的悦1 小时前
嵌入式 OTA(远程固件升级)(二)
服务器·数据库·能源·储能·ota