本文针对的是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"命令的通知</