首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ElasticSearch鸟巢交叉簇搜索C#

ElasticSearch鸟巢交叉簇搜索C#
EN

Stack Overflow用户
提问于 2021-05-12 09:07:49
回答 1查看 120关注 0票数 0

我需要使用Nest执行跨集群搜索,但我无法找到一种方法。

Uri elasticNode =新Uri(elasticSearchUri);ConnectionSettings nodeSettings = new nodeSettings ElasticClient elasticClient = new ElasticClient(nodeSettings);

也找不到关于它的文档。

任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-12 11:00:27

对于跨簇搜索,首先需要配置至少一个远程集群。

代码语言:javascript
复制
var pool = new SingleNodeConnectionPool(new Uri("http://example.com:9200"));
var settings = new ConnectionSettings(pool);
var client = new ElasticClient(settings);

var putSettingsResponse = client.Cluster.PutSettings(s => s
    .Persistent(d => d
        .Add("cluster.remote.cluster_two.seeds", new[] { "127.0.0.1:9300" })
        .Add("cluster.remote.cluster_two.skip_unavailable", true)
    )
);

这将在cluster_two (使用传输层端口)处配置一个名为127.0.0.1:9300的集群。

现在,在配置有客户端和远程集群的集群中进行搜索。

代码语言:javascript
复制
var searchResponse = client.Search<MyDocument>(s => s
    .Index("index_name,cluster_two:index_name")
    .Query(q => q
        .MatchAll()
    )
);

,它在集群中的"index_name"索引中搜索http://example.com:9200,在远程集群中在127.0.0.1中搜索名为"index_name"的索引。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67500542

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档