聊聊BitCaskKeyDir
时间:2022-07-24
本文章向大家介绍聊聊BitCaskKeyDir,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
序
本文主要研究一下BitCaskKeyDir
BitCaskKeyDir
bitcask-java/src/main/java/com/trifork/bitcask/BitCaskKeyDir.java
public class BitCaskKeyDir {
Map<ByteString, BitCaskEntry> map = new HashMap<ByteString, BitCaskEntry>();
ReadWriteLock rwl = new ReentrantReadWriteLock();
private boolean is_ready;
public boolean put(ByteString key, BitCaskEntry ent) {
Lock writeLock = rwl.writeLock();
writeLock.lock();
try {
BitCaskEntry old = map.get(key);
if (old == null) {
map.put(key, ent);
return true;
} else if (ent.is_newer_than(old)) {
map.put(key, ent);
return true;
} else {
return false;
}
} finally {
writeLock.unlock();
}
}
public BitCaskEntry get(ByteString key) {
Lock readLock = rwl.readLock();
readLock.lock();
try {
return map.get(key);
} finally {
readLock.unlock();
}
}
//......
}
- BitCaskKeyDir提供了map来存放BitCaskEntry;其put方法使用writeLock.lock(),对于old值为null的或者新值大于old值的才put进去,否则返回false,最后writeLock.unlock();其get方法使用readLock.lock()从map读取指定key的值,最后readLock.unlock()
key_dirs
bitcask-java/src/main/java/com/trifork/bitcask/BitCaskKeyDir.java
public class BitCaskKeyDir {
public static Map<File,BitCaskKeyDir> key_dirs = new HashMap<File, BitCaskKeyDir>();
public static Lock keydir_lock = new ReentrantLock();
public static BitCaskKeyDir keydir_new(File dirname, int openTimeoutSecs) throws IOException {
File abs_name = dirname.getAbsoluteFile();
BitCaskKeyDir dir;
keydir_lock.lock();
try {
dir = key_dirs.get(abs_name);
if (dir == null) {
dir = new BitCaskKeyDir();
key_dirs.put(abs_name, dir);
return dir;
}
} finally {
keydir_lock.unlock();
}
if (dir.wait_for_ready(openTimeoutSecs)) {
return dir;
} else {
throw new IOException("timeout while waiting for keydir");
}
}
public synchronized boolean is_ready() {
return is_ready;
}
public synchronized void mark_ready() {
is_ready = true;
this.notifyAll();
}
public synchronized boolean wait_for_ready(int timeout_secs) {
long now = System.currentTimeMillis();
long abs_timeout = now + (timeout_secs * 1000);
while (!is_ready && now < abs_timeout) {
try {
wait();
} catch (InterruptedException e) {
// ignore
}
now = System.currentTimeMillis();
}
return is_ready;
}
}
- BitCaskKeyDir定义了static的key_dirs,用于存放指定File的BitCaskKeyDir;其keydir_new会针对不存在的BitCaskKeyDir进行创建,最后通过dir.wait_for_ready(openTimeoutSecs)等待ready
小结
BitCaskKeyDir提供了map来存放BitCaskEntry;其put方法使用writeLock.lock(),对于old值为null的或者新值大于old值的才put进去,否则返回false,最后writeLock.unlock();其get方法使用readLock.lock()从map读取指定key的值,最后readLock.unlock()
doc
- BitCaskKeyDir
- Golang学习--GroupCache的使用
- 基于 Webpack & Vue & Vue-Router 的 SPA 初体验
- GO语言高并发学习心得体会例
- Go 语言实现的网络连接池:Pool
- go语言操作redis连接池的方法
- WebVR如此近 - three.js的WebVR示例程序解析
- 【Dev Club分享】基于RxJava的一种MVP实现
- Android 动态链接库加载原理及 HotFix 方案介绍
- 如果裸写一个goroutine pool
- 【Dev Club 分享】微信 iOS SQLite 源码优化实践
- 移动客户端中高效使用 SQLite
- 【Dev Club 分享】微信热补丁 Tinker 的实践演进之路
- Android 进程保活招式大全
- 【Dev Club 分享】H5 视频直播那些事
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux系统—Centos7安装教程
- 2.2 IPython基础
- Linux系统crond、rsync、打包备份数据操作实战
- 2.3 Python语言基础
- 开发需求
- Linux系统组建SVN服务器
- 面向对象学习
- 常用模块
- 代理错误[WinError 10061]
- Linux系统JDK+Tomcat环境安装布署过程
- Python version 3.6 required, which was not found in the registry错误解决
- LNMP架构应用实战——Nginx服务介绍与安装
- 使用tidylib解决不规则网页问题
- LNMP架构应用实战——Nginx服务配置文件介绍
- Mac Sublime Text3快捷键