db-tutorial/pages/293175/index.html

252 lines
74 KiB
HTML
Raw Permalink Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<!DOCTYPE html>
<html lang="en-US">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Elasticsearch 索引 | DB-TUTORIAL</title>
<meta name="generator" content="VuePress 1.9.9">
<link rel="icon" href="/db-tutorial/img/favicon.ico">
<script src="https://cdn.wwads.cn/js/makemoney.js" type="text/javascript"></script>
<meta name="description" content="☕ db-tutorial 是一个数据库教程。">
<meta name="keywords" content="vuepress,theme,blog,vdoing">
<meta name="theme-color" content="#11a8cd">
<meta name="wwads-cn-verify" content="mxqWx62nfQQ9ocT4e5DzISHzOWyF4s">
<link rel="preload" href="/db-tutorial/assets/css/0.styles.51390d19.css" as="style"><link rel="preload" href="/db-tutorial/assets/js/app.be3f2e92.js" as="script"><link rel="preload" href="/db-tutorial/assets/js/2.aded268b.js" as="script"><link rel="preload" href="/db-tutorial/assets/js/70.40a2cea2.js" as="script"><link rel="prefetch" href="/db-tutorial/assets/js/10.551ab278.js"><link rel="prefetch" href="/db-tutorial/assets/js/11.c049b6a2.js"><link rel="prefetch" href="/db-tutorial/assets/js/12.92d587d6.js"><link rel="prefetch" href="/db-tutorial/assets/js/13.a7b35fa5.js"><link rel="prefetch" href="/db-tutorial/assets/js/14.9ec959b5.js"><link rel="prefetch" href="/db-tutorial/assets/js/15.e7943372.js"><link rel="prefetch" href="/db-tutorial/assets/js/16.c6ad7b26.js"><link rel="prefetch" href="/db-tutorial/assets/js/17.39500ebd.js"><link rel="prefetch" href="/db-tutorial/assets/js/18.29949979.js"><link rel="prefetch" href="/db-tutorial/assets/js/19.78f879b8.js"><link rel="prefetch" href="/db-tutorial/assets/js/20.3ce14df7.js"><link rel="prefetch" href="/db-tutorial/assets/js/21.9d311c7c.js"><link rel="prefetch" href="/db-tutorial/assets/js/22.90234550.js"><link rel="prefetch" href="/db-tutorial/assets/js/23.12cf9e2d.js"><link rel="prefetch" href="/db-tutorial/assets/js/24.5b436e46.js"><link rel="prefetch" href="/db-tutorial/assets/js/25.8f2dc7d9.js"><link rel="prefetch" href="/db-tutorial/assets/js/26.61665ff4.js"><link rel="prefetch" href="/db-tutorial/assets/js/27.dfc7cc88.js"><link rel="prefetch" href="/db-tutorial/assets/js/28.a6286a66.js"><link rel="prefetch" href="/db-tutorial/assets/js/29.bfa8c106.js"><link rel="prefetch" href="/db-tutorial/assets/js/3.82108019.js"><link rel="prefetch" href="/db-tutorial/assets/js/30.c93b7a2e.js"><link rel="prefetch" href="/db-tutorial/assets/js/31.d48aab81.js"><link rel="prefetch" href="/db-tutorial/assets/js/32.33f8bb7c.js"><link rel="prefetch" href="/db-tutorial/assets/js/33.eb3b622d.js"><link rel="prefetch" href="/db-tutorial/assets/js/34.1ba1a06c.js"><link rel="prefetch" href="/db-tutorial/assets/js/35.24e4fee8.js"><link rel="prefetch" href="/db-tutorial/assets/js/36.dc61504e.js"><link rel="prefetch" href="/db-tutorial/assets/js/37.f1c9c729.js"><link rel="prefetch" href="/db-tutorial/assets/js/38.5024023f.js"><link rel="prefetch" href="/db-tutorial/assets/js/39.30ed016e.js"><link rel="prefetch" href="/db-tutorial/assets/js/4.884deeca.js"><link rel="prefetch" href="/db-tutorial/assets/js/40.6a6327f0.js"><link rel="prefetch" href="/db-tutorial/assets/js/41.3767f4d8.js"><link rel="prefetch" href="/db-tutorial/assets/js/42.14a20b0f.js"><link rel="prefetch" href="/db-tutorial/assets/js/43.b059081c.js"><link rel="prefetch" href="/db-tutorial/assets/js/44.73f724d9.js"><link rel="prefetch" href="/db-tutorial/assets/js/45.68f2ab27.js"><link rel="prefetch" href="/db-tutorial/assets/js/46.aed8a61f.js"><link rel="prefetch" href="/db-tutorial/assets/js/47.3bbf2366.js"><link rel="prefetch" href="/db-tutorial/assets/js/48.81688356.js"><link rel="prefetch" href="/db-tutorial/assets/js/49.1d366c93.js"><link rel="prefetch" href="/db-tutorial/assets/js/5.42f2cdb7.js"><link rel="prefetch" href="/db-tutorial/assets/js/50.ee6f08b7.js"><link rel="prefetch" href="/db-tutorial/assets/js/51.47835d9d.js"><link rel="prefetch" href="/db-tutorial/assets/js/52.b0cab79c.js"><link rel="prefetch" href="/db-tutorial/assets/js/53.106440a2.js"><link rel="prefetch" href="/db-tutorial/assets/js/54.340ab690.js"><link rel="prefetch" href="/db-tutorial/assets/js/55.00623de9.js"><link rel="prefetch" href="/db-tutorial/assets/js/56.9f086601.js"><link rel="prefetch" href="/db-tutorial/assets/js/57.f5ad5f3f.js"><link rel="prefetch" href="/db-tutorial/assets/js/58.14827368.js"><link rel="prefetch" href="/db-tutorial/assets/js/59.c41f57d6.js"><link rel="prefetch" href="/db-tutorial/assets/js/6.5a5b4e54.js"><link rel="prefetch" href="/db-tutorial/assets/js/60.314534c0.js"><link rel="prefetch" href="/db-tutorial/assets/js/61.1ea5e4b7.js"><link rel="prefetch" href="/db-tutorial/assets/js/62.8b52e8fc.js"><link rel="prefetch" href="/db-tutorial/assets/js/63.d2fa8325.js"><link rel="prefetch" href="/db-tutorial/assets/js/64.ea2577e7.js"><link rel="prefetch" href="/db-tutorial/assets/js/65.563da2bb.js"><link rel="prefetch" href="/db-tutorial/assets/js/66.34eb51bd.js"><link rel="prefetch" href="/db-tutorial/assets/js/67.ab57f04f.js"><link rel="prefetch" href="/db-tutorial/assets/js/68.15b6f540.js"><link rel="prefetch" href="/db-tutorial/assets/js/69.54590de4.js"><link rel="prefetch" href="/db-tutorial/assets/js/7.913bec54.js"><link rel="prefetch" href="/db-tutorial/assets/js/71.3ce50922.js"><link rel="prefetch" href="/db-tutorial/assets/js/72.b9c022e9.js"><link rel="prefetch" href="/db-tutorial/assets/js/73.fba94661.js"><link rel="prefetch" href="/db-tutorial/assets/js/74.998d6c2f.js"><link rel="prefetch" href="/db-tutorial/assets/js/75.6efb68b0.js"><link rel="prefetch" href="/db-tutorial/assets/js/76.57273256.js"><link rel="prefetch" href="/db-tutorial/assets/js/77.3ddffb5b.js"><link rel="prefetch" href="/db-tutorial/assets/js/78.8fde3d74.js"><link rel="prefetch" href="/db-tutorial/assets/js/79.7a472c31.js"><link rel="prefetch" href="/db-tutorial/assets/js/8.103b4774.js"><link rel="prefetch" href="/db-tutorial/assets/js/80.4c55c65f.js"><link rel="prefetch" href="/db-tutorial/assets/js/81.cbdb67b8.js"><link rel="prefetch" href="/db-tutorial/assets/js/82.9c14d852.js"><link rel="prefetch" href="/db-tutorial/assets/js/83.a3d7d272.js"><link rel="prefetch" href="/db-tutorial/assets/js/84.6994dacc.js"><link rel="prefetch" href="/db-tutorial/assets/js/85.aca8d788.js"><link rel="prefetch" href="/db-tutorial/assets/js/86.00671865.js"><link rel="prefetch" href="/db-tutorial/assets/js/87.9076c4e8.js"><link rel="prefetch" href="/db-tutorial/assets/js/88.bbe68dab.js"><link rel="prefetch" href="/db-tutorial/assets/js/89.e2173071.js"><link rel="prefetch" href="/db-tutorial/assets/js/9.386bfe3a.js"><link rel="prefetch" href="/db-tutorial/assets/js/90.429162f2.js"><link rel="prefetch" href="/db-tutorial/assets/js/91.6ecc7c85.js"><link rel="prefetch" href="/db-tutorial/assets/js/92.efe42934.js"><link rel="prefetch" href="/db-tutorial/assets/js/93.69562766.js"><link rel="prefetch" href="/db-tutorial/assets/js/94.04aebfbc.js"><link rel="prefetch" href="/db-tutorial/assets/js/95.fe7cfce4.js"><link rel="prefetch" href="/db-tutorial/assets/js/96.674475d6.js"><link rel="prefetch" href="/db-tutorial/assets/js/97.8a7b73f2.js"><link rel="prefetch" href="/db-tutorial/assets/js/98.bf85add1.js">
<link rel="stylesheet" href="/db-tutorial/assets/css/0.styles.51390d19.css">
</head>
<body class="theme-mode-light">
<div id="app" data-server-rendered="true"><div class="theme-container sidebar-open have-rightmenu"><header class="navbar blur"><div title="目录" class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/db-tutorial/" class="home-link router-link-active"><img src="https://raw.githubusercontent.com/dunwu/images/master/common/dunwu-logo.png" alt="DB-TUTORIAL" class="logo"> <span class="site-name can-hide">DB-TUTORIAL</span></a> <div class="links"><div class="search-box"><input aria-label="Search" autocomplete="off" spellcheck="false" value=""> <!----></div> <nav class="nav-links can-hide"><div class="nav-item"><a href="/db-tutorial/12.数据库/01.数据库综合/" class="nav-link">数据库综合</a></div><div class="nav-item"><a href="/db-tutorial/12.数据库/02.数据库中间件/" class="nav-link">数据库中间件</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="关系型数据库" class="dropdown-title"><a href="/db-tutorial/12.数据库/03.关系型数据库/" class="link-title">关系型数据库</a> <span class="title" style="display:none;">关系型数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/03.关系型数据库/01.综合/" class="nav-link">综合</a></li><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/03.关系型数据库/02.Mysql/" class="nav-link">Mysql</a></li><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/03.关系型数据库/99.其他/" class="nav-link">其他</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="文档数据库" class="dropdown-title"><!----> <span class="title" style="display:;">文档数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/04.文档数据库/01.MongoDB/" class="nav-link">MongoDB</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="KV数据库" class="dropdown-title"><!----> <span class="title" style="display:;">KV数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/05.KV数据库/01.Redis/" class="nav-link">Redis</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="搜索引擎数据库" class="dropdown-title"><!----> <span class="title" style="display:;">搜索引擎数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/07.搜索引擎数据库/01.Elasticsearch/" class="nav-link">Elasticsearch</a></li><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/07.搜索引擎数据库/02.Elastic/" class="nav-link">Elastic技术栈</a></li></ul></div></div> <a href="https://github.com/dunwu/db-tutorial" target="_blank" rel="noopener noreferrer" class="repo-link">
GitHub
<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav></div></header> <div class="sidebar-mask"></div> <div class="sidebar-hover-trigger"></div> <aside class="sidebar" style="display:none;"><!----> <nav class="nav-links"><div class="nav-item"><a href="/db-tutorial/12.数据库/01.数据库综合/" class="nav-link">数据库综合</a></div><div class="nav-item"><a href="/db-tutorial/12.数据库/02.数据库中间件/" class="nav-link">数据库中间件</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="关系型数据库" class="dropdown-title"><a href="/db-tutorial/12.数据库/03.关系型数据库/" class="link-title">关系型数据库</a> <span class="title" style="display:none;">关系型数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/03.关系型数据库/01.综合/" class="nav-link">综合</a></li><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/03.关系型数据库/02.Mysql/" class="nav-link">Mysql</a></li><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/03.关系型数据库/99.其他/" class="nav-link">其他</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="文档数据库" class="dropdown-title"><!----> <span class="title" style="display:;">文档数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/04.文档数据库/01.MongoDB/" class="nav-link">MongoDB</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="KV数据库" class="dropdown-title"><!----> <span class="title" style="display:;">KV数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/05.KV数据库/01.Redis/" class="nav-link">Redis</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="搜索引擎数据库" class="dropdown-title"><!----> <span class="title" style="display:;">搜索引擎数据库</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/07.搜索引擎数据库/01.Elasticsearch/" class="nav-link">Elasticsearch</a></li><li class="dropdown-item"><!----> <a href="/db-tutorial/12.数据库/07.搜索引擎数据库/02.Elastic/" class="nav-link">Elastic技术栈</a></li></ul></div></div> <a href="https://github.com/dunwu/db-tutorial" target="_blank" rel="noopener noreferrer" class="repo-link">
GitHub
<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav> <ul class="sidebar-links"><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>数据库综合</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>数据库中间件</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>关系型数据库</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>文档数据库</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>KV数据库</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>列式数据库</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>搜索引擎数据库</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><section class="sidebar-group collapsable is-sub-group depth-1"><p class="sidebar-heading open"><span>Elasticsearch</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/db-tutorial/pages/0cb563/" class="sidebar-link">Elasticsearch 面试总结</a></li><li><a href="/db-tutorial/pages/98c3a5/" class="sidebar-link">Elasticsearch 快速入门</a></li><li><a href="/db-tutorial/pages/0fb506/" class="sidebar-link">Elasticsearch 简介</a></li><li><a href="/db-tutorial/pages/293175/" aria-current="page" class="active sidebar-link">Elasticsearch 索引</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level2"><a href="/db-tutorial/pages/293175/#索引管理操作" class="sidebar-link">索引管理操作</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#索引删除" class="sidebar-link">索引删除</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#索引别名" class="sidebar-link">索引别名</a></li></ul></li><li class="sidebar-sub-header level2"><a href="/db-tutorial/pages/293175/#settings-详解" class="sidebar-link">Settings 详解</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#固定属性" class="sidebar-link">固定属性</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#索引静态配置" class="sidebar-link">索引静态配置</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#索引动态配置" class="sidebar-link">索引动态配置</a></li></ul></li><li class="sidebar-sub-header level2"><a href="/db-tutorial/pages/293175/#mapping-详解" class="sidebar-link">Mapping 详解</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#映射分类" class="sidebar-link">映射分类</a></li><li class="sidebar-sub-header level4"><a href="/db-tutorial/pages/293175/#静态映射" class="sidebar-link">静态映射</a></li><li class="sidebar-sub-header level4"><a href="/db-tutorial/pages/293175/#动态映射" class="sidebar-link">动态映射</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#基础类型" class="sidebar-link">基础类型</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#复杂类型" class="sidebar-link">复杂类型</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#特殊类型" class="sidebar-link">特殊类型</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#mapping-属性" class="sidebar-link">Mapping 属性</a></li></ul></li><li class="sidebar-sub-header level2"><a href="/db-tutorial/pages/293175/#索引查询" class="sidebar-link">索引查询</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#多个-index、多个-type-查询" class="sidebar-link">多个 index、多个 type 查询</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#uri-搜索" class="sidebar-link">URI 搜索</a></li><li class="sidebar-sub-header level3"><a href="/db-tutorial/pages/293175/#查询流程" class="sidebar-link">查询流程</a></li></ul></li><li class="sidebar-sub-header level2"><a href="/db-tutorial/pages/293175/#参考资料" class="sidebar-link">参考资料</a></li></ul></li><li><a href="/db-tutorial/pages/83bd15/" class="sidebar-link">Elasticsearch 查询</a></li><li><a href="/db-tutorial/pages/e1b769/" class="sidebar-link">Elasticsearch 高亮搜索及显示</a></li><li><a href="/db-tutorial/pages/24baff/" class="sidebar-link">Elasticsearch 排序</a></li><li><a href="/db-tutorial/pages/f89f66/" class="sidebar-link">Elasticsearch 聚合</a></li><li><a href="/db-tutorial/pages/a5a001/" class="sidebar-link">Elasticsearch 分析器</a></li><li><a href="/db-tutorial/pages/2d95ce/" class="sidebar-link">Elasticsearch 性能优化</a></li><li><a href="/db-tutorial/pages/4b1907/" class="sidebar-link">Elasticsearch Rest API</a></li><li><a href="/db-tutorial/pages/201e43/" class="sidebar-link">ElasticSearch Java API 之 High Level REST Client</a></li><li><a href="/db-tutorial/pages/9a2546/" class="sidebar-link">Elasticsearch 集群和分片</a></li><li><a href="/db-tutorial/pages/fdaf15/" class="sidebar-link">Elasticsearch 运维</a></li></ul></section></li><li><section class="sidebar-group collapsable is-sub-group depth-1"><p class="sidebar-heading"><span>Elastic</span> <span class="arrow right"></span></p> <!----></section></li></ul></section></li></ul> </aside> <div><main class="page"><div class="theme-vdoing-wrapper "><div class="articleInfo-wrap" data-v-06225672><div class="articleInfo" data-v-06225672><ul class="breadcrumbs" data-v-06225672><li data-v-06225672><a href="/db-tutorial/" title="首页" class="iconfont icon-home router-link-active" data-v-06225672></a></li> <li data-v-06225672><a href="/db-tutorial/categories/?category=%E6%95%B0%E6%8D%AE%E5%BA%93" title="分类" data-v-06225672>数据库</a></li><li data-v-06225672><a href="/db-tutorial/categories/?category=%E6%90%9C%E7%B4%A2%E5%BC%95%E6%93%8E%E6%95%B0%E6%8D%AE%E5%BA%93" title="分类" data-v-06225672>搜索引擎数据库</a></li><li data-v-06225672><a href="/db-tutorial/categories/?category=Elasticsearch" title="分类" data-v-06225672>Elasticsearch</a></li></ul> <div class="info" data-v-06225672><div title="作者" class="author iconfont icon-touxiang" data-v-06225672><a href="https://github.com/dunwu" target="_blank" title="作者" class="beLink" data-v-06225672>dunwu</a></div> <div title="创建时间" class="date iconfont icon-riqi" data-v-06225672><a href="javascript:;" data-v-06225672>2022-02-22</a></div> <!----></div></div></div> <!----> <div class="content-wrapper"><div class="right-menu-wrapper"><div class="right-menu-margin"><div class="right-menu-title">目录</div> <div class="right-menu-content"></div></div></div> <h1><img src="">Elasticsearch 索引<!----></h1> <div class="theme-vdoing-content content__default"><h1 id="elasticsearch-索引"><a href="#elasticsearch-索引" class="header-anchor">#</a> Elasticsearch 索引</h1> <h2 id="索引管理操作"><a href="#索引管理操作" class="header-anchor">#</a> 索引管理操作</h2> <p>Elasticsearch 索引管理主要包括如何进行索引的创建、索引的删除、副本的更新、索引读写权限、索引别名的配置等等内容。</p> <h3 id="索引删除"><a href="#索引删除" class="header-anchor">#</a> 索引删除</h3> <p>ES 索引删除操作向 ES 集群的 http 接口发送指定索引的 delete http 请求即可,可以通过 curl 命令,具体如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code><span class="token function">curl</span> <span class="token parameter variable">-X</span> DELETE http://<span class="token punctuation">{</span>es_host<span class="token punctuation">}</span>:<span class="token punctuation">{</span>es_http_port<span class="token punctuation">}</span>/<span class="token punctuation">{</span>index<span class="token punctuation">}</span>
</code></pre></div><p>如果删除成功,它会返回如下信息,具体示例如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code><span class="token function">curl</span> <span class="token parameter variable">-X</span> DELETE http://10.10.10.66:9200/my_index?pretty
</code></pre></div><p>为了返回的信息便于读取,增加了 pretty 参数:</p> <div class="language-bash extra-class"><pre class="language-bash"><code><span class="token punctuation">{</span>
<span class="token string">&quot;acknowledged&quot;</span> <span class="token builtin class-name">:</span> <span class="token boolean">true</span>
<span class="token punctuation">}</span>
</code></pre></div><h3 id="索引别名"><a href="#索引别名" class="header-anchor">#</a> 索引别名</h3> <p>ES 的索引别名就是给一个索引或者多个索引起的另一个名字,典型的应用场景是针对索引使用的平滑切换。</p> <p>首先,创建索引 my_index然后将别名 my_alias 指向它,示例如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>PUT /my_index
PUT /my_index/_alias/my_alias
</code></pre></div><p>也可以通过如下形式:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>POST /_aliases
<span class="token punctuation">{</span>
<span class="token string">&quot;actions&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">[</span>
<span class="token punctuation">{</span> <span class="token string">&quot;add&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span> <span class="token string">&quot;index&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;my_index&quot;</span>, <span class="token string">&quot;alias&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;my_alias&quot;</span> <span class="token punctuation">}</span><span class="token punctuation">}</span>
<span class="token punctuation">]</span>
<span class="token punctuation">}</span>
</code></pre></div><p>也可以在一次请求中增加别名和移除别名混合使用:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>POST /_aliases
<span class="token punctuation">{</span>
<span class="token string">&quot;actions&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">[</span>
<span class="token punctuation">{</span> <span class="token string">&quot;remove&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span> <span class="token string">&quot;index&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;my_index&quot;</span>, <span class="token string">&quot;alias&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;my_alias&quot;</span> <span class="token punctuation">}</span><span class="token punctuation">}</span>
<span class="token punctuation">{</span> <span class="token string">&quot;add&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span> <span class="token string">&quot;index&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;my_index_v2&quot;</span>, <span class="token string">&quot;alias&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;my_alias&quot;</span> <span class="token punctuation">}</span><span class="token punctuation">}</span>
<span class="token punctuation">]</span>
<span class="token punctuation">}</span>
</code></pre></div><blockquote><p>需要注意的是,如果别名与索引是一对一的,使用别名索引文档或者查询文档是可以的,但是如果别名和索引是一对多的,使用别名会发生错误,因为 ES 不知道把文档写入哪个索引中去或者从哪个索引中读取文档。</p></blockquote> <p>ES 索引别名有个典型的应用场景是平滑切换,更多细节可以查看 <a href="https://www.knowledgedict.com/tutorial/elasticsearch-index-smooth-shift.html" target="_blank" rel="noopener noreferrer">ElasticsearchES索引零停机无需重启无缝平滑切换的方法<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></p> <h2 id="settings-详解"><a href="#settings-详解" class="header-anchor">#</a> Settings 详解</h2> <p>Elasticsearch 索引的配置项主要分为<strong>静态配置属性</strong><strong>动态配置属性</strong>,静态配置属性是索引创建后不能修改,而动态配置属性则可以随时修改。</p> <p>ES 索引设置的 api 为 <strong><em><code>_settings</code></em></strong>,完整的示例如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>PUT /my_index
<span class="token punctuation">{</span>
<span class="token string">&quot;settings&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;index&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;number_of_shards&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;1&quot;</span>,
<span class="token string">&quot;number_of_replicas&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;1&quot;</span>,
<span class="token string">&quot;refresh_interval&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;60s&quot;</span>,
<span class="token string">&quot;analysis&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;filter&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;tsconvert&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;type&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;stconvert&quot;</span>,
<span class="token string">&quot;convert_type&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;t2s&quot;</span>,
<span class="token string">&quot;delimiter&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;,&quot;</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;synonym&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;type&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;synonym&quot;</span>,
<span class="token string">&quot;synonyms_path&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;analysis/synonyms.txt&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;analyzer&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;ik_max_word_synonym&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;filter&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">[</span>
<span class="token string">&quot;synonym&quot;</span>,
<span class="token string">&quot;tsconvert&quot;</span>,
<span class="token string">&quot;standard&quot;</span>,
<span class="token string">&quot;lowercase&quot;</span>,
<span class="token string">&quot;stop&quot;</span>
<span class="token punctuation">]</span>,
<span class="token string">&quot;tokenizer&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;ik_max_word&quot;</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;ik_smart_synonym&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;filter&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">[</span>
<span class="token string">&quot;synonym&quot;</span>,
<span class="token string">&quot;standard&quot;</span>,
<span class="token string">&quot;lowercase&quot;</span>,
<span class="token string">&quot;stop&quot;</span>
<span class="token punctuation">]</span>,
<span class="token string">&quot;tokenizer&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;ik_smart&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;mapping&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;coerce&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;false&quot;</span>,
<span class="token string">&quot;ignore_malformed&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;false&quot;</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;indexing&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;slowlog&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;threshold&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;index&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;warn&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;2s&quot;</span>,
<span class="token string">&quot;info&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;1s&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;provided_name&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;hospital_202101070533&quot;</span>,
<span class="token string">&quot;query&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;default_field&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;timestamp&quot;</span>,
<span class="token string">&quot;parse&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;allow_unmapped_fields&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;false&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;requests&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;cache&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;enable&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;true&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;search&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;slowlog&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;threshold&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;fetch&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;warn&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;1s&quot;</span>,
<span class="token string">&quot;info&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;200ms&quot;</span>
<span class="token punctuation">}</span>,
<span class="token string">&quot;query&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;warn&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;1s&quot;</span>,
<span class="token string">&quot;info&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;500ms&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</code></pre></div><h3 id="固定属性"><a href="#固定属性" class="header-anchor">#</a> 固定属性</h3> <ul><li><strong><em><code>index.creation_date</code></em></strong>:顾名思义索引的创建时间戳。</li> <li><strong><em><code>index.uuid</code></em></strong>:索引的 uuid 信息。</li> <li><strong><em><code>index.version.created</code></em></strong>:索引的版本号。</li></ul> <h3 id="索引静态配置"><a href="#索引静态配置" class="header-anchor">#</a> 索引静态配置</h3> <ul><li><strong><em><code>index.number_of_shards</code></em></strong>:索引的主分片数,默认值是 <strong><em><code>5</code></em></strong>。这个配置在索引创建后不能修改;在 es 层面,可以通过 <strong><em><code>es.index.max_number_of_shards</code></em></strong> 属性设置索引最大的分片数,默认为 <strong><em><code>1024</code></em></strong></li> <li><strong><em><code>index.codec</code></em></strong>:数据存储的压缩算法,默认值为 <strong><em><code>LZ4</code></em></strong>,可选择值还有 <strong><em><code>best_compression</code></em></strong>,它比 LZ4 可以获得更好的压缩比(即占据较小的磁盘空间,但存储性能比 LZ4 低)。</li> <li><strong><em><code>index.routing_partition_size</code></em></strong>:路由分区数,如果设置了该参数,其路由算法为:<code>( hash(_routing) + hash(_id) % index.routing_parttion_size ) % number_of_shards</code>。如果该值不设置,则路由算法为 <code>hash(_routing) % number_of_shardings</code><code>_routing</code> 默认值为 <code>_id</code></li></ul> <p>静态配置里有重要的部分是配置分析器config analyzers</p> <ul><li><p><strong><code>index.analysis</code></strong></p> <p>:分析器最外层的配置项,内部主要分为 char_filter、tokenizer、filter 和 analyzer。</p> <ul><li><strong><em><code>char_filter</code></em></strong>:定义新的字符过滤器件。</li> <li><strong><em><code>tokenizer</code></em></strong>:定义新的分词器。</li> <li><strong><em><code>filter</code></em></strong>:定义新的 token filter如同义词 filter。</li> <li><strong><em><code>analyzer</code></em></strong>:配置新的分析器,一般是 char_filter、tokenizer 和一些 token filter 的组合。</li></ul></li></ul> <h3 id="索引动态配置"><a href="#索引动态配置" class="header-anchor">#</a> 索引动态配置</h3> <ul><li><strong><em><code>index.number_of_replicas</code></em></strong>:索引主分片的副本数,默认值是 <strong><em><code>1</code></em></strong>,该值必须大于等于 0这个配置可以随时修改。</li> <li><strong><em><code>index.refresh_interval</code></em></strong>:执行新索引数据的刷新操作频率,该操作使对索引的最新更改对搜索可见,默认为 <strong><em><code>1s</code></em></strong>。也可以设置为 <strong><em><code>-1</code></em></strong> 以禁用刷新。更详细信息参考 <a href="https://www.knowledgedict.com/tutorial/elasticsearch-refresh_interval-settings.html" target="_blank" rel="noopener noreferrer">Elasticsearch 动态修改 refresh_interval 刷新间隔设置<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></li></ul> <h2 id="mapping-详解"><a href="#mapping-详解" class="header-anchor">#</a> Mapping 详解</h2> <p>在 Elasticsearch 中,<strong><code>Mapping</code></strong>(映射),用来定义一个文档以及其所包含的字段如何被存储和索引,可以在映射中事先定义字段的数据类型、字段的权重、分词器等属性,就如同在关系型数据库中创建数据表时会设置字段的类型。</p> <p>Mapping 会把 json 文档映射成 Lucene 所需要的扁平格式</p> <p>一个 Mapping 属于一个索引的 Type</p> <ul><li>每个文档都属于一个 Type</li> <li>一个 Type 有一个 Mapping 定义</li> <li>7.0 开始,不需要在 Mapping 定义中指定 type 信息</li></ul> <h3 id="映射分类"><a href="#映射分类" class="header-anchor">#</a> 映射分类</h3> <p>在 Elasticsearch 中,映射可分为静态映射和动态映射。在关系型数据库中写入数据之前首先要建表,在建表语句中声明字段的属性,在 Elasticsearch 中则不必如此Elasticsearch 最重要的功能之一就是让你尽可能快地开始探索数据,文档写入 Elasticsearch 中,它会根据字段的类型自动识别,这种机制称为<strong>动态映射</strong>,而<strong>静态映射</strong>则是写入数据之前对字段的属性进行手工设置。</p> <h4 id="静态映射"><a href="#静态映射" class="header-anchor">#</a> 静态映射</h4> <p><strong>静态映射</strong>是在创建索引时手工指定索引映射。静态映射和 SQL 中在建表语句中指定字段属性类似。相比动态映射,通过静态映射可以添加更详细、更精准的配置信息。</p> <p>如何定义一个 Mapping</p> <div class="language-bash extra-class"><pre class="language-bash"><code>PUT /books
<span class="token punctuation">{</span>
<span class="token string">&quot;mappings&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span>
<span class="token string">&quot;type_one&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span> <span class="token punctuation">..</span>. any mappings <span class="token punctuation">..</span>. <span class="token punctuation">}</span>,
<span class="token string">&quot;type_two&quot;</span><span class="token builtin class-name">:</span> <span class="token punctuation">{</span> <span class="token punctuation">..</span>. any mappings <span class="token punctuation">..</span>. <span class="token punctuation">}</span>,
<span class="token punctuation">..</span>.
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</code></pre></div><h4 id="动态映射"><a href="#动态映射" class="header-anchor">#</a> 动态映射</h4> <p><strong>动态映射</strong>是一种偷懒的方式,可直接创建索引并写入文档,文档中字段的类型是 Elasticsearch <strong>自动识别</strong>的,不需要在创建索引的时候设置字段的类型。在实际项目中,如果遇到的业务在导入数据之前不确定有哪些字段,也不清楚字段的类型是什么,使用动态映射非常合适。当 Elasticsearch 在文档中碰到一个以前没见过的字段时,它会利用动态映射来决定该字段的类型,并自动把该字段添加到映射中,根据字段的取值自动推测字段类型的规则见下表:</p> <table><thead><tr><th style="text-align:left;">JSON 格式的数据</th> <th style="text-align:left;">自动推测的字段类型</th></tr></thead> <tbody><tr><td style="text-align:left;">null</td> <td style="text-align:left;">没有字段被添加</td></tr> <tr><td style="text-align:left;">true or false</td> <td style="text-align:left;">boolean 类型</td></tr> <tr><td style="text-align:left;">浮点类型数字</td> <td style="text-align:left;">float 类型</td></tr> <tr><td style="text-align:left;">数字</td> <td style="text-align:left;">long 类型</td></tr> <tr><td style="text-align:left;">JSON 对象</td> <td style="text-align:left;">object 类型</td></tr> <tr><td style="text-align:left;">数组</td> <td style="text-align:left;">由数组中第一个非空值决定</td></tr> <tr><td style="text-align:left;">string</td> <td style="text-align:left;">有可能是 date 类型若开启日期检测、double 或 long 类型、text 类型、keyword 类型</td></tr></tbody></table> <p>下面举一个例子认识动态 mapping在 Elasticsearch 中创建一个新的索引并查看它的 mapping命令如下</p> <div class="language-bash extra-class"><pre class="language-bash"><code>PUT books
GET books/_mapping
</code></pre></div><p>此时 books 索引的 mapping 是空的,返回结果如下:</p> <div class="language-json extra-class"><pre class="language-json"><code><span class="token punctuation">{</span>
<span class="token property">&quot;books&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;mappings&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span><span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</code></pre></div><p>再往 books 索引中写入一条文档,命令如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>PUT books/it/1
<span class="token punctuation">{</span>
<span class="token string">&quot;id&quot;</span><span class="token builtin class-name">:</span> <span class="token number">1</span>,
<span class="token string">&quot;publish_date&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;2019-11-10&quot;</span>,
<span class="token string">&quot;name&quot;</span><span class="token builtin class-name">:</span> <span class="token string">&quot;master Elasticsearch&quot;</span>
<span class="token punctuation">}</span>
</code></pre></div><p>文档写入完成之后,再次查看 mapping返回结果如下</p> <div class="language-json extra-class"><pre class="language-json"><code><span class="token punctuation">{</span>
<span class="token property">&quot;books&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;mappings&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;properties&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;id&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;type&quot;</span><span class="token operator">:</span> <span class="token string">&quot;long&quot;</span>
<span class="token punctuation">}</span><span class="token punctuation">,</span>
<span class="token property">&quot;name&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;type&quot;</span><span class="token operator">:</span> <span class="token string">&quot;text&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;fields&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;keyword&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;type&quot;</span><span class="token operator">:</span> <span class="token string">&quot;keyword&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;ignore_above&quot;</span><span class="token operator">:</span> <span class="token number">256</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span><span class="token punctuation">,</span>
<span class="token property">&quot;publish_date&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;type&quot;</span><span class="token operator">:</span> <span class="token string">&quot;date&quot;</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</code></pre></div><p>使用动态 mapping 要结合实际业务需求来综合考虑,如果将 Elasticsearch 当作主要的数据存储使用,并且希望出现未知字段时抛出异常来提醒你注意这一问题,那么开启动态 mapping 并不适用。在 mapping 中可以通过 <code>dynamic</code> 设置来控制是否自动新增字段,接受以下参数:</p> <ul><li><strong><code>true</code></strong>:默认值为 true自动添加字段。</li> <li><strong><code>false</code></strong>:忽略新的字段。</li> <li><strong><code>strict</code></strong>:严格模式,发现新的字段抛出异常。</li></ul> <h3 id="基础类型"><a href="#基础类型" class="header-anchor">#</a> 基础类型</h3> <table><thead><tr><th style="text-align:left;">类型</th> <th style="text-align:left;">关键字</th></tr></thead> <tbody><tr><td style="text-align:left;">字符串类型</td> <td style="text-align:left;">string、text、keyword</td></tr> <tr><td style="text-align:left;">数字类型</td> <td style="text-align:left;">long、integer、short、byte、double、float、half_float、scaled_float</td></tr> <tr><td style="text-align:left;">日期类型</td> <td style="text-align:left;">date</td></tr> <tr><td style="text-align:left;">布尔类型</td> <td style="text-align:left;">boolean</td></tr> <tr><td style="text-align:left;">二进制类型</td> <td style="text-align:left;">binary</td></tr> <tr><td style="text-align:left;">范围类型</td> <td style="text-align:left;">range</td></tr></tbody></table> <h3 id="复杂类型"><a href="#复杂类型" class="header-anchor">#</a> 复杂类型</h3> <table><thead><tr><th style="text-align:left;">类型</th> <th style="text-align:left;">关键字</th></tr></thead> <tbody><tr><td style="text-align:left;">数组类型</td> <td style="text-align:left;">array</td></tr> <tr><td style="text-align:left;">对象类型</td> <td style="text-align:left;">object</td></tr> <tr><td style="text-align:left;">嵌套类型</td> <td style="text-align:left;">nested</td></tr></tbody></table> <h3 id="特殊类型"><a href="#特殊类型" class="header-anchor">#</a> 特殊类型</h3> <table><thead><tr><th style="text-align:left;">类型</th> <th style="text-align:left;">关键字</th></tr></thead> <tbody><tr><td style="text-align:left;">地理类型</td> <td style="text-align:left;">geo_point</td></tr> <tr><td style="text-align:left;">地理图形类型</td> <td style="text-align:left;">geo_shape</td></tr> <tr><td style="text-align:left;">IP 类型</td> <td style="text-align:left;">ip</td></tr> <tr><td style="text-align:left;">范围类型</td> <td style="text-align:left;">completion</td></tr> <tr><td style="text-align:left;">令牌计数类型</td> <td style="text-align:left;">token_count</td></tr> <tr><td style="text-align:left;">附件类型</td> <td style="text-align:left;">attachment</td></tr> <tr><td style="text-align:left;">抽取类型</td> <td style="text-align:left;">percolator</td></tr></tbody></table> <h3 id="mapping-属性"><a href="#mapping-属性" class="header-anchor">#</a> Mapping 属性</h3> <p>Elasticsearch 的 mapping 中的字段属性非常多,具体如下表格:</p> <p>| 属性名 | 描述 |
| :- | :- | |
| <strong><em><code>type</code></em></strong> | 字段类型,常用的有 text、integer 等等。 |
| <strong><em><code>index</code></em></strong> | 当前字段是否被作为索引。可选值为 <strong><em><code>true</code></em></strong>,默认为 true。 |
| <strong><em><code>store</code></em></strong> | 是否存储指定字段,可选值为 <strong><em><code>true</code></em></strong> | <strong><em><code>false</code></em></strong>,设置 true 意味着需要开辟单独的存储空间为这个字段做存储,而且这个存储是独立于 <strong><em><code>_source</code></em></strong> 的存储的。 |
| <strong><em><code>norms</code></em></strong> | 是否使用归一化因子,可选值为 <strong><em><code>true</code></em></strong> | <strong><em><code>false</code></em></strong>,不需要对某字段进行打分排序时,可禁用它,节省空间;<em>type</em><em>text</em> 时,默认为 <em>true</em>;而 <em>type</em><em>keyword</em> 时,默认为 <em>false</em>。 |
| <strong><em><code>index_options</code></em></strong> | 索引选项控制添加到倒排索引Inverted Index的信息这些信息用于搜索Search和高亮显示<strong><em><code>docs</code></em></strong>:只索引文档编号(Doc Number)<strong><em><code>freqs</code></em></strong>索引文档编号和词频率term frequency<strong><em><code>positions</code></em></strong>:索引文档编号,词频率和词位置(序号);<strong><em><code>offsets</code></em></strong>索引文档编号词频率词偏移量开始和结束位置和词位置序号。默认情况下被分析的字符串analyzed string字段使用 <em>positions</em>,其他字段默认使用 <em>docs</em>。此外,需要注意的是 <em>index_option</em> 是 elasticsearch 特有的设置属性;临近搜索和短语查询时,<em>index_option</em> 必须设置为 <em>offsets</em>,同时高亮也可使用 postings highlighter。 |
| <strong><em><code>term_vector</code></em></strong> | 索引选项控制词向量相关信息:<strong><em><code>no</code></em></strong>:默认值,表示不存储词向量相关信息;<strong><em><code>yes</code></em></strong>:只存储词向量信息;<strong><em><code>with_positions</code></em></strong>:存储词项和词项位置;<strong><em><code>with_offsets</code></em></strong>:存储词项和字符偏移位置;<strong><em><code>with_positions_offsets</code></em></strong>:存储词项、词项位置、字符偏移位置。<em>term_vector</em> 是 lucene 层面的索引设置。 |
| <strong><em><code>similarity</code></em></strong> | 指定文档相似度算法(也可以叫评分模型):<strong><em><code>BM25</code></em></strong>ES 5 之后的默认设置。 |
| <strong><em><code>copy_to</code></em></strong> | 复制到自定义 _all 字段,值是数组形式,即表明可以指定多个自定义的字段。 |
| <strong><em><code>analyzer</code></em></strong> | 指定索引和搜索时的分析器,如果同时指定 <em>search_analyzer</em> 则搜索时会优先使用 <em>search_analyzer</em>。 |
| <strong><em><code>search_analyzer</code></em></strong> | 指定搜索时的分析器,搜索时的优先级最高。 |
| <strong><em><code>null_value</code></em></strong> | 用于需要对 Null 值实现搜索的场景,只有 Keyword 类型支持此配置。 |</p> <h2 id="索引查询"><a href="#索引查询" class="header-anchor">#</a> 索引查询</h2> <h3 id="多个-index、多个-type-查询"><a href="#多个-index、多个-type-查询" class="header-anchor">#</a> 多个 index、多个 type 查询</h3> <p>Elasticsearch 的搜索 api 支持<strong>一个索引index的多个类型type查询</strong>以及**多个索引index**的查询。</p> <p>例如,我们可以搜索 twitter 索引下面所有匹配条件的所有类型中文档,如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>GET /twitter/_search?q<span class="token operator">=</span>user:shay
</code></pre></div><p>我们也可以搜索一个索引下面指定多个 type 下匹配条件的文档,如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>GET /twitter/tweet,user/_search?q<span class="token operator">=</span>user:banon
</code></pre></div><p>我们也可以搜索多个索引下匹配条件的文档,如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>GET /twitter,elasticsearch/_search?q<span class="token operator">=</span>tag:wow
</code></pre></div><p>此外我们也可以搜索所有索引下匹配条件的文档用_all 表示所有索引,如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>GET /_all/_search?q<span class="token operator">=</span>tag:wow
</code></pre></div><p>甚至我们可以搜索所有索引及所有 type 下匹配条件的文档,如下:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>GET /_search?q<span class="token operator">=</span>tag:wow
</code></pre></div><h3 id="uri-搜索"><a href="#uri-搜索" class="header-anchor">#</a> URI 搜索</h3> <p>Elasticsearch 支持用 uri 搜索,可用 get 请求里面拼接相关的参数,并用 curl 相关的命令就可以进行测试。</p> <p>如下有一个示例:</p> <div class="language-bash extra-class"><pre class="language-bash"><code>GET twitter/_search?q<span class="token operator">=</span>user:kimchy
</code></pre></div><p>如下是上一个请求的相应实体:</p> <div class="language-json extra-class"><pre class="language-json"><code><span class="token punctuation">{</span>
<span class="token property">&quot;timed_out&quot;</span><span class="token operator">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
<span class="token property">&quot;took&quot;</span><span class="token operator">:</span> <span class="token number">62</span><span class="token punctuation">,</span>
<span class="token property">&quot;_shards&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;total&quot;</span><span class="token operator">:</span> <span class="token number">1</span><span class="token punctuation">,</span>
<span class="token property">&quot;successful&quot;</span><span class="token operator">:</span> <span class="token number">1</span><span class="token punctuation">,</span>
<span class="token property">&quot;skipped&quot;</span><span class="token operator">:</span> <span class="token number">0</span><span class="token punctuation">,</span>
<span class="token property">&quot;failed&quot;</span><span class="token operator">:</span> <span class="token number">0</span>
<span class="token punctuation">}</span><span class="token punctuation">,</span>
<span class="token property">&quot;hits&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;total&quot;</span><span class="token operator">:</span> <span class="token number">1</span><span class="token punctuation">,</span>
<span class="token property">&quot;max_score&quot;</span><span class="token operator">:</span> <span class="token number">1.3862944</span><span class="token punctuation">,</span>
<span class="token property">&quot;hits&quot;</span><span class="token operator">:</span> <span class="token punctuation">[</span>
<span class="token punctuation">{</span>
<span class="token property">&quot;_index&quot;</span><span class="token operator">:</span> <span class="token string">&quot;twitter&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;_type&quot;</span><span class="token operator">:</span> <span class="token string">&quot;_doc&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;_id&quot;</span><span class="token operator">:</span> <span class="token string">&quot;0&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;_score&quot;</span><span class="token operator">:</span> <span class="token number">1.3862944</span><span class="token punctuation">,</span>
<span class="token property">&quot;_source&quot;</span><span class="token operator">:</span> <span class="token punctuation">{</span>
<span class="token property">&quot;user&quot;</span><span class="token operator">:</span> <span class="token string">&quot;kimchy&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;date&quot;</span><span class="token operator">:</span> <span class="token string">&quot;2009-11-15T14:12:12&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;message&quot;</span><span class="token operator">:</span> <span class="token string">&quot;trying out Elasticsearch&quot;</span><span class="token punctuation">,</span>
<span class="token property">&quot;likes&quot;</span><span class="token operator">:</span> <span class="token number">0</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
<span class="token punctuation">]</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</code></pre></div><p>URI 中允许的参数:</p> <table><thead><tr><th style="text-align:left;">名称</th> <th style="text-align:left;">描述</th></tr></thead> <tbody><tr><td style="text-align:left;">q</td> <td style="text-align:left;">查询字符串,映射到 query_string 查询</td></tr> <tr><td style="text-align:left;">df</td> <td style="text-align:left;">在查询中未定义字段前缀时使用的默认字段</td></tr> <tr><td style="text-align:left;">analyzer</td> <td style="text-align:left;">查询字符串时指定的分词器</td></tr> <tr><td style="text-align:left;">analyze_wildcard</td> <td style="text-align:left;">是否允许通配符和前缀查询,默认设置为 false</td></tr> <tr><td style="text-align:left;">batched_reduce_size</td> <td style="text-align:left;">应在协调节点上一次减少的分片结果数。如果请求中潜在的分片数量很大,则应将此值用作保护机制,以减少每个搜索请求的内存开销</td></tr> <tr><td style="text-align:left;">default_operator</td> <td style="text-align:left;">默认使用的匹配运算符,可以是<em>AND</em>或者<em>OR</em>,默认是<em>OR</em></td></tr> <tr><td style="text-align:left;">lenient</td> <td style="text-align:left;">如果设置为 true将会忽略由于格式化引起的问题如向数据字段提供文本默认为 false</td></tr> <tr><td style="text-align:left;">explain</td> <td style="text-align:left;">对于每个 hit包含了具体如何计算得分的解释</td></tr> <tr><td style="text-align:left;">_source</td> <td style="text-align:left;">请求文档内容的参数,默认 true设置 false 的话不返回_source 字段,可以使用**_source_include<strong></strong>_source_exclude**参数分别指定返回字段和不返回的字段</td></tr> <tr><td style="text-align:left;">stored_fields</td> <td style="text-align:left;">指定每个匹配返回的文档中的存储字段,多个用逗号分隔。不指定任何值将导致没有字段返回</td></tr> <tr><td style="text-align:left;">sort</td> <td style="text-align:left;">排序方式,可以是<em>fieldName</em><em>fieldName:asc</em>或者<em>fieldName:desc</em>的形式。fieldName 可以是文档中的实际字段也可以是诸如_score 字段,其表示基于分数的排序。此外可以指定多个 sort 参数(顺序很重要)</td></tr> <tr><td style="text-align:left;">track_scores</td> <td style="text-align:left;">当排序时,若设置 true返回每个命中文档的分数</td></tr> <tr><td style="text-align:left;">track_total_hits</td> <td style="text-align:left;">是否返回匹配条件命中的总文档数,默认为 true</td></tr> <tr><td style="text-align:left;">timeout</td> <td style="text-align:left;">设置搜索的超时时间,默认无超时时间</td></tr> <tr><td style="text-align:left;">terminate_after</td> <td style="text-align:left;">在达到查询终止条件之前,指定每个分片收集的最大文档数。如果设置,则在响应中多了一个 terminated_early 的布尔字段,以指示查询执行是否实际上已终止。默认为 no terminate_after</td></tr> <tr><td style="text-align:left;">from</td> <td style="text-align:left;">从第几条(索引以 0 开始)结果开始返回,默认为 0</td></tr> <tr><td style="text-align:left;">size</td> <td style="text-align:left;">返回命中的文档数,默认为 10</td></tr> <tr><td style="text-align:left;">search_type</td> <td style="text-align:left;">搜索的方式,可以是<em>dfs_query_then_fetch</em><em>query_then_fetch</em>。默认为<em>query_then_fetch</em></td></tr> <tr><td style="text-align:left;">allow_partial_search_results</td> <td style="text-align:left;">是否可以返回部分结果。如设置为 false表示如果请求产生部分结果则设置为返回整体故障默认为 true表示允许请求在超时或部分失败的情况下获得部分结果</td></tr></tbody></table> <h3 id="查询流程"><a href="#查询流程" class="header-anchor">#</a> 查询流程</h3> <p>在 Elasticsearch 中,查询是一个比较复杂的执行模式,因为我们不知道那些 document 会被匹配到,任何一个 shard 上都有可能,所以一个 search 请求必须查询一个索引或多个索引里面的所有 shard 才能完整的查询到我们想要的结果。</p> <p>找到所有匹配的结果是查询的第一步,来自多个 shard 上的数据集在分页返回到客户端之前会被合并到一个排序后的 list 列表,由于需要经过一步取 top N 的操作,所以 search 需要进过两个阶段才能完成,分别是 query 和 fetch。</p> <h2 id="参考资料"><a href="#参考资料" class="header-anchor">#</a> 参考资料</h2> <ul><li><a href="https://www.elastic.co/" target="_blank" rel="noopener noreferrer">Elasticsearch 官网<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></li> <li><a href="https://www.knowledgedict.com/tutorial/elasticsearch-index-mapping.html" target="_blank" rel="noopener noreferrer">Elasticsearch 索引映射类型及 mapping 属性详解<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></li></ul></div></div> <div class="page-edit"><div class="edit-link"><a href="https://github.com/dunwu/db-tutorial/edit/master/docs/12.数据库/07.搜索引擎数据库/01.Elasticsearch/04.Elasticsearch索引.md" target="_blank" rel="noopener noreferrer">📝 帮助改善此页面!</a> <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></div> <div class="tags"><a href="/db-tutorial/tags/?tag=%E6%95%B0%E6%8D%AE%E5%BA%93" title="标签">#数据库</a><a href="/db-tutorial/tags/?tag=%E6%90%9C%E7%B4%A2%E5%BC%95%E6%93%8E%E6%95%B0%E6%8D%AE%E5%BA%93" title="标签">#搜索引擎数据库</a><a href="/db-tutorial/tags/?tag=Elasticsearch" title="标签">#Elasticsearch</a><a href="/db-tutorial/tags/?tag=%E7%B4%A2%E5%BC%95" title="标签">#索引</a></div> <div class="last-updated"><span class="prefix">上次更新:</span> <span class="time">2024/10/09, 07:16:02</span></div></div> <div class="page-nav-wapper"><div class="page-nav-centre-wrap"><a href="/db-tutorial/pages/0fb506/" class="page-nav-centre page-nav-centre-prev"><div class="tooltip">Elasticsearch 简介</div></a> <a href="/db-tutorial/pages/83bd15/" class="page-nav-centre page-nav-centre-next"><div class="tooltip">Elasticsearch 查询</div></a></div> <div class="page-nav"><p class="inner"><span class="prev">
<a href="/db-tutorial/pages/0fb506/" class="prev">Elasticsearch 简介</a></span> <span class="next"><a href="/db-tutorial/pages/83bd15/">Elasticsearch 查询</a>
</span></p></div></div></div> <div class="article-list"><div class="article-title"><a href="/db-tutorial/archives/" class="iconfont icon-bi">最近更新</a></div> <div class="article-wrapper"><dl><dd>01</dd> <dt><a href="/db-tutorial/pages/b59ba2/"><div>
HBase Java API 管理功能
<!----></div></a> <span class="date">04-13</span></dt></dl><dl><dd>02</dd> <dt><a href="/db-tutorial/pages/ce5ca0/"><div>
HBase Java API 其他高级特性
<!----></div></a> <span class="date">03-31</span></dt></dl><dl><dd>03</dd> <dt><a href="/db-tutorial/pages/c8cfeb/"><div>
HBase 数据模型
<!----></div></a> <span class="date">03-16</span></dt></dl> <dl><dd></dd> <dt><a href="/db-tutorial/archives/" class="more">更多文章&gt;</a></dt></dl></div></div></main></div> <div class="footer"><div class="icons"><a href="mailto:forbreak@163.com" title="发邮件" target="_blank" class="iconfont icon-youjian"></a><a href="https://github.com/dunwu" title="GitHub" target="_blank" class="iconfont icon-github"></a></div>
Theme by
<a href="https://github.com/xugaoyi/vuepress-theme-vdoing" target="_blank" title="本站主题">Vdoing</a>
| Copyright © 2019-2024
<span>钝悟dunwu | CC-BY-SA-4.0</span></div> <div class="buttons"><div title="返回顶部" class="button blur go-to-top iconfont icon-fanhuidingbu" style="display:none;"></div> <div title="去评论" class="button blur go-to-comment iconfont icon-pinglun" style="display:none;"></div> <div title="主题模式" class="button blur theme-mode-but iconfont icon-zhuti"><ul class="select-box" style="display:none;"><li class="iconfont icon-zidong">
跟随系统
</li><li class="iconfont icon-rijianmoshi">
浅色模式
</li><li class="iconfont icon-yejianmoshi">
深色模式
</li><li class="iconfont icon-yuedu">
阅读模式
</li></ul></div></div> <!----> <!----> <div class="custom-html-window custom-html-window-rb" style="display:;"><div class="custom-wrapper"><span class="close-but">×</span> <div>
<div class="wwads-cn wwads-vertical windowRB" data-id="261" style="max-width:160px;
min-width: auto;min-height:auto;"></div>
<style>
.windowRB{ padding: 0;}
.windowRB .wwads-img{margin-top: 10px;}
.windowRB .wwads-content{margin: 0 10px 40px 10px;}
.custom-html-window-rb .close-but{
display: none;
}
</style>
</div></div></div></div><div class="global-ui"><div></div></div></div>
<script src="/db-tutorial/assets/js/app.be3f2e92.js" defer></script><script src="/db-tutorial/assets/js/2.aded268b.js" defer></script><script src="/db-tutorial/assets/js/70.40a2cea2.js" defer></script>
</body>
</html>