Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板
原文:Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。
本章,我们将简单介绍索引模板和动态模板的内容。其实,在前面章节,我们已经粗略地用到了动态模板,但是没有明确提出这样的概念。
索引模板Index Template
索引模板,英文名为Index Template。它是一种机制,这种机制允许我们定义一种模板,这种模板当新索引创建时将被自动应用。模板包含settings和mapping,以及这个模板是否可被应用于新的索引。
索引模板有以下限制:
- 索引模板仅在一个索引新创建时才起作用,修改模板不会影响已创建的索引。
- 可以设定多个索引模板,这些索引模板的设置将被
merge在一起。 - 可以通过对索引模板指定
order的数值,来控制merge的过程。
模板定义可以如下:
-
{
-
"order": 0, // 模板优先级
-
"template": "sample_info*", // 模板匹配的名称方式
-
"settings": {...}, // 索引设置
-
"mappings": {...}, // 索引中各字段的映射定义
-
"aliases": {...} // 索引的别名
-
}
接下来,我们创建两个模板。
接下来,我们创建两个模板。
-
# 创建一个默认模板,模板名为 template_default
-
# 这个模板匹配所有的索引,它的order属性值为0。索引创建时将被设置一个分片,一个副本。
-
PUT _template/template_default
-
{
-
"index_patterns": ["*"],
-
"order" : 0,
-
"version": 1,
-
"settings": {
-
"number_of_shards": 1,
-
"number_of_replicas":1
-
}
-
}
-
-
# 创建一个模板,模板名为 template_test
-
# 这个模板匹配test开头的索引,它的order属性值为1。索引创建时将被设置一个分片,两个副本。
-
# 并且,date类型自动检测功能将关闭,数字自动检测功能将开启。
-
PUT /_template/template_test
-
{
-
"index_patterns" : ["test*"],
-
"order" : 1,
-
"settings" : {
-
"number_of_shards": 1,
-
"number_of_replicas" : 2
-
},
-
"mappings" : {
-
"date_detection": false,
-
"numeric_detection": true
-
}
-
}
-
-
# 删除模板名为template_1的模板
-
DELETE /_template/template_1
-
-
# 获取模板名为template_1的模板
-
GET /_template/template_1
-
-
# 获取通配符模板
-
GET /_template/temp*
-
-
# 获取多个模板
-
GET /_template/template_1,template_2
-
-
# 获取所有模板
-
GET /_template
-
-
# 判断模板是否存在
-
HEAD _template/template_1
1、模板优先级
有时候,一个模板可能绝大部分符合新建索引的需求,但是局部需要微调,此时,如果复制旧的模板,修改该模板后,成为一个新的索引模板即可达到我们的需求,但是这操作略显重复。此时,可以采用模板叠加与覆盖来操作。模板的优先级是通过模板中的 order 字段定义的,数字越大,优先级越高。
- 应用Elasticsearch默认的
settings和mappings。 - 应用 order 数值低的索引模板中的设置。
- 应用 order 数值高的索引模板中的设置
- 应用索引创建时,用户指定的
settings和mappings
2、索引模板的匹配
索引模板中的 index_patterns字段定义的是该索引模板所应用的索引情况。如 "index_patterns" : ["test*"] 所表示的含义是,当新建索引时,所有以 tete 开头的索引都会自动匹配到该索引模板。利用该模板进行相应的设置和字段添加等。
3、setting 部分
索引模板中的 setting 部分一般定义的是索引的主分片、拷贝分片、刷新时间、自定义分析器等。常见的 setting 部分结构如下:
-
-
"settings": {
-
"index": {
-
"analysis": {...}, // 自定义的分析器
-
"number_of_shards": "32", // 主分片的个数
-
"number_of_replicas": "1", // 主分片的拷贝分片个数
-
"refresh_interval": "5s" // 刷新时间
-
}
-
}
-
建立的索引,不会立马查到,这是为什么 Elasticsearch 为 near-real-time(接近实时)的原因,需要配置刷新时间,默认的是 1s。setting 的设置中,重点是自定义分析器的设置。
分析器是三个顺序执行的组件的结合。他们分别是字符过滤器、分词器、标记过滤器。
动态模板
动态模板,英文名为Dynamic Templates,是根据Elasticsearch可识别的数据类型,结合字段名称,来动态设定字段类型的一种机制。
而Elasticsearch自带了动态字段映射,它的规则如下所示。
动态字段映射
通过动态模板这种机制,我们可以达到类似下面的效果:
- 所有的字符串类型都设定成
keyword,或者关闭keyword字段。 is开头的字段都设置成boolean类型。long_开头的字段都设置成long类型。
它的语法如下所示:
动态模板的语法
这种语法包含以下内容:
- 动态模板是定义在某个具体索引的mappings中
- 动态模板需要指定一个名称,例如上图的
my_template_name - 匹配规则是一个数组
- 为匹配到的字段设置
mapping
1. 例子1
-
DELETE my_index
-
# 简单的例子
-
PUT my_index
-
{
-
"mappings": {
-
"dynamic_templates": [
-
{
-
"strings_as_boolean": {
-
"match_mapping_type": "string",
-
"match":"is*",
-
"mapping": {
-
"type": "boolean"
-
}
-
}
-
},
-
{
-
"strings_as_keywords": {
-
"match_mapping_type": "string",
-
"mapping": {
-
"type": "keyword"
-
}
-
}
-
}
-
]
-
}
-
}
-
PUT my_index/_doc/1
-
{
-
"firstName":"Ruan",
-
"isVIP":"true"
-
}
-
GET my_index/_mapping
在这个例子中,我们设置了两个动态模板。
- 根据
strings_as_boolean的动态模板定义,如果字段类型为字符串类型,且字段名以is开头,其字段类型将映射成boolean类型。 - 根据
strings_as_keywords的动态模板定义,如果字段类型为字符串类型,其字段类型将映射成keyword类型。
2. 例子2
-
DELETE my_index
-
# 路径的例子
-
PUT my_index
-
{
-
"mappings": {
-
"dynamic_templates": [
-
{
-
"full_name": {
-
"path_match": "name.*",
-
"path_unmatch": "*.middle",
-
"mapping": {
-
"type": "text",
-
"copy_to": "full_name"
-
}
-
}
-
}
-
]
-
}
-
}
-
-
-
PUT my_index/_doc/1
-
{
-
"name": {
-
"first": "John",
-
"middle": "Winston",
-
"last": "Lennon"
-
}
-
}
-
-
GET my_index/_search?q=full_name:John
在这个例子中,我们定义了一个动态模板,名字叫full_name。它会匹配路径,路径以name开头,且不以middle结尾的字段,将被映射成一个text,且拷贝到full_name这个字段中。
总结
我们了解了索引模板和动态模板各自的作用,也举了一些实际的例子来加深我们的印象。但是,更全面的内容还需要看Elasticsearch的官网。
Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板的更多相关文章
- Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer
原文:Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处 ...
- Elasticsearch7.X 入门学习第五课笔记---- - Mapping设定介绍
原文:Elasticsearch7.X 入门学习第五课笔记---- - Mapping设定介绍 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本 ...
- Elasticsearch7.X 入门学习第四课笔记---- Search API之(Request Body Search 和DSL简介)
原文:Elasticsearch7.X 入门学习第四课笔记---- Search API之(Request Body Search 和DSL简介) 版权声明:本文为博主原创文章,遵循CC 4.0 BY ...
- Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search)
原文:Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...
- Elasticsearch7.X 入门学习第九课笔记-----聚合分析Aggregation
原文:Elasticsearch7.X 入门学习第九课笔记-----聚合分析Aggregation 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. ...
- Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD
原文:Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链 ...
- Elasticsearch7.X 入门学习第一课笔记----基本概念
原文:Elasticsearch7.X 入门学习第一课笔记----基本概念 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https: ...
- Redis学习第八课:Redis高级实用特性(一)
Redis高级实用特性 注:我学习的环境是vmware7.1 + ubantu10.10+ redis 3.0.2 1.安全性 设置客户端连接后进行任何其他指定前需要的密码.因为redis速度相当快, ...
- salesforce 零基础开发入门学习(八)数据分页简单制作
本篇介绍通过使用VF自带标签和Apex实现简单的数据翻页功能. 代码上来之前首先简单介绍一下本篇用到的主要知识: 1.ApexPages命名空间 此命名空间下的类用于VF的控制. 主要的类包括但不限于 ...
随机推荐
- mongodb replica set搭建
1/安装mongodb 配置repo: [mongodb-org-3.4]name=MongoDB Repositorybaseurl=https://repo.mongodb.org/yum/red ...
- php大文件上传解决方案
PHP用超级全局变量数组$_FILES来记录文件上传相关信息的. 1.file_uploads=on/off 是否允许通过http方式上传文件 2.max_execution_time=30 允许脚本 ...
- XXX is not a function
今天,一个以前的小伙伴跟我说他遇到了一个问题,调试了将近两天(这家伙一开始不打算干程序员,跑去干了两个月销售,现在又想回来写代码了,所以就自己折腾一个demo,免得面试的时候被问住) 我把他的代码从头 ...
- es之IK分词器
1:默认的分析器-- standard 使用默认的分词器 curl -XGET 'http://hadoop01:9200/_analyze?pretty&analyzer=standard' ...
- [CSP-S模拟测试]:随(快速幂+数学)
题目描述 给出$n$个正整数$a_1,a_2...a_n$和一个质数mod.一个变量$x$初始为$1$.进行$m$次操作.每次在$n$个数中随机选一个$a_i$,然后$x=x\times a_i$.问 ...
- 含有对象的List集合实现字母数字混合排序
List<PageData> varList = [{BOMCode=10A, mantotal=4}, {BOMCode=10B, mantotal=1}, {BOMCode=11A, ...
- Ecipse代码调试
1.设置断点 2.启动调试 在代码空白处中右击,选择Debug as —>1 Java Application 快捷键 表示当前实现继续运行直到下一个断点,快捷键为F8. 表示打断整个进程 表示 ...
- 电脑配置Java环境变量之后,在cmd中仍然无法识别
在电脑上配置了Java的环境变量,但是在cmd框中仍然无法识别: 解决方法:cmd.exe右键---以管理员身份运行,即可识别
- electron原来这么简单----打包你的react、VUE桌面应用程序
也许你不甘心只写网页,被人叫做"他会写网页",也许你有项目需求,必须写桌面应用,然而你只会前端,没关系.网上的教程很多,但是很少有能说的浅显易懂的,我尽力将electron打包应用 ...
- 《SQL Server 2012 T-SQL基础》读书笔记 - 9.事务和并发
Chapter 9 Transactions and Concurrency SQL Server默认会把每个单独的语句作为一个事务,也就是会自动在每个语句最后提交事务(可以设置IMPLICIT_TR ...