经过几个月的开发,FerretDB 现在已经达到生产可用了,这是一个开源的 MongoDB 替代品,建立在 PostgreSQL 之上,并在 Apache 2.0 许可下发布。
FerretDB 希望将 MongoDB 数据库的工作负载带回其开源的本源,使 PostgreSQL 和其他数据库后端能够运行 MongoDB 工作负载,保留 MongoDB 现有生态所提供的机会。
- 在任何地方部署 + 保持对你的数据的控制
- 在基于云的项目中自由使用它
- 使用现有的 PostgreSQL 基础设施来运行 MongoDB 工作负载
GA 的主要功能补充
在这个 GA 版本中,FerretDB 现在支持createIndexes
命令。这将使你能够指定你想要索引的字段,以及要使用的索引类型(例如,升序、降序等)。
例如,假设你有一个 users
集合,包含几个字段,包括 “age”、”name”和 “email”,你想为 “age” 字段创建一个索引。现在你可以运行下面的命令:
db.users.createIndex({ age: 1 })
这将在 “age” 字段上创建一个升序索引,这将加快对该字段进行过滤的任何查询。
还添加了dropIndexes
命令,它允许你从一个集合中删除索引。下面是一个例子:
db.users.dropIndex({ age: 1 })
这将从 “users” 集合中删除索引。
FerretDB 1.0 扩展了聚集管道的功能,除了在 $group
阶段内的 $sum
累加器外,还包括其他阶段,如 $unwind
、 $limit
和 $skip
。通过这些补充,可以对采集数据进行更精细的计算和操作。除了这些,还在$collStats
聚合管道阶段增加了对count
和storageStats
字段的支持。
为了帮助你收集更多关于集合、数据库和服务器性能的信息,FerretDB 1.0 启用了对几个服务器命令的部分支持,包括collStats
、dbStats
和dataSize
。
要检索一个集合的统计数据,请使用collStats
命令:
db.runCommand({ collStats: "users" })
如果是关于数据库的统计,运行下面的命令:
db.runCommand({ dbStats: 1 })
对于集合的总数据量,运行下面的命令:
db.runCommand({ dataSize: "<database>.<collection>" })
项目状态
FerretDB 现在拥有:
- 超过 40 位代码贡献者,有超过 130 个来自我们社区的 PR
- 在 GitHub 上有超过 5.6k Stars 和 200 次 Forks
- 超过 100 个运行中的实例
- FerretDB 下载超过 10000 次
随着 FerretDB 1.0 的发布,这些数字还会继续增长。
更多详情可查看:https://blog.ferretdb.io/ferretdb-1-0-ga-opensource-mongodb-alternative/