mirror of
https://github.com/fluencelabs/redis
synced 2025-04-30 13:02:14 +00:00
for (p)expireat use absolute time, without double recomputation
This commit is contained in:
parent
b518a83525
commit
81a28fe131
17
src/db.c
17
src/db.c
@ -516,7 +516,7 @@ void expireGenericCommand(redisClient *c, long long offset, int unit) {
|
||||
return;
|
||||
|
||||
if (unit == UNIT_SECONDS) milliseconds *= 1000;
|
||||
milliseconds -= offset;
|
||||
milliseconds += offset;
|
||||
|
||||
de = dictFind(c->db->dict,key->ptr);
|
||||
if (de == NULL) {
|
||||
@ -543,8 +543,7 @@ void expireGenericCommand(redisClient *c, long long offset, int unit) {
|
||||
addReply(c, shared.cone);
|
||||
return;
|
||||
} else {
|
||||
long long when = mstime()+milliseconds;
|
||||
setExpire(c->db,key,when);
|
||||
setExpire(c->db,key,milliseconds);
|
||||
addReply(c,shared.cone);
|
||||
signalModifiedKey(c->db,key);
|
||||
server.dirty++;
|
||||
@ -553,19 +552,19 @@ void expireGenericCommand(redisClient *c, long long offset, int unit) {
|
||||
}
|
||||
|
||||
void expireCommand(redisClient *c) {
|
||||
expireGenericCommand(c,0,UNIT_SECONDS);
|
||||
}
|
||||
|
||||
void expireatCommand(redisClient *c) {
|
||||
expireGenericCommand(c,mstime(),UNIT_SECONDS);
|
||||
}
|
||||
|
||||
void expireatCommand(redisClient *c) {
|
||||
expireGenericCommand(c,0,UNIT_SECONDS);
|
||||
}
|
||||
|
||||
void pexpireCommand(redisClient *c) {
|
||||
expireGenericCommand(c,0,UNIT_MILLISECONDS);
|
||||
expireGenericCommand(c,mstime(),UNIT_MILLISECONDS);
|
||||
}
|
||||
|
||||
void pexpireatCommand(redisClient *c) {
|
||||
expireGenericCommand(c,mstime(),UNIT_MILLISECONDS);
|
||||
expireGenericCommand(c,0,UNIT_MILLISECONDS);
|
||||
}
|
||||
|
||||
void ttlGenericCommand(redisClient *c, int output_ms) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user