mirror of
https://github.com/fluencelabs/redis
synced 2025-03-19 17:10:50 +00:00
rdb: saving skiplist in reversed order to accelerate the deserialisation process
This commit is contained in:
parent
271733f4f8
commit
23ec36909e
15
src/rdb.c
15
src/rdb.c
@ -704,23 +704,24 @@ ssize_t rdbSaveObject(rio *rdb, robj *o) {
|
|||||||
nwritten += n;
|
nwritten += n;
|
||||||
} else if (o->encoding == OBJ_ENCODING_SKIPLIST) {
|
} else if (o->encoding == OBJ_ENCODING_SKIPLIST) {
|
||||||
zset *zs = o->ptr;
|
zset *zs = o->ptr;
|
||||||
dictIterator *di = dictGetIterator(zs->dict);
|
zskiplist *zsl = zs->zsl;
|
||||||
dictEntry *de;
|
|
||||||
|
|
||||||
if ((n = rdbSaveLen(rdb,dictSize(zs->dict))) == -1) return -1;
|
if ((n = rdbSaveLen(rdb,zsl->length)) == -1) return -1;
|
||||||
nwritten += n;
|
nwritten += n;
|
||||||
|
|
||||||
while((de = dictNext(di)) != NULL) {
|
zskiplistNode *zn = zsl->tail;
|
||||||
sds ele = dictGetKey(de);
|
while (zn != NULL) {
|
||||||
double *score = dictGetVal(de);
|
sds ele = zn->ele;
|
||||||
|
double *score = &zn->score;
|
||||||
|
|
||||||
if ((n = rdbSaveRawString(rdb,(unsigned char*)ele,sdslen(ele)))
|
if ((n = rdbSaveRawString(rdb,(unsigned char*)ele,sdslen(ele)))
|
||||||
== -1) return -1;
|
== -1) return -1;
|
||||||
nwritten += n;
|
nwritten += n;
|
||||||
if ((n = rdbSaveBinaryDoubleValue(rdb,*score)) == -1) return -1;
|
if ((n = rdbSaveBinaryDoubleValue(rdb,*score)) == -1) return -1;
|
||||||
nwritten += n;
|
nwritten += n;
|
||||||
|
|
||||||
|
zn = zn->backward;
|
||||||
}
|
}
|
||||||
dictReleaseIterator(di);
|
|
||||||
} else {
|
} else {
|
||||||
serverPanic("Unknown sorted set encoding");
|
serverPanic("Unknown sorted set encoding");
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user