设为首页 收藏本站
查看: 650|回复: 0

[经验分享] linux内存分配slub的几个疑问

[复制链接]

尚未签到

发表于 2016-3-3 05:06:17 | 显示全部楼层 |阅读模式
  对于SLUB不熟的同学可以先跳过了,涉及的东西比较细致。
  简单来说SLUB的结构是N(CPU数)个kmem_cache_cpu,和一个kmem_cache_node组成。其中kmem_cache_cpu的目的是为了从技术层面上提高CPU命中缓存,以及在同一个页面上不出现一个脏的内存(即不同时被多个CPU持有)。我把这个实现机制手工在WINDOWS下实现了一套,在开启多个kmem_cache_cpu的时候出现了个问题:
  1.在释放对象的时候,判断是否是当前kmem_cache_cpu页面所在
  2.如果是,则直接插入
  3.如果不是,释放到邻居节点
  

  如果是单个kmem_cache_cpu肯定没问题,但是在多个kmem_cache_cpu下,很可能会把其中一个kmem_cache_cpu已经持有的页面释放到邻居节点。举个例子:
  

  假设一个页面地址是0-9,
  kmem_cache_cpu1,持有A页面,空闲的情况为A0-A5
  kmem_cache_cpu2,持有B页面,
  当轮到kmem_cache_cpu2执行的时候,一个A页面的地址A6释放,程序检测到非B页面,则直接释放到邻居节点。那么这个时候A页面已经被切割成两段,并且在公共的邻居节点中。这个时候反而是增加了内存的脏度。后仔细看代码发现,源码中有这段:
  


struct kmem_cache_cpu {
void **freelist;/* Pointer to first free per cpu object */
struct page *page;/* The slab from which we are allocating */
int node;/* The node of the page (or -1 for debug) */
unsigned int offset;/* Freepointer offset (in word units) */
unsigned int objsize;/* Size of an object (from kmem_cache) */
#ifdef CONFIG_SLUB_STATS
unsigned stat[NR_SLUB_STAT_ITEMS];
#endif
};
    注意到struct page *page;了吗?之前一直忽略它。并且真相在分配的函数里面,
  如果freelist无效的话,会多查询一次page页的地址。
  

  

  2011年1月15日增
  细致看了下,觉得这个地方还是有BUG。
  释放上就两个步骤
  1)走本地PAGE
  2)NODE节点
  

  申请上比较复杂
  1)走本地freelist
  2)走本页page
  3)走邻居节点
  4)走系统
  

  并且做了一些看似应该释放做的事:
  1)如果page和freelist都为空,则走deactivate_slab();
     deactivate_slab中有很多兼容的判断,要一一舍弃。阅读源码最痛苦的就是这点。
     其中用到了个值page->inuse。这个值很奇怪,它指的是在kmem_cache_cpu当前+使用中的对象,如果释放了则
     进行减一,所以你看不到他的++。
     1)如果page->inuse大于0,并且freelist还有值,加入邻居。这个估计是兼容的代码,之前的判断freelist不为空
     2)反之,加到邻居链表。
     3)如果当前邻居链表满,则释放掉
  2)如果freelist为空,page不为空,很可能其他的kmem_cache_cpu释放了对象,则走load_freelist:
  

  

  疑问一:就是加入邻居链表和释放加入邻居链表的冲突。从条件上看,其实两个都是依赖page->freelist是否为空加入,但是在deactivate_slab加入邻居节点后,并没有对page->freelist进行处理,如果这时候有对象释放,是否会造成重复加入?
  这个疑问是我弄错了,如果page->inuse==0,表示对象都已经释放,不会触发再次释放
  
  疑问二:在多个kmem_cache_cpu情况下,释放的元素都是放到共同的邻居页面,很有可能被其他的kmem_cache_cpu直接取到,这样就造成2个不同的kmem_cache_cpu共享同个页面,这就违背了里面缓存命中的功能。
  

  

  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-185511-1-1.html 上篇帖子: Linux硬件状况 下篇帖子: linux yum安装wireshark(网络分析工具)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表