.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); });