elasticsearch的一个最为显著的优点:快速全文检索。关于elasticsearch 全文检索的原理,请看:https://blog.csdn.net/wolfcode_cn/article/details/81907195

一、es 安装

参考官网安装教程:https://www.elastic.co/guide/en/elasticsearch/reference/6.6/zip-targz.html

教程中介绍了多种操作系统多种安装方式:

本篇选择的是linux操作系统下,手动下载安装包的方式安装:

wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.6.2.tar.gz
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.6.2.tar.gz.sha512
shasum -a -c elasticsearch-6.6..tar.gz.sha512
tar -xzf elasticsearch-6.6..tar.gz
cd elasticsearch-6.6./

安装完毕之后,测试是否成功:

./bin/elasticsearch

此开启方式是前台开启,如果要后台运行

./bin/elasticsearch &

curl -X GET "localhost:9200/"

得到下面的信息:

下面设置在守护进程中运行,开机可以自启动es:

[program:elasticsearch]
command=/home/shippingadmin/elasticsearch-6.6./bin/elasticsearch startsecs=
autostart=true
autorestart=true
stderr_logfile=/var/log/applogs/elasticsearch.err.log
stdout_logfile=/var/log/applogs/elasticsearch.out.log
user=shippingadmin
stopsignal=INT

二、es 数据库操作

引入 nuget 包

Install-Package NEST

连接es代码:

 public static ElasticClient Client;
