通过前两章已经完成
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 中(例如进