码迷,mamicode.com
首页 > 数据库 > 详细

ssdb binlog机制 存疑

时间:2016-04-10 12:45:29      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:

int BinlogQueue::del_range(uint64_t start, uint64_t end){
    while(start <= end){
        leveldb::WriteBatch batch;
        for(int count = 0; start <= end && count < 1000; start++, count++){
            batch.Delete(encode_seq_key(start));
        }
//这里会实际删除数据库的数据,但是del_range会在binlog定期清理函数中调用

//问题:log_clean_thread_func的定位应该是清理min/last seq ,维护一个范围而已,为何要实际删除数据呢?况且,set的kv值,在commit时候,实际写入了db了(然后清理log时候再给删除)?实在不明白!

        leveldb::Status s = db->Write(leveldb::WriteOptions(), &batch);
        if(!s.ok()){
            return -1;
        }
    }
    return 0;
}

  

ssdb binlog机制 存疑

标签:

原文地址:http://www.cnblogs.com/zhaoyl/p/5373736.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!