MongoDB 的一些坑

  • 由于是文档型数据库,不像关系型数据库一样有规范的field。举个贴近生活的例子, 关系型数据库就像是一张Excel表格,所有的列都是统一的;而MongoDB就像是把json 存在一个txt文件里。用成怎样全靠自觉啊!!!

  • 存储空间吃了就不吐出来。MongoDB在使用的时候发现,空间在吃了以后,除非执行 repairDataBase 而且MongoDB会为每一个item都存一个 _id,这个_id包含了时间戳等信息。也是要 占用一定空间的。另外MongoDB的journal没有4G空间还起不来。。。

  • 最低只有collection级别的锁。https://docs.mongodb.com/manual/faq/concurrency/ 这个由于目前做的东西没有高并发的时候,所以暂时还无法说这个级别的锁很怎么样。

  • 建索引时会阻塞数据库 https://docs.mongodb.com/manual/core/index-creation/#index-build 所以建索引的时候一定要先看看是否已经有过。当然我们可以增加 background 选项, 这样建立索引的时候MongoDB仍然可用。


更多文章
  • How to implement fork syscall in Golang?
  • 关于运营的思考-运营要怎么做?
  • Python中实现单例模式的n种方式和原理
  • Golang defer中修改返回值
  • Python dataclass 源码阅读与分析
  • gRPC-gateway 源码阅读与分析
  • 如何阅读源代码
  • 我心目中的配置中心应该怎么做?
  • 设计一个HTTP网关
  • 设计一个分布式块存储
  • Linux低电量自动关机
  • CGO简明教程
  • 求值策略:Applicative Order vs Normal Order
  • High Performance MySQL阅读笔记
  • MySQL EXPLAIN中的filesort是什么?