大家好,欢迎来到IT知识分享网。
出品|开源中国
经过几个月的开发,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/
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/123527.html