mirror of
https://github.com/fluencelabs/redis
synced 2025-03-19 09:00:51 +00:00
Prevent expirations and evictions while paused
Proposed fix to https://github.com/antirez/redis/issues/4027
This commit is contained in:
parent
e91b81c612
commit
a3e53cf9bc
@ -380,6 +380,12 @@ int freeMemoryIfNeeded(void) {
|
|||||||
long long delta;
|
long long delta;
|
||||||
int slaves = listLength(server.slaves);
|
int slaves = listLength(server.slaves);
|
||||||
|
|
||||||
|
/* We cannot free memory while clients are paused as this will require
|
||||||
|
* evictions which modify the dataset and will break the guarantee that
|
||||||
|
* data will be static while clients are paused. */
|
||||||
|
if (clientsArePaused())
|
||||||
|
goto cant_free;
|
||||||
|
|
||||||
/* Check if we are over the memory usage limit. If we are not, no need
|
/* Check if we are over the memory usage limit. If we are not, no need
|
||||||
* to subtract the slaves output buffers. We can just return ASAP. */
|
* to subtract the slaves output buffers. We can just return ASAP. */
|
||||||
mem_reported = zmalloc_used_memory();
|
mem_reported = zmalloc_used_memory();
|
||||||
|
@ -105,6 +105,10 @@ void activeExpireCycle(int type) {
|
|||||||
int dbs_per_call = CRON_DBS_PER_CALL;
|
int dbs_per_call = CRON_DBS_PER_CALL;
|
||||||
long long start = ustime(), timelimit;
|
long long start = ustime(), timelimit;
|
||||||
|
|
||||||
|
/* We cannot expire keys while clients are paused as the dataset is
|
||||||
|
* supposed to be static. */
|
||||||
|
if (clientsArePaused()) return;
|
||||||
|
|
||||||
if (type == ACTIVE_EXPIRE_CYCLE_FAST) {
|
if (type == ACTIVE_EXPIRE_CYCLE_FAST) {
|
||||||
/* Don't start a fast cycle if the previous cycle did not exited
|
/* Don't start a fast cycle if the previous cycle did not exited
|
||||||
* for time limt. Also don't repeat a fast cycle for the same period
|
* for time limt. Also don't repeat a fast cycle for the same period
|
||||||
|
Loading…
x
Reference in New Issue
Block a user