/// <summary>
/// 初始化es连接
/// </summary>
public static void Init()
{
//单节点
var node = new Uri("http://192.168.1.23:8920");
//指定默认索引是可选的,但如果没有为给定请求推断索引,NEST可能会引发异常,这里的默认索引是skuindex
var settings = new ConnectionSettings(node)
.DefaultMappingFor<Sku>(m => m.IndexName("skuitem")); //使用与群集中的三个Elasticsearch节点的地址对接的SniffingConnectionPool,并且客户端将使用此类型的池来维护可以以循环方式发送请求的群集中的可用节点列表 //var uris = new[]
//{
// new Uri("http://localhost:9200"),
// new Uri("http://localhost:9201"),
// new Uri("http://localhost:9202"),
//}; //var connectionPool = new SniffingConnectionPool(uris);
//var settings = new ConnectionSettings(connectionPool)
// .DefaultMappingFor<Sku>(m => m.IndexName("SKU")); Client = new ElasticClient(settings);

创建索引:

/// <summary>
/// 创建索引,并建立POCO映射关系,这在es第一次插入sku数据时,是必要的,重复插入并不会报错
/// </summary>
/// <returns></returns>
public static bool CreateIndex()
{
var createIndexResponse = Client.CreateIndex("skuitem", c => c
.Mappings(ms => ms
.Map<Sku>(m => m.AutoMap())
)
);
return createIndexResponse.IsValid;
}

定义Entity:

 [ElasticsearchType(IdProperty = "Id")]
public class Sku
{ public System.Guid Id { get; set; } [Keyword]
public string Code { get; set; } [Keyword]
public string SerialNumber { get; set; } public List<ItemTitle> SearchTitles { get; set; }
} public class ItemTitle
{
public Guid Id { get; set; } [Keyword]
public string Title { get; set; } [Keyword]
public string CultureCode { get; set; }
}

插入数据,并做查询:

 static void Main(string[] args)
{ SkuManager.Init(); SkuManager.CreateIndex(); List<Sku> skus = new List<Sku>()
{
new Sku()
{
Id=Guid.NewGuid(),
Code="sku1",
SerialNumber="abc1234",
SearchTitles=new List<ItemTitle>()
{
new ItemTitle()
{
Id=Guid.NewGuid(),
CultureCode="cn",
Title="ddkdkdkdkdkdkdk",
},
new ItemTitle()
{
Id=Guid.NewGuid(),
CultureCode="en",
Title="ddkdkdkdkdkdkdk",
}
}
},
new Sku()
{
Id=Guid.NewGuid(),
Code="sku2",
SerialNumber="abc1dddfd234",
SearchTitles=new List<ItemTitle>()
{
new ItemTitle()
{
Id=Guid.NewGuid(),
CultureCode="cn",
Title="ddkdkdkdkdkdksdfsdk",
},
new ItemTitle()
{
Id=Guid.NewGuid(),
CultureCode="en",
Title="ddkdkdksdfdkdkdkdk",
}
}
}
}; var indexResult = SkuManager.Client.IndexMany<Sku>(skus); var searchResult1 = SkuManager.Client.Search<Sku>(s => s
.From()
.Size()
.Query(q => q
.Match(m => m
.Field(f => f.SerialNumber)
.Query("fd")
)
)
); var query = new List<Func<QueryContainerDescriptor<Sku>, QueryContainer>>();
query.Add(sku => sku.Wildcard(tm => tm.Field(f => f.SerialNumber).Value("*fd*")));
query.Add(sku => sku.Term(tm => tm.Field(f => f.Code).Value("sku2"))); var searchResult2 = SkuManager.Client.Search<Sku>(s => s
.Query(q => q.Bool(b => b.Must(query))
)
).Documents.ToList(); }

总结:1.es是用java代码编写的数据存储以及提供了丰富的数据操作API,所以在windows或者linux安装es之前,是需要先安装java sdk,并设置环境变量;关于环境变量的文章请参考:

https://www.cnblogs.com/jasonzeng/p/8302171.html

https://blog.csdn.net/u012498149/article/details/78771729

2.es相对应的客户端是 kibana,提供了强大的数据查询,图表,统计等功能,后面可能要针对 kibana作一次学习总结;

3.现在es最新版本,7.x已经出来,安装完之后,用elasticsearch.net,是不兼容的,因为elasticsearch.net,只支持到 6.x版本;

4.关于elasticsearch.net,更多的数据库操作,请看官网,其中有low lever client, high lever client, 本篇用的是high level client:  https://www.elastic.co/guide/en/elasticsearch/client/net-api/6.x/nest.html

elasticsearch数据库使用的更多相关文章

  1. [转帖]Elasticsearch数据库

    Elasticsearch数据库 2018-05-06 11:30:48 七色米 阅读数 23634更多 分类专栏: 数据库   版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转 ...

  2. elasticSearch数据库、skywalking集群部署

    Centos6上面安装elasticsearc数据库的集群 安装的是6.3.2版本,安装之前首先要先安装jdk1.8版本 安装之前首先需要关闭防火墙 Centos6 sudo service ipta ...

  3. Elasticsearch数据库 | Elasticsearch-7.5.0应用搭建实战

    Elasticsearch 是一个可用于分布式以及符合RESTful 风格的搜索和数据分析引擎.-- Elastic Stack 官网 搭建Elasticsearch的"那些事儿" ...

  4. Elasticsearch数据库优化实战:让你的ES飞起来

    摘要:ES已经成为了全能型的数据产品,在很多领域越来越受欢迎,本文旨在从数据库领域分析ES的使用. 本文分享自华为云社区<Elasticsearch数据库加速实践>,原文作者:css_bl ...

  5. ElasticSearch数据库同步插件logstash

    1.下载和elasticsearch 相同版本的logstash. 2.进行解压后,进入bin下,新建一个文件mysql.conf,并输入 input { stdin{ }} output { std ...

  6. Elasticsearch数据库 | Elasticsearch-7.5.0应用基础实战

    Elasticsearch 是一个可用于分布式以及符合RESTful 风格的搜索和数据分析引擎.-- Elastic Stack 官网 关于Elasticsearch的"爱恨情仇" ...

  7. elasticsearch数据库(ES)

    1. http://blog.csdn.net/cnweike/article/details/33736429 http://www.oschina.net/translate/elasticsea ...

  8. 【ElasticSearch】给ElasticSearch数据库配置慢查询日志

    给ElasticSearch引擎配置慢查询日志,可以实时监控搜索过慢的日志.虽然ElasticSearch以快速搜索而出名,但随着数据量的进一步增大或是服务器的一些性能问题,会有可能出现慢查询的情况. ...

  9. 什么是Elasticsearch

    一个采用Restfull API 标准的高扩展性和高可用性的实时数据分析的全文搜索工具 Elasticsearch 涉及到的一些概念: 1.Node(节点): 单个的装有Elasticsearch服务 ...

随机推荐

  1. redirect和forward 的区别

    1.从地址栏显示来说 forward 是服务器请求资源,服务器直接访问目标地址url,把那个url的响应内容读取过来,然后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容从哪里来的,所以他的地 ...

  2. UVaLive 6680 Join the Conversation (DP)

    题意:给出n条发言,让你求最大的交流长度并输出标记顺序. 析:这个题要知道的是,前面的人是不能at后面的人,只能由后面的人at前面的,那就简单了,我们只要更新每一层的最大值就好,并不会影响到其他层. ...

  3. bzoj 4808: 马【匈牙利算法】

    网格图黑白染色,然后能互相攻击到的点之间连边,跑匈牙利算法最大匹配,答案是好点个数-最大匹配(最大独立集) 注意pao的时候只从一种颜色的格子统计即可 #include<iostream> ...

  4. 牛客OI周赛2-提高组

    A.游戏 链接:https://www.nowcoder.com/acm/contest/210/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语 ...

  5. 转 linux shell自定义函数(定义、返回值、变量作用域)介绍

    linux shell 可以用户定义函数,然后在shell脚本中可以随便调用.下面说说它的定义方法,以及调用需要注意那些事项. 一.定义shell函数(define function) 语法: [ f ...

  6. cocos creator 场景如何透明,多个canvas层级显示

    转载地址:https://forum.cocos.com/t/creator-canvas/55373/14 Creator 版本:1.7 目标平台:WEB MOBILE 项目需要,页面做了多个Can ...

  7. idea工程jdk设置问题

    经常用idea的朋友,会遇到一个问题,那就是你在单测的时候,会报一个jdk的错,截图如下: 我的解决方案是在pom.xml里配置一个节点: <properties> <maven.c ...

  8. md5加密、Des加密对称可逆加密、RSA非对称可逆加密、https单边验证、银行U盾双边认证

    1.md5不可逆的加密方式,加密成一个32位的字符串.算法是公开的,任何语言的加密结果都是一样的.总有可能是重复的.     用途:             (1)防止明文存储:可以用作密码加密    ...

  9. P3373 【模板】线段树 2 区间求和 区间乘 区间加

    题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格式: 第一行包含三个整数N.M.P,分别 ...

  10. 如何快速排查解决Android中的内存泄露问题

    概述 内存泄露是Android开发中比较常见的问题,一旦发生会导致大量内存空间得不到释放,可用内存急剧减少,导致运行卡顿,部分功能不可用甚至引发应用crash.对于复杂度比较高.多人协同开发的项目来讲 ...