Memcached-如何防止memcache丢失数据?
内存没有全部占用的情况下,memcached出现了丢失缓存数据的现象,如何有效的利用内存碎片,防止数据丢失?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
内存没有全部占用的情况下,memcached出现了丢失缓存数据的现象,如何有效的利用内存碎片,防止数据丢失?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(1)
出现这个问题的原因在于memcached默认使用Slab Allocator的方式进行内存分配,该方式不会释放已分配的内存,而是重复使用已分配的内存,这就造成了问题中所说的数据丢失,命中下降的问题。解决办法是在Memcached启动时,使用如下方法来增加内存的分配,或是禁用LRU来避免出现该问题。
$ memcached -M -m 1024
“-M”参数表示禁止LRU,“-m”选项是用来指定最大内存大小的。不指定具体数值则使用默认值64MB。
详细请参考:memcached server LRU 深入分析