我必须使用500,000个以上的名称来实现自动完成功能,以后可能会增加到400万个以上的名称。
后端是使用Spring的Java REST Web服务调用。我应该使用 MongoDB , Redis 还是 Elasticsearch 来存储和查询/搜索名称?
这是一个关键的搜索用例,MongoDB和Redis非常适合基于键的查找,而不是用于搜索目的,而Elasticsearch是专门针对此类用例构建的分布式搜索引擎。
在选择系统之前,您应该了解功能在内部的工作方式,并且要在选择它的考虑因素以下。
Elasticsearch在反向索引中建立索引的文档,并且可以处理令牌匹配(可以轻松定制以适应业务需求),因此搜索速度非常快。Redis和MongoDB在内部没有这种结构,因此不应在此用例中使用。您不应该对选择Elasticsearch来实现自动完成功能有任何疑问。
由于自动完成是必不可少的搜索功能之一,因此有一个出色的博客,您应该阅读该博客以了解Elasticsearcg提供的不同方法及其折衷方法。