mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 08:38:27 -05:00
Fix rdb save by allowing dumping of expire keys, so that when
we add a new slave, and do a failover, eighter by manual or not, other local slaves will delete the expired keys properly.
This commit is contained in:
parent
6536ce27a4
commit
2a887bd53f
@ -988,16 +988,13 @@ size_t rdbSavedObjectLen(robj *o) {
|
|||||||
* On error -1 is returned.
|
* On error -1 is returned.
|
||||||
* On success if the key was actually saved 1 is returned, otherwise 0
|
* On success if the key was actually saved 1 is returned, otherwise 0
|
||||||
* is returned (the key was already expired). */
|
* is returned (the key was already expired). */
|
||||||
int rdbSaveKeyValuePair(rio *rdb, robj *key, robj *val,
|
int rdbSaveKeyValuePair(rio *rdb, robj *key, robj *val, long long expiretime)
|
||||||
long long expiretime, long long now)
|
|
||||||
{
|
{
|
||||||
int savelru = server.maxmemory_policy & MAXMEMORY_FLAG_LRU;
|
int savelru = server.maxmemory_policy & MAXMEMORY_FLAG_LRU;
|
||||||
int savelfu = server.maxmemory_policy & MAXMEMORY_FLAG_LFU;
|
int savelfu = server.maxmemory_policy & MAXMEMORY_FLAG_LFU;
|
||||||
|
|
||||||
/* Save the expire time */
|
/* Save the expire time */
|
||||||
if (expiretime != -1) {
|
if (expiretime != -1) {
|
||||||
/* If this key is already expired skip it */
|
|
||||||
if (expiretime < now) return 0;
|
|
||||||
if (rdbSaveType(rdb,RDB_OPCODE_EXPIRETIME_MS) == -1) return -1;
|
if (rdbSaveType(rdb,RDB_OPCODE_EXPIRETIME_MS) == -1) return -1;
|
||||||
if (rdbSaveMillisecondTime(rdb,expiretime) == -1) return -1;
|
if (rdbSaveMillisecondTime(rdb,expiretime) == -1) return -1;
|
||||||
}
|
}
|
||||||
@ -1091,7 +1088,6 @@ int rdbSaveRio(rio *rdb, int *error, int flags, rdbSaveInfo *rsi) {
|
|||||||
dictEntry *de;
|
dictEntry *de;
|
||||||
char magic[10];
|
char magic[10];
|
||||||
int j;
|
int j;
|
||||||
long long now = mstime();
|
|
||||||
uint64_t cksum;
|
uint64_t cksum;
|
||||||
size_t processed = 0;
|
size_t processed = 0;
|
||||||
|
|
||||||
@ -1134,7 +1130,7 @@ int rdbSaveRio(rio *rdb, int *error, int flags, rdbSaveInfo *rsi) {
|
|||||||
|
|
||||||
initStaticStringObject(key,keystr);
|
initStaticStringObject(key,keystr);
|
||||||
expire = getExpire(db,&key);
|
expire = getExpire(db,&key);
|
||||||
if (rdbSaveKeyValuePair(rdb,&key,o,expire,now) == -1) goto werr;
|
if (rdbSaveKeyValuePair(rdb,&key,o,expire) == -1) goto werr;
|
||||||
|
|
||||||
/* When this RDB is produced as part of an AOF rewrite, move
|
/* When this RDB is produced as part of an AOF rewrite, move
|
||||||
* accumulated diff from parent to child while rewriting in
|
* accumulated diff from parent to child while rewriting in
|
||||||
|
@ -142,7 +142,7 @@ ssize_t rdbSaveObject(rio *rdb, robj *o);
|
|||||||
size_t rdbSavedObjectLen(robj *o);
|
size_t rdbSavedObjectLen(robj *o);
|
||||||
robj *rdbLoadObject(int type, rio *rdb);
|
robj *rdbLoadObject(int type, rio *rdb);
|
||||||
void backgroundSaveDoneHandler(int exitcode, int bysignal);
|
void backgroundSaveDoneHandler(int exitcode, int bysignal);
|
||||||
int rdbSaveKeyValuePair(rio *rdb, robj *key, robj *val, long long expiretime, long long now);
|
int rdbSaveKeyValuePair(rio *rdb, robj *key, robj *val, long long expiretime);
|
||||||
robj *rdbLoadStringObject(rio *rdb);
|
robj *rdbLoadStringObject(rio *rdb);
|
||||||
ssize_t rdbSaveStringObject(rio *rdb, robj *obj);
|
ssize_t rdbSaveStringObject(rio *rdb, robj *obj);
|
||||||
ssize_t rdbSaveRawString(rio *rdb, unsigned char *s, size_t len);
|
ssize_t rdbSaveRawString(rio *rdb, unsigned char *s, size_t len);
|
||||||
|
Loading…
Reference in New Issue
Block a user