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]表示 堆空间的使用情况。

相关推荐
JY.yuyu2 小时前
Linux计划任务进程
linux·运维·服务器
single-life2 小时前
Linux 下 部署es+nebula(附带内网部署方式)
linux·运维·elasticsearch·nebula
last demo2 小时前
docker镜像
运维·docker·容器
ICT董老师2 小时前
kubernetes中operator与helm有什么区别?部署mysql集群是选择operator部署还是helm chart部署?
linux·运维·mysql·云原生·容器·kubernetes
wjhx2 小时前
对ubuntu22.04版本日志的处理
linux·ubuntu
缘来是黎2 小时前
运维面试场景题——故障排查与解决
运维·面试·职场和发展
乾元2 小时前
构建你的个人「网络 AI 实验室」——硬件、模拟器与数据集清单
运维·网络·人工智能·网络协议·架构
情缘晓梦.2 小时前
Linux指令和权限
linux·运维·服务器
ybdesire2 小时前
Joern服务器启动后cpgqls-client结合python编程进行扫描
运维·服务器·python