memcached 线程总结

本文针对的是memcached-1.4.24版本。

1. hash表扩容线程  [ assoc_maintenance_thread ]

    (1) 创建新的hash表

          当插入item时,如果hash表里的数据量超了桶数量的1.5倍,则触发"创建新的hash表"。

          在"创建新的hash表"之前,会暂时挂起以下线程:rebalance线程、LRU维护线程、LRU crawl线程、worker线程。创建完成之后,再恢复这些线程。

    (2) 将旧hash表数据迁移到新hash中

2. automove线程 [ slab_maintenance_thread ]

    (1) 检测是否需要进行rebalance:挑选出连续三次没有被踢的slab作为源,连续三次被踢得最惨的slab作为目标,为rebalance作准备。

    (2) 通知rebalance线程执行

3. rebalance线程 [ slab_rebalance_thread ]

    (1) 接收automove线程的通知,或接收"slabs reassign"命令的通知</

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值