BlotDB 学习总结(三)

通过前两章已经完成

1.学习 DB 文件是如何通过字节组织成具体的文件、如何进行读写?

2.BoltDB 如何实现事务?

3.BlotDB 如何实现 MVCC?

最后一章就了解一下 mmap。

BlotDB 通过 mmap 来提高读的效率。具体代码在 db.go 中 mmap。具体 mmap 的实现,需要根据允许环境决定,这里我以 window 做为学习,具体代码在 blot_windows 中的 mmap 中。

mmap

mmap 是一种将文件/设备映射到内存的方法,实现文件的磁盘地址和进程虚拟地址空间中的一段虚拟地址的一一映射关系,也就是说,可以在某个进程中通过操作这一段映射的内存,实现对文件的读写等操作。修改了这一段内存的内容,文件对应位置的内容也会同步修改,而读取这一段内存的内容,相当于读取文件对应位置的内容。

mmap 另一个非常重要的特性是减少内存的拷贝次数。在 linux 系统中,文件的读写操作通常通过 read 和 write 这两个系统调用来实现,这个过程会产生频繁的内存拷贝。比如 read 函数就涉及了 2 次内存拷贝:

(1)操作系统读取磁盘文件到页缓存。

(2)从页缓存将数据拷贝到 read 传递的 buf 中(例如进

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值