.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. Dapr-服务调用

    前言 上一篇对Dapr进行了了解,并搭建了Dapr环境.接下来就对Dapr的各个构建块类型的了解.应用实际案例. 一.服务调用: 在许多具有多个需要相互通信的服务的环境中,都会面临着很多问题. 如: ...

  2. 【Java虚拟机9】类加载器之命名空间详解

    前言 前面介绍类加载器的时候,介绍了一下命名空间这个概念.今天就通过一个例子,来详细了解一下[类加载器的命名空间].然后通过这个例子,我们可以总结一下双亲委托模型的好处与优点. 例1(不删除class ...

  3. 【UE4 C++ 基础知识】<14> 多线程——AsyncTask

    概念 AsyncTask AsyncTask 系统是一套基于线程池的异步任务处理系统.每创建一个AsyncTas,都会被加入到线程池中进行执行 AsyncTask 泛指 FAsyncTask 和 FA ...

  4. [对对子队]团队任务拆解Alpha

    Alpha阶段主要目标 完成游戏场景的基本实现(不要求美术资源) 完成游戏UI的基本实现(不要求美术资源) 制作第一部分的关卡(顺序语句,制作3-5关) 完成第一部分关卡和游戏基本逻辑的测试 任务分解 ...

  5. 2021.9.13考试总结[NOIP模拟52]

    T1 路径 考虑每一位的贡献,第$i$位每$2^i$个数会变一次,那么答案为$\sum_{i=1}^{log_2n} \frac{n}{2^i}$. $code:$ 1 #include<bit ...

  6. 算法:杨辉三角(Pascal's Triangle)

    一.杨辉三角介绍 杨辉三角形,又称帕斯卡三角形.贾宪三角形.海亚姆三角形.巴斯卡三角形,是二项式系数的一种写法,形似三角形,在中国首现于南宋杨辉的<详解九章算法>得名,书中杨辉说明是引自贾 ...

  7. 像素反转 牛客网 程序员面试金典 C++ Python

    像素反转 牛客网 程序员面试金典 题目描述 有一副由NxN矩阵表示的图像,这里每个像素用一个int表示,请编写一个算法,在不占用额外内存空间的情况下(即不使用缓存矩阵),将图像顺时针旋转90度. 给定 ...

  8. Python Numpy matplotlib Histograms 直方图

    import numpy as np import matplotlib.pyplot as plt mu,sigma = 2,0.5 v = np.random.normal(mu,sigma,10 ...

  9. 批量免密ssh

    参考连接:https://www.cnblogs.com/xiaoyuxixi/p/11413355.html 适用于所有密码都一样的情况下 应用场景: 在应用ansible的实际情况中,有一个很现实 ...

  10. Redis网络库源码分析(3)之ae.c

    一.aeCreateEventLoop & aeCreateFileEvent 上一篇文章中,我们已经将服务器启动,只是其中有些细节我们跳过了,比如aeCreateEventLoop函数到底做 ...