.Net Core中使用ElasticSearch(二)

  .Net的ElasticSearch 有两个版本,Elasticsearch.Net(低级) 和 NEST(高级),推荐使用 NEST,低级版本的更灵活,水太深 把握不住。有个需要注意,使用的版本号必须要ElasticSearch服务端版本号一致。

一、 连接池   1.1 SingleNodeConnectionPool 单节点连接池

    适合只有一个节点的情况。当没有在ConnectionSettings 构造函数中显式指定连接池类型的时候,默认此连接池。这种连接池不会标记节点是否存活

  1.2 StaticConnectionPool 静态连接池

    适合多个节点,它维护一个静态的节点hosts清单,使用前通过ping节点来确认节点是否存活。如果一个节点处理请求失败,该节点会被标记为死节点,这个节点会被“关禁闭”,“关禁闭”出来后,会再次处理请求,如果还是失败,“关禁闭”的时间会更长。

  1.3 SniffingConnectionPool 嗅探连接池

    它继承至静态连接池,有静态连接池的Ping特性。区别在于是动态的,用户提供hosts种子,而客户端则会嗅探这些hosts并发现集群的其他节点。当集群中添加或删除节点时,客户端会相应更新。

  1.4 StickyConnectionPool 黏性连接池

    选择一个可用节点作为请求主节点,支持ping 不支持嗅探

  1.5 StickySniffingConnectionPool 黏性嗅探连接池

    选择一个可用节点作为请求主节点,支持ping 支持嗅探

二、注入

   官方推荐使用单例注入ElasticClient。

services.AddSingleton<IElasticClient>(provider => { var connectionPool = new SingleNodeConnectionPool(new Uri(":9200")); var connectionSetting = new ConnectionSettings(connectionPool).DisableDirectStreaming(); return new ElasticClient(connectionSetting); });

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zggzfd.html