memcache容量用完会怎么样?

来源:互联网 发布:高等数学软件手机版 编辑:程序博客网 时间:2024/04/19 14:56

满了之后不会重启,会让旧的数据失效,memcached满了会利用LRU算法让很久没使用过的记录失效,新的记录会替换失效的记录,但是因为memcached是根据存入记录的大小根据hash算法映射到某一个内存分片上(SLAB),所以很可能会出现如果存的数据都是等长的,比如登陆session信息、验证码信息之类的,memcached会只存在某一个slab中,而每一个slab中的page数量是有限制的,当超过之后memcached就在这个slab种执行LRU算法,淘汰旧的记录,所以很有可能你分给memcached了100M的内存空间,但是可能某个slab中只用掉了很少,但是新数据写入后还是要在这个slab中进行LRU,旧的数据还是会丢失,内存却浪费了很多没用,所以如果所存的数据有命中率要求,不能接受丢失数据的情况,那这种就会有问题了,如果是等长的数据可能需要对源代码进行修改,使之适合存放等长数据。


转自:http://bbs.phpchina.com/thread-217512-1-1.html点击打开链接


原创粉丝点击