Linux内存碎片

有没有办法检测 Linux上的内存碎片?这是因为在一些长期运行的服务器上,我注意到性能下降,只有在重新启动进程后,我才能看到更好的性能.使用linux巨大页面支持时我注意到了更多 – linux中的大页面更容易出现碎片吗?

我特别看了/ proc / buddyinfo.我想知道是否有更好的方法(不仅仅是CLI命令本身,任何程序或理论背景都可以)来查看它.

解决方法

我正在回答 linux标签.我的回答仅针对Linux.

是的,大页面更容易碎片化.内存有两种视图,一种是进程获取的视图(虚拟),另一种是内核管理的视图(实际).任何页面越大,将其邻居分组(并与其保持一致)就越困难,尤其是当您的服务在一个系统上运行时,该系统也必须支持其他默认情况下分配和写入更多内存的系统实际上最终使用.

内核对(真实)授权地址的映射是私有的.用户空间在内核呈现它们时有一个很好的理由,因为内核需要能够过度使用而不会混淆用户空间.你的进程得到了一个漂亮的,连续的“迪士尼”地址空间,可以在其中工作,无视内核在幕后实际使用的内存.

您在长时间运行的服务器上看到性能下降的原因很可能是因为未明确锁定的已分配块(例如mlock()/ mlockall()或posix_madvise())并且暂时未被修改,这意味着您的当必须读取它们时,服务滑动到磁盘.修改此行为会使您的进程成为一个糟糕的邻居,这就是为什么许多人将他们的RDBMS放在一个完全不同于web / php / python / ruby​​ / whatever的服务器上的原因.理所当然地解决这个问题的唯一方法是减少对连续区块的竞争.

当页面A在内存中并且页面B已经移动到交换时,碎片只是非常明显(在大多数情况下).当然,重新启动您的服务似乎可以“解决”这个问题,但这只是因为内核还没有机会在其过度使用率的范围内将(现在)新分配的块分页出来.

事实上,在高负载下重新启动(假设)’apache’可能会将其他服务拥有的块直接发送到磁盘.所以是的,’apache’会在短时间内得到改善,但’mysql’可能会受到影响……至少在内核使得它们在没有足够的物理内存的情况下遭受同等程度时会受到影响.

添加更多内存,或拆分要求苛刻的malloc()消费者:)它不仅仅是你需要关注的碎片.

尝试使用vmstat来概述实际存储的位置.

相关文章

linux常用进程通信方式包括管道(pipe)、有名管道(FIFO)、...
Linux性能观测工具按类别可分为系统级别和进程级别,系统级别...
本文详细介绍了curl命令基础和高级用法,包括跳过https的证书...
本文包含作者工作中常用到的一些命令,用于诊断网络、磁盘占满...
linux的平均负载表示运行态和就绪态及不可中断状态(正在io)的...
CPU上下文频繁切换会导致系统性能下降,切换分为进程切换、线...