LevelDB场景分析1--整体结构分析
基本用法
数据结构
class DBImpl : public DB
{
private:struct CompactionState;struct Writer;// Information kept for every waiting writerEnv* const env_; // 文件,目录,日志,Schedule线程const InternalKeyComparator internal_comparator_;const InternalFilterPolicy internal_filter_policy_; // 提高随机读的性能const Options options_; // Options to control the behavior of a database (passed to DB::Open)bool owns_info_log_;bool owns_cache_;const std::string dbname_;// table_cache_ provides its own synchronizationTableCache* table_cache_;// Lock over the persistent DB state. Non-NULL iff successfully acquired.FileLock* db_lock_;// State below is protected by mutex_port::Mutex mutex_;port::AtomicPointer shutting_down_;port::CondVar bg_cv_; // Signalled when background work finishesMemTable* mem_;MemTable* imm_; // Memtable being compactedport::AtomicPointer has_imm_; // So bg thread can detect non-NULL imm_WritableFile* logfile_;uint64_t logfile_number_;log::Writer* log_;uint32_t seed_; // For sampling.// Queue of writers.std::deque<Writer*> writers_;WriteBatch* tmp_batch_;SnapshotList snapshots_;// Set of table files to protect from deletion because they are// part of ongoing compactions.std::set<uint64_t> pending_outputs_;// Has a background compaction been scheduled or is running?bool bg_compaction_scheduled_;ManualCompaction* manual_compaction_;VersionSet* versions_;// Have we encountered a background error in paranoid mode?Status bg_error_;CompactionStats stats_[config::kNumLevels];
};
红色部分成员是需要重点关注的。
主要场景
public:Status DB::Open(const Options& options, const std::string& dbname, DB** dbptr)
// Implementations of the DB interface
virtual Status Put(const WriteOptions&, const Slice& key, const Slice& value);virtual Status Delete(const WriteOptions&, const Slice& key);virtual Status Write(const WriteOptions& options, WriteBatch* updates);virtual Status Get(const ReadOptions& options,const Slice& key,std::string* value);virtual Iterator* NewIterator(const ReadOptions&);virtual const Snapshot* GetSnapshot();virtual void ReleaseSnapshot(const Snapshot* snapshot);virtual bool GetProperty(const Slice& property, std::string* value);virtual void GetApproximateSizes(const Range* range, int n, uint64_t* sizes);virtual void CompactRange(const Slice* begin, const Slice* end);// Extra methods (for testing) that are not in the public DB interface// Record a sample of bytes read at the specified internal key.// Samples are taken approximately once every config::kReadBytesPeriod// bytes.void RecordReadSample(Slice key);
private:
Iterator* NewInternalIterator(const ReadOptions&,SequenceNumber* latest_snapshot,uint32_t* seed);Status NewDB();// Recover the descriptor from persistent storage. May do a significant// amount of work to recover recently logged updates. Any changes to// be made to the descriptor are added to *edit.Status Recover(VersionEdit* edit) EXCLUSIVE_LOCKS_REQUIRED(mutex_);void MaybeIgnoreError(Status* s) const;// Delete any unneeded files and stale in-memory entries.void DeleteObsoleteFiles();// Compact the in-memory write buffer to disk. Switches to a new// log-file/memtable and writes a new descriptor iff successful.// Errors are recorded in bg_error_.void CompactMemTable() EXCLUSIVE_LOCKS_REQUIRED(mutex_);Status RecoverLogFile(uint64_t log_number,VersionEdit* edit,SequenceNumber* max_sequence)EXCLUSIVE_LOCKS_REQUIRED(mutex_);Status WriteLevel0Table(MemTable* mem, VersionEdit* edit, Version* base)EXCLUSIVE_LOCKS_REQUIRED(mutex_);Status MakeRoomForWrite(bool force /* compact even if there is room? */)EXCLUSIVE_LOCKS_REQUIRED(mutex_);WriteBatch* BuildBatchGroup(Writer** last_writer);void RecordBackgroundError(const Status& s);void MaybeScheduleCompaction() EXCLUSIVE_LOCKS_REQUIRED(mutex_);static void BGWork(void* db);void BackgroundCall();void BackgroundCompaction() EXCLUSIVE_LOCKS_REQUIRED(mutex_);void CleanupCompaction(CompactionState* compact)EXCLUSIVE_LOCKS_REQUIRED(mutex_);Status DoCompactionWork(CompactionState* compact)EXCLUSIVE_LOCKS_REQUIRED(mutex_);Status OpenCompactionOutputFile(CompactionState* compact);Status FinishCompactionOutputFile(CompactionState* compact, Iterator* input);Status InstallCompactionResults(CompactionState* compact)EXCLUSIVE_LOCKS_REQUIRED(mutex_);
综合介绍
LevelDB主要有以下几个部分的内存开销:memtable,immutable table,table cache,block cache
memtable和immutable table的大小由 options_.write_buffer_size决定。
table cache由max_open_files决定数量。
block cache最大可以传入 size_t的大小。
由于使用了mmap,因此需要尽量使内存大于数据规模。否则可能造成随机读爆慢。
LevelDB场景分析1--整体结构分析的更多相关文章
- LevelDB场景分析4--BackgroundCompaction
1.DBImpl::Open uint64_t new_log_number = impl->versions_->NewFileNumber(); WritableF ...
- LevelDB场景分析2--Open
1.源码 1 Status DB::Open(const Options& options, const std::string& dbname, uint64_t new_ ...
- EasyNVR智能云终端硬件使用场景分析:如何实现软硬一体的视频上云整体解决方案
背景分析 在于众多的客户交流中,经常会被客户问到,"EasyNVR到底是软件还是硬件?"."EasyNVR能否出一个硬件的版本,摆脱自建服务器的压力?".&qu ...
- [阿里DIN] 深度兴趣网络源码分析 之 整体代码结构
[阿里DIN] 深度兴趣网络源码分析 之 整体代码结构 目录 [阿里DIN] 深度兴趣网络源码分析 之 整体代码结构 0x00 摘要 0x01 文件简介 0x02 总体架构 0x03 总体代码 0x0 ...
- JVM之调优及常见场景分析
JVM调优 GC调优是最后要做的工作,GC调优的目的可以总结为下面两点: 减少对象晋升到老年代的数量 减少FullGC的执行时间 通过监控排查问题及验证优化结果,可以分为: 命令监控:jps.jinf ...
- TYPESDK手游聚合SDK服务端设计思路与架构之一:应用场景分析
TYPESDK 服务端设计思路与架构之一:应用场景分析 作为一个渠道SDK统一接入框架,TYPESDK从一开始,所面对的需求场景就是多款游戏,通过一个统一的SDK服务端,能够同时接入几十个甚至几百个各 ...
- Duilib源码分析(六)整体流程
在<Duilib源码分析(一)整体框架>.<Duilib源码分析(二)控件构造器—CDialogBuilder>以及<Duilib源码分析(三)XML解析器—CMarku ...
- Oracle dbms_lock.sleep()存储过程使用技巧-场景-分析-实例
<Oracle dbms_lock.sleep()存储过程使用技巧>-场景-分析-实例 摘要:今天是2014年3月10日,北京,雾霾,下午组织相关部门开会.会议的结尾一名开发工程师找到了我 ...
- 理解 python metaclass使用技巧与应用场景分析
理解python metaclass使用技巧与应用场景分析 参考: decorator与metaclass:http://jfine-python-classes.readthedocs. ...
随机推荐
- tensorflow 之常见模块conv,bn...实现
使用tensorflow时,会发现tf.nn,tf.layers, tf.contrib模块有很多功能是重复的,尤其是卷积操作,在使用的时候,我们可以根据需要现在不同的模块.但有些时候可以一起混用. ...
- Copy List with Random Pointer leetcode java
题目: A linked list is given such that each node contains an additional random pointer which could poi ...
- DIV+CSS自适应窗口高度
<html> <head> <title>DIV+CSS自适应窗口高度</title> <style type="text/css&qu ...
- activity 保存数据
activity 保存数据对android的商业项目十分的重要,譬如你在发微博的时候,突然来了一个电话,你洋洋洒洒写了100个字,你不能保存的话,你岂不要卖要骂娘. 那activity究竟是保存数据的 ...
- 【翻译自mos文章】CRS显示 正在执行的db instance 是offline状态
CRS显示 正在执行的db instance 是offline状态 转自: CRS shows Running Instance Status as OFFLINE (Doc ID 1673397.1 ...
- AIDL旅行记之开篇AIDL基本介绍
嗨,伙伴们,计划了一周的想法最终要在这一刻实现了. 一直都想写一个博客专栏,但是总是鼓不起勇气来写.感觉自己的水量还不太够.哈哈.这次下定决心,与小伙伴们一起分享下Android中的AIDL,从此,也 ...
- 多个桌面Deskspace如何使用
1 给Deskspace设置背景.在DeskSpace选项中设置显示背景为天空箱体图像(软件自带的图像效果,也可以使用静态图像,即自己的图片) 2 给六个桌面各设置一个背景(也可以使用同一个背景)右击 ...
- 如何安装Tomcat
1 请确认已经安装了JRE或JDK并配置好了环境变量,关于如何配置环境变量,参考我的另一篇文章"WIN7如何配置java环境变量,运行环境.doc" 2 用记事本打开bin目录下的 ...
- 带"叉叉"的GridView
由于需要用到“删除图片”的功能,需要写这样一个小demo: 对之前博文的修改 发现imageView监听点击事件 效果实在不敢恭维,因此换个方式:设置Touch的监听函数, 下面的Demo没有改过来哈 ...
- uva 10670 Work Reduction(贪心)
题目连接:10670 - Work Reduction 题目大意:有tol的工作量,和要求达到的工作剩余量sur,然后是公司总数,对应每个公司提供两种服务,1.完成一个工作量,2.完成当前未完成工作量 ...
