草庐IT

Volatile-LRU

全部标签

redis - 如何使用redis作为partial LRU?

我有两种类型的Redis键:post:{pid}和comment:{cid}。我想存储最多100条记录的任一类型的缓存。例如我有100条帖子记录和50条评论记录。当评论记录到来时,它会被保存。当一条帖子记录到来时,一条现有记录将被替换。 最佳答案 Redis的缓存功能做不到这一点。您需要自己跟踪和删除key。一个排序集,其中成员是一个键的名称,分数是一个时间戳,可以用于此目的。注意:LRU表示最近最少使用,而您所描述的是基于创建顺序的驱逐。细微差别。 关于redis-如何使用redis作

redis - 我想将 redis 用作 lru 缓存,我可以按 db 来做还是需要新的 redis 实例?

我想使用当前的redis实例作为lru缓存。但是,我已经在使用db0作为过期key。是否有可能将当前的redis实例用作lru缓存(例如,具有不同的数据库编号) 最佳答案 是的。这是可能的,这个想法本身并没有错。为了更准确地回答,我需要有关您的情况的更多详细信息。 关于redis-我想将redis用作lru缓存,我可以按db来做还是需要新的redis实例?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

php - Redis 的 allkeys-lru maxmemory 策略是否要求 key 设置过期?

Redis的allkeys-lrumaxmemory策略是否要求数据库中的所有键都设置过期时间?没有设置过期时的故障转移是什么? 最佳答案 allkeys-*逐出策略不关心TTL。崩溃和意外行为(看着你@ceehayoz)应该报告给项目的repo,尽管EC是一项服务,他们使用的Redis版本可能与官方OSS项目相同,也可能不同。 关于php-Redis的allkeys-lrumaxmemory策略是否要求key设置过期?,我们在StackOverflow上找到一个类似的问题:

hash - 在 LRU 上删除 Redis Hash Key 的字段

我如何在Redis上设置LRU,它不是在实例级别而是在某些特定级别。让我们说一个哈希。我使用散列键作为一个缓存桶,字段作为键,值是值。所以它就像:Redis;skey-field-value=type-key-field对我来说。如果它不是直截了当的,那么我想使用另一个数据库级LRU。(一个Redis实例有16个DB,我想将DB1用作LRU这意味着进入DB1的所有内容都将遵循LRU,而进入DB-2,3...的所有内容将不遵循LRU)。 最佳答案 我用Hash+SortedSet实现了它。在我的例子中相当于Redis规范是:散列key

caching - Redis 缓存使用 volitile-lru 抛出 OOM 错误

为了调试,我们将Redis设置为volitile-lru和10mb的最大内存我们在电子商务商店中使用Redis进行HTTP缓存-当页面上有并行请求时,错误:OOMcommandnotallowedwhenusedmemory>'maxmemory'出现。难道不应该通过将maxmemory-policy设置为volitile-lru来避免这种情况吗?redis是否不够快,无法释放内存并设置新内存(每个请求大约有200-600kb) 最佳答案 来自文档:volatile-lru:通过首先尝试移除最近较少使用的(LRU)键来逐出键,但仅在

php - 具有 LRU 过期的内存缓存

我正在为我的PHP驱动的网站寻找内存缓存。它不是高流量网站,我只是想缓存数据和某些页面的一部分以提高性能。数据大小从几个字节到几个kB不等。我目前正在使用xCache,没有遇到任何问题。转用memcached好还是redis好?有没有更好的选择? 最佳答案 如果您没有任何明显的问题,为什么现在要切换?Memcached或redis可能更好,但如果您现在不需要它们,最好还是留下它们。只要您的缓存策略是合理的并且缓存接口(interface)是抽象的,您就应该能够在以后真正觉得需要切换到可扩展缓存时添加它们。此外,PHP中的xCache

node.js - 防止为 connect-redis session 设置 TTL 以允许 allkeys-lru 用于内存策略

我已经使用connect-redis和redis包设置了一个非常简单的RedisStore。我有一个专门用于我的session存储的盒子,我想使用allkeys-lrumaxmemory策略而不是TTL进行逐出。似乎connect-redis的存储不允许设置TTL(我在创建存储时尝试在选项对象中使用-1,看起来像将TTL设置为0)。有关如何执行此操作的任何建议?另外,有人明白为什么这可能是一种不好的做法吗? 最佳答案 查看relevantsourcecode,似乎connect-redis不会让您在key未过期的情况下使用它。在我看

caching - Redis 可以将磁盘用作 LRU 缓存的一部分吗?

我们需要一个分布式LRU缓存,但它可以同时使用内存和磁盘。我们有一个大型数据集,它永久存储在磁盘上。我们从该数据集创建其他计算数据集,但仅在客户需要时才创建。由于这些辅助数据集源自持久性数据,因此我们永远不需要永久保存这些派生数据。我认为Redis可以将磁盘用作二级LRU缓存,但一直找不到任何指向这一点的文档。Redis似乎只使用磁盘来持久化整个缓存。我设想我们能够使用一堆Redis实例进行横向扩展。如果Redis做不到,是否有其他系统可以做到? 最佳答案 如果数据不适合内存,操作系统可以将其换出到磁盘。这称为虚拟内存。在这里您可以

redis - volatile-ttl 在 Redis 中如何工作?

在Redis.conf中,介绍了各种关键的逐出策略,以及有关它们工作原理的一些基础知识。我相信我想使用volatile-ttl,但我找不到关于它如何工作的足够信息。表面上,清澈见底;最接近过期时间的key最先出现。如果Redis逐出具有过期时间的所有键怎么办?假设它仍然需要继续逐出以保持在maxmemory以下,那么它接下来选择什么来逐出?#MAXMEMORYPOLICY:howRediswillselectwhattoremovewhenmaxmemory#isreached.Youcanselectamongfivebehaviors:##volatile-lru->removet

redis - 当内存被填满时,使用 Volatile-LRU maxmemory 策略的 Redis 缓存会发生什么?

我在Azure中有一个redis缓存,最大内存策略设置为Volatile-LRU。写入Redis时,我没有为key添加到期时间。在这种情况下,当缓存内存被填满时会发生什么? 最佳答案 在volatile-lru策略下,redis永远不会驱逐没有过期的键。如果所有内存都被未设置过期的key用完,那么下次您使用需要分配比可用内存更多内存的命令时,比如SET,该命令将失败,您将得到此错误消息:OOMcommandnotallowedwhenusedmemory>'maxmemory'您仍然可以使用不分配内存的命令,例如GET。如果你让你的