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仍然可用。


更多文章
  • Golang里数据库migration方案
  • Android SwipeRefreshLayout左右滑动冲突的解决
  • Android调用gRPC的两个小工具函数
  • Android上结合kotlin使用coroutine
  • gRPC错误处理
  • Java collection的结构
  • 为啥Redis使用pipelining会更快?
  • 通过阳台种菜实现蔬菜自由
  • 从GORM里学习到的panic处理方式
  • Go使用闭包简化数据库操作代码
  • TCMalloc设计文档学习
  • Flask和requests做一个简单的请求代理
  • Linux常用命令(四):xargs
  • Linux常用命令(二):htop
  • Linux常用命令(三):watch