leveldb 内部写操作为什么要用互斥锁保证同步

2016-11-23 00:00:46 +08:00
 HxSeek

如果多线程向 leveldb 执行写操作,为什么其内部机制要保证每个写操作要互斥锁来保证同步?不互斥不行吗(不互斥的话会出现什么情况)?我觉得,既然不是修改同一个数据,只是一起同时写入内存中,应该没问题吧?

1300 次点击
所在节点    数据库
6 条回复
auser
2016-11-23 00:05:52 +08:00
虽然不知道内部机制 但感觉这个问题跟链表添加新元素不要互斥实现线程安全差不多
IwfWcf
2016-11-23 02:47:18 +08:00
SkipList 不允许并发写
HxSeek
2016-11-23 09:50:25 +08:00
@IwfWcf 如果不是 skiplist 的话就可以了?
enenaaa
2016-11-23 11:01:10 +08:00
不熟悉 leveldb ,但除了用户数据, 还要维护全局索引、计数、状态之类的吧。 这些操作都需要加锁。
IwfWcf
2016-11-23 11:27:37 +08:00
@HxSeek 要提供有序的特性,不用 SkipList 你想用什么数据结构?平衡树连读都要加锁
nelson
2016-11-23 14:36:33 +08:00
凭印象回答,这个锁区间里做的事情应该不单单是改 skip list ,还有写 WAL , mutable/imputable list 切换、分配流水号等等,不过已经在粒度上控制得很好了, I/O 部分是在锁之外的。

有个比较巧妙的地方是,会把多个 Write 的操作合并起来,交由其中一个调用线程来完成。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/322521

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX