.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("http://127.0.0.1:9200"));
var connectionSetting = new ConnectionSettings(connectionPool).DisableDirectStreaming();
return new ElasticClient(connectionSetting);
});

三、增删改查

3.1 添加

3.1.1 单个添加

var user = new User()
{
Id = 1,
Age = 18,
Name = "MicroHeart",
Gender = true
};
//第一种
var resp = client.Index(user, s => s.Index(indexName));//指定操作索引名称
//第二种
connectionSettings.DefaultIndex(indexName);//指定默认索引名称
var client = new ElasticClient(connectionSettings);
resp = client.IndexDocument(user);//操作默认索引

3.1.2 批量添加

//第一种
var resp = client.IndexMany(new List<User>() { user }); //操作默认索引
resp = client.IndexMany(new List<User>() { user }, indexName); //操作指定索引
//第二种
resp = client.Bulk(b => b.Index(indexName).IndexMany(users, (desc, user) => desc.Index(user.Gender ? "boy" : "girl")));
//第三种
var bulkAllObservable = client.BulkAll(users, b => b
.Index("people")
.BackOffTime("30s") //重试间隔时间
.BackOffRetries(2) //重试次数
.RefreshOnCompleted()
.MaxDegreeOfParallelism(Environment.ProcessorCount)
.Size(1000) //每次请求文档个数
);

IndexMany:是在单个 HTTP 请求所有文档,因此对于非常大的文档集合,这不是建议的方法。

Bulk:是在单个 HTTP 请求所有文档,如果需要对很多文档进行索引控制,可以使用此方法。例子中将男孩插入“boy”索引中,女孩添加到“girl”索引中

BulkAll:适合对多个大文档集合操作,在多个HTTP请求中,分批次操作文档,内置了重试机制。

上面所有的插入方法都是根据_id的值判断文档是否存在(这里因为user有个属性为Id,默认Es将Id的属性值作为_id的值),如果已经存在文档,就更新,否则就添加。

通过返回对象的IsValid属性来判断是否添加成功。

3.2 删除

var resp = client.Delete<User>(1, d => d.Index(indexName));//单个删除
var resp = client.DeleteByQuery<User>(x => x.Index(indexName).Query(q => q.Range(r => r.Field(f => f.Age).LessThan(18)))); //删除年龄小于18的

返回的对象包含

deleted:表示删除的数量。

Failures:删除失败的集合。

3.3 查询

3.3.1 根据Id获取单个

var resp = client.Get<User>(3, d => d.Index(indexName));

返回的类型为 GetResponse<User>,包含下面几个属性。

index:表示索引,

type:值固定为“_doc”,

found:表示是否找到文档,

version:文档的版本号,

source:存储的数据user

3.3.2 根据Id集合获取多个

 var resp = client.GetMany<User>(new List<long>() { 19L, 20L, 21L }, indexName);

3.3.3 根据条件查询

var resp = client.Search<User>(x => x.Index(indexName)
.From(0)
.Size(20)
.Query(q => q.Range(r => r.Field(f => f.Age).GreaterThan(18)) &&
q.Range(r => r.Field(f => f.Age).LessThan(30)) &&
q.Term(t => t.Gender, true)));

返回的类型为 ISearchResponse<User>,包含下面几个属性。

TimedOut:查询是否超时

Shards:完成这个搜索查询了多少个分片

Took:此次查询消耗的时间

MaxScore:此次查询中最符合查询条件的文档的最大得分

Total:符合查询条件的总数

Hits:存储的数据user集合

例子只是简单的查询。ES专为查询而生,所以它的查询很灵活,后面单独讲。

3.4 更新

var user = new User()
{
Age = 18,
Gender = false,
Name = "test"
};
var resp4 = client.Update<User>(20, u => u.Index(indexName).Doc(user));

返回的IsValid 表示是否更新成功。

封装装一个操作仓储,链接

  

