memcached 线程总结
2015-07-28 11:36
459 查看
本文针对的是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"命令的通知
(2) 执行reassign:把源slab的第1页的所有item从hash表和LRU队列里移除;然后将源slab的第1页迁移,作为目标slab的最后一页。
4. LRU维护线程 [ lru_maintainer_thread ]
(1) 清理LRU队列
清除过期的数据和被flush的数据
将过多的HOT和WARM数据迁移到COLD_LRU
将刚访问过的数据从 HOT_LRU 或 WARM_LRU中迁移到队列前端
将刚访问过的数据从 COLD_LRU 迁移到 WARM_LRU
(2) 在HOT_LRU, WARM_LRU, COLD_LRU中插入 crawl item,通知 crawl线程执行
5. LRU crawl线程 [ item_crawler_thread ]
(1) 接收LRU维护线程的通知,开始执行
(2) 清除HOT, WARM, COLD 中 过期的数据和被flush的数据
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"命令的通知
(2) 执行reassign:把源slab的第1页的所有item从hash表和LRU队列里移除;然后将源slab的第1页迁移,作为目标slab的最后一页。
4. LRU维护线程 [ lru_maintainer_thread ]
(1) 清理LRU队列
清除过期的数据和被flush的数据
将过多的HOT和WARM数据迁移到COLD_LRU
将刚访问过的数据从 HOT_LRU 或 WARM_LRU中迁移到队列前端
将刚访问过的数据从 COLD_LRU 迁移到 WARM_LRU
(2) 在HOT_LRU, WARM_LRU, COLD_LRU中插入 crawl item,通知 crawl线程执行
5. LRU crawl线程 [ item_crawler_thread ]
(1) 接收LRU维护线程的通知,开始执行
(2) 清除HOT, WARM, COLD 中 过期的数据和被flush的数据
相关文章推荐
- Nginx + MySQL + PHP + Xcache + Memcached
- redis做DB缓存mysql做冗余数据库,memcached主备存储session下的集群高可用方案
- PHP中memcached的使用
- Memcached简介
- PHP实现的memcache环形队列类实例
- Memcached实现内存缓存(一)
- memcache操作
- 【飞天奔月出品】memcached四大注意事项(key长度,空格限制,最大item)
- Memcached 群集高可用性(HA)架构
- xmemcached net.rubyeye.xmemcached.exception.UnknownCommandException
- 用Varnish和Memcached缓存给WordPress网站提速-内存级加速
- Memcached Java使用
- win7下安装memcache
- 百度地图sdk接入报错:com.baidu.platform.comjni.map.commonmemcache.JNICommonMemCache.Create:()J
- 为什么不能用memcached存储Session?
- 为什么不能用memcached存储Session?
- memcache和memcached区别
- memcached问题集锦
- REDIS与MEMCACHED的区别
- Memcached工作原理介绍