- 我经常听说 mongodb 可以在一个集合级别执行原子性。 您知道为什么以及如何将其与分片联系起来吗?
- replication 和 replicasets 之间的唯一区别是两者都是主/从(主要/次要),但 replicasets 具有 如果 master 挂了就选举,对吗?
- 在 ACID 中,mongodb2 支持/不支持哪些?
- 能否通过 safe=true 保证 mongodb 的持久性?
谢谢!
最佳答案
MongoDB 目前可以在“更新单个文档”级别提供原子性,仅此而已。这与分片完全无关。
或多或少。副本集较新,您现在基本上应该一直使用它们。如今,主/从复制只是为了向后兼容。 future 很可能只有副本集会获得新功能。
为单个文档的更新提供了原子性(参见 #1)。根本没有真正提供一致性和隔离性——您的应用程序必须这样做。可以通过要求在驱动程序报告成功之前将写入操作持久保存到多个节点来提供持久性(以某种方式)(参见 #4)。
可以通过调整 Write Concern 来提供持久性,方法是使用 W > 1 的值,和/或(尽管这很慢)使用 fsync。查看WriteConcern documentation或 connection string文档。
关于sql - MongoDB : few questions,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9159356/