.Net Core中使用ElasticSearch(二)的更多相关文章

  1. .Net Core中使用ElasticSearch(一)

    一.安装配置 在官网下载Es,注意版本号,不同大版本号之间差异很大.我安装的是7.14.0版本 1.1 安装成服务 cmd 进入bin目录下执行 elasticsearch-service.bat i ...

  2. (12)ASP.NET Core 中的配置二(Configuration)

    1.内存配置 MemoryConfigurationProvider使用内存中集合作为配置键值对.若要激活内存中集合配置,请在ConfigurationBuilder的实例上调用AddInMemory ...

  3. IdentityServer4在Asp.Net Core中的应用(二)

    继续上次授权的内容,客户端模式后我们再说以下密码模式,先回顾下密码模式的流程: 我们还是使用上次的代码,在那基础上修改,在IdentityServer4里面有一个IdentityServer4.Tes ...

  4. (13)ASP.NET Core 中的选项模式(Options)

    1.前言 选项(Options)模式是对配置(Configuration)的功能的延伸.在12章(ASP.NET Core中的配置二)Configuration中有介绍过该功能(绑定到实体类.绑定至对 ...

  5. ASP.NET Core中使用IOC三部曲(二.采用Autofac来替换IOC容器,并实现属性注入)

    前言 本文主要是详解一下在ASP.NET Core中,自带的IOC容器相关的使用方式和注入类型的生命周期. 这里就不详细的赘述IOC是什么 以及DI是什么了.. emm..不懂的可以自行百度. 目录 ...

  6. ExpandoObject与DynamicObject的使用 RabbitMQ与.net core(一)安装 RabbitMQ与.net core(二)Producer与Exchange ASP.NET Core 2.1 : 十五.图解路由(2.1 or earler) .NET Core中的一个接口多种实现的依赖注入与动态选择看这篇就够了

    ExpandoObject与DynamicObject的使用   using ImpromptuInterface; using System; using System.Dynamic; names ...

  7. 深入理解net core中的依赖注入、Singleton、Scoped、Transient(二)

    相关文章: 深入理解net core中的依赖注入.Singleton.Scoped.Transient(一) 深入理解net core中的依赖注入.Singleton.Scoped.Transient ...

  8. ELK系列(二):.net core中使用ELK

    ELK安装好后,我们现在.net Core中使用一下,大体思路就是结合NLog日志组件将数据写入ELK中,其它语言同理. ELK的安装还是有些复杂的,我们也可以在Docker中安装ELK:docker ...

  9. 探索ASP.Net Core 3.0系列二:聊聊ASP.Net Core 3.0 中的Startup.cs

    原文:探索ASP.Net Core 3.0系列二:聊聊ASP.Net Core 3.0 中的Startup.cs 前言:.NET Core 3.0 SDK包含比以前版本更多的现成模板. 在本文中,我将 ...

随机推荐

  1. kafka初认识(一)

    首先贴出官网地址:https://kafka.apache.org/ 一. 简介 Kafka 是 linkedin 使用 Scala 编写具有高水平扩展和高吞吐量的分布式消息系统.Kafka 对消息保 ...

  2. C++ 与 Visual Studio 2019 和 WSL

    Visual Studio 使用 C++ 的 Linux 开发(WSL) https://devblogs.microsoft.com/cppblog/c-with-visual-studio-201 ...

  3. 联想SR658安装显卡驱动【NVIDIA Tesla V100】

    1. 安装基础依赖环境 yum -y install gcc kernel-devel kernel-headers 2.查看内核和源码版本是否一致 查看内核版本: ls /boot | grep v ...

  4. 6月4日 Scrum Meeting

    日期:2021年6月4日 会议主要内容概述:讨论账单功能模块,讨论账单前后端接口. 一.进度情况 组员 负责 两日内已完成的工作 后两日计划完成的工作 工作中遇到的困难 徐宇龙 后端 账单数据界面 设 ...

  5. 并发编程从零开始(八)-ConcurrentHashMap

    并发编程从零开始(八)-ConcurrentHashMap 5.5 ConcurrentHashMap HashMap通常的实现方式是"数组+链表",这种方式被称为"拉链 ...

  6. Seata的一些概念

    Seata的一些概念 一.什么是seata 二.AT模式的介绍 1.前提条件 2.整体机制 3.读写隔离的实现 1.写隔离 2.读隔离 三.事务分组 1.事务分组是什么? 2.通过事务分组如何找到后端 ...

  7. Linux基础是零基础必须要过的关,你懂了多少

    #LINUX基础学习 ##命令行下的基础知识 Linux区分英文的大小写. date :查看时间 cal:查看日历 [Tab] 热键 :可以自动补全命令名和文件名 [Ctrl]+C 热键 :可以中断正 ...

  8. 『学了就忘』Linux基础 — 6、VMware虚拟机安装Linux系统(超详细)

    目录 1.打开VMware虚拟机软件 2.选择Linux系统的ISO安装镜像 3.开启虚拟机安装系统 (1)进入Linux系统安装界面 (2)硬件检测 (3)检测光盘 (4)欢迎界面 (5)选择语言 ...

  9. 【转】PLI是什么以及怎么用

    programmable language interface 这里就说给verilog用的一些系统函数,还是无双大大的帖子 首先介绍了怎么让你自己写的pli系统函数在ncverilog里面可以成功调 ...

  10. 精心整理Java微服务最全面试题集(含答案)

    微服务架构相关 大型网站架构演变过程 网站架构演变演变过程 传统架构 → 分布式架构 → SOA架构 → 微服务架构 什么是分布式架构 分布式架构就是将传统结构按照模块进行拆分,不同的人负责不同的模块 ...