<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="zh-Hans-CN">
	<id>http://wiki.eijux.com/index.php?action=history&amp;feed=atom&amp;title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3</id>
	<title>ElasticSearch：运维相关 - 版本历史</title>
	<link rel="self" type="application/atom+xml" href="http://wiki.eijux.com/index.php?action=history&amp;feed=atom&amp;title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3"/>
	<link rel="alternate" type="text/html" href="http://wiki.eijux.com/index.php?title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3&amp;action=history"/>
	<updated>2026-04-29T14:44:43Z</updated>
	<subtitle>本wiki上该页面的版本历史</subtitle>
	<generator>MediaWiki 1.38.2</generator>
	<entry>
		<id>http://wiki.eijux.com/index.php?title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3&amp;diff=6486&amp;oldid=prev</id>
		<title>2023年3月31日 (五) 14:02 Eijux</title>
		<link rel="alternate" type="text/html" href="http://wiki.eijux.com/index.php?title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3&amp;diff=6486&amp;oldid=prev"/>
		<updated>2023-03-31T14:02:55Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;zh-Hans-CN&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;←上一版本&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2023年3月31日 (五) 22:02的版本&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot;&gt;第1行：&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;第1行：&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[category:&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;ElasticSearch&lt;/del&gt;]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;[[category:&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;ElasticSearch教程&lt;/ins&gt;]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 关于 ==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 关于 ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Eijux</name></author>
	</entry>
	<entry>
		<id>http://wiki.eijux.com/index.php?title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3&amp;diff=3746&amp;oldid=prev</id>
		<title>Eijux：​建立内容为“category:ElasticSearch  == 关于 == 【转自：[https://www.orchome.com/Elasticsearch/index https://www.orchome.com/Elasticsearch/index]】  == 设置elasti…”的新页面</title>
		<link rel="alternate" type="text/html" href="http://wiki.eijux.com/index.php?title=ElasticSearch%EF%BC%9A%E8%BF%90%E7%BB%B4%E7%9B%B8%E5%85%B3&amp;diff=3746&amp;oldid=prev"/>
		<updated>2021-05-22T11:10:05Z</updated>

		<summary type="html">&lt;p&gt;建立内容为“&lt;a href=&quot;/%E5%88%86%E7%B1%BB:ElasticSearch&quot; title=&quot;分类:ElasticSearch&quot;&gt;category:ElasticSearch&lt;/a&gt;  == 关于 == 【转自：[https://www.orchome.com/Elasticsearch/index https://www.orchome.com/Elasticsearch/index]】  == 设置elasti…”的新页面&lt;/p&gt;
&lt;p&gt;&lt;b&gt;新页面&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[category:ElasticSearch]]&lt;br /&gt;
&lt;br /&gt;
== 关于 ==&lt;br /&gt;
【转自：[https://www.orchome.com/Elasticsearch/index https://www.orchome.com/Elasticsearch/index]】&lt;br /&gt;
&lt;br /&gt;
== 设置elasticsearch的默认分区数和副本数 ==&lt;br /&gt;
elasticsearch 5.1版本，默认在配置中可设置分区和副本的数量现在不能使用了。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
修改现有elasticsearch的默认副本数：（如下，修改：副本数为0）&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
curl -XPUT https://192.168.x.x:9200/_settings -d '&lt;br /&gt;
 {&lt;br /&gt;
&amp;quot;index&amp;quot;:{&lt;br /&gt;
&amp;quot;number_of_replicas&amp;quot;:0&lt;br /&gt;
}&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
设置elasticsearch默认模板：（如下，修改：分区数为10，副本数为0）&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
curl -XPUT https://192.168.x.x:9200/_template/log -d '{&lt;br /&gt;
  &amp;quot;template&amp;quot;: &amp;quot;log-*&amp;quot;,&lt;br /&gt;
  &amp;quot;settings&amp;quot;: {&lt;br /&gt;
    &amp;quot;number_of_shards&amp;quot;: 10,&lt;br /&gt;
    &amp;quot;number_of_replicas&amp;quot;: &amp;quot;0&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
* 这样后面生成 log-* 的索引都会按照这个模板来了。&lt;br /&gt;
* 参见：【'''[https://www.elastic.co/guide/en/elasticsearch/reference/current/indices-templates.html 模板官网页面]'''】&lt;br /&gt;
&lt;br /&gt;
== Elasticsearch删除历史日志 ==&lt;br /&gt;
示例，从 kafka 采集日志到 es 的相关 logstash 的配置：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
input{&lt;br /&gt;
  kafka{&lt;br /&gt;
  topics =&amp;gt; [&amp;quot;logs-normal&amp;quot;,&amp;quot;logs-error&amp;quot;,&amp;quot;logs-point&amp;quot;]&lt;br /&gt;
     bootstrap_servers =&amp;gt; &amp;quot;192.168.x.x:9092,192.168.x.x:9092,192.168.x.x:9092&amp;quot;&lt;br /&gt;
     codec =&amp;gt; json&lt;br /&gt;
     group_id=&amp;gt; &amp;quot;logstash&amp;quot;&lt;br /&gt;
     codec =&amp;gt; multiline {&lt;br /&gt;
        pattern =&amp;gt; &amp;quot;\s&amp;quot;&lt;br /&gt;
        negate=&amp;gt;true&lt;br /&gt;
        what =&amp;gt; &amp;quot;previous&amp;quot;&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
filter{&lt;br /&gt;
   grok{&lt;br /&gt;
        match =&amp;gt; {&amp;quot;message&amp;quot; =&amp;gt; &amp;quot;\[(?&amp;lt;datetime&amp;gt;\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2},\d{3})&amp;quot;}&lt;br /&gt;
   }&lt;br /&gt;
   date{&lt;br /&gt;
        match =&amp;gt; [&amp;quot;datetime&amp;quot;, &amp;quot;yyyy-MM-dd HH:mm:ss,SSS&amp;quot;]&lt;br /&gt;
        target =&amp;gt; &amp;quot;@timestamp&amp;quot;&lt;br /&gt;
   }&lt;br /&gt;
   mutate {&lt;br /&gt;
    remove_field =&amp;gt; [&amp;quot;datetime&amp;quot;]&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
output{&lt;br /&gt;
    elasticsearch {&lt;br /&gt;
            action =&amp;gt; &amp;quot;index&amp;quot;&lt;br /&gt;
            hosts  =&amp;gt; [&amp;quot;192.168.x.x:9200&amp;quot;,&amp;quot;192.168.x.x:9200&amp;quot;,&amp;quot;192.168.x.x:9200&amp;quot;]&lt;br /&gt;
            index  =&amp;gt; &amp;quot;applog-%{+YYYY.MM.dd}&amp;quot;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
如上，“index =&amp;gt; &amp;quot;applog-%{+YYYY.MM.dd}&amp;quot;”会根据 timestamp 的时间来生成每天的日志块，那么删除日志也根据“索引+日期”来删除。&lt;br /&gt;
&lt;br /&gt;
如：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
curl -XDELETE  &amp;quot;192.168.101.123:9200/applog-2016.12.26&amp;quot;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
查看日志存储的位置，磁盘已经释放了。&lt;br /&gt;
&lt;br /&gt;
== ElasticSearch定时删除数据 ==&lt;br /&gt;
如下脚本可以定时删除数据：&lt;br /&gt;
: （新建 delete_es_by_day.sh 脚本）&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
#!/bin/sh  &lt;br /&gt;
# example: sh  delete_es_by_day.sh logstash-kettle-log logsdate 30  &lt;br /&gt;
&lt;br /&gt;
index_name=$1  &lt;br /&gt;
daycolumn=$2  &lt;br /&gt;
savedays=$3  &lt;br /&gt;
format_day=$4  &lt;br /&gt;
&lt;br /&gt;
if [ ! -n &amp;quot;$savedays&amp;quot; ]; then  &lt;br /&gt;
  echo &amp;quot;the args is not right,please input again....&amp;quot;  &lt;br /&gt;
  exit 1  &lt;br /&gt;
fi  &lt;br /&gt;
&lt;br /&gt;
if [ ! -n &amp;quot;$format_day&amp;quot; ]; then  &lt;br /&gt;
   format_day='%Y%m%d'  &lt;br /&gt;
fi  &lt;br /&gt;
&lt;br /&gt;
sevendayago=`date -d &amp;quot;-${savedays} day &amp;quot; +${format_day}`  &lt;br /&gt;
&lt;br /&gt;
curl -XDELETE &amp;quot;10.130.3.102:9200/${index_name}/_query?pretty&amp;quot; -d &amp;quot;  &lt;br /&gt;
{  &lt;br /&gt;
        &amp;quot;query&amp;quot;: {  &lt;br /&gt;
                &amp;quot;filtered&amp;quot;: {  &lt;br /&gt;
                        &amp;quot;filter&amp;quot;: {  &lt;br /&gt;
                                &amp;quot;bool&amp;quot;: {  &lt;br /&gt;
                                        &amp;quot;must&amp;quot;: {  &lt;br /&gt;
                                                &amp;quot;range&amp;quot;: {  &lt;br /&gt;
                                                        &amp;quot;${daycolumn}&amp;quot;: {  &lt;br /&gt;
                                                                &amp;quot;from&amp;quot;: null,  &lt;br /&gt;
                                                                &amp;quot;to&amp;quot;: ${sevendayago},  &lt;br /&gt;
                                                                &amp;quot;include_lower&amp;quot;: true,  &lt;br /&gt;
                                                                &amp;quot;include_upper&amp;quot;: true  &lt;br /&gt;
                                                        }  &lt;br /&gt;
                                                }  &lt;br /&gt;
                                        }  &lt;br /&gt;
                                }  &lt;br /&gt;
                        }  &lt;br /&gt;
                }  &lt;br /&gt;
        }  &lt;br /&gt;
}&amp;quot;  &lt;br /&gt;
&lt;br /&gt;
echo &amp;quot;ok&amp;quot;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
参数说明：&lt;br /&gt;
# 索引名；&lt;br /&gt;
# 日期字段名；&lt;br /&gt;
# 保留最近几天数据，单位天；&lt;br /&gt;
# 日期格式，可不输（默认形式20160101）&lt;br /&gt;
&lt;br /&gt;
== ElasticSearch中根据查询结果删除数据（delete by query） ==&lt;br /&gt;
原有的方法在2.0版本中已经删除了，提供了delete by query插件来实现这个功能。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
# 安装插件：&lt;br /&gt;
#: &amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
cd /path/to/ElasticSearch&lt;br /&gt;
sudo bin/plugin install delete-by-query&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
#: 成功安装后：&lt;br /&gt;
#: [[File:Elasticsearch：安装delete-by-query插件.png|400px]]&lt;br /&gt;
#* 集群环境下必须在每个结点上安装，安装之后要重启结点才能使这个插件生效。&lt;br /&gt;
#*（安装和重启之后就可以像2.0以前的版本一样使用delete by query了。）&lt;br /&gt;
# 执行删除命令：&lt;br /&gt;
#: &amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
curl -XDELETE 'https://10.0.21.xx:9200/applog/logs/_query?pretty' -d ' &lt;br /&gt;
{&lt;br /&gt;
  &amp;quot;query&amp;quot;: {&lt;br /&gt;
    &amp;quot;filtered&amp;quot;: {&lt;br /&gt;
      &amp;quot;filter&amp;quot;: {&lt;br /&gt;
        &amp;quot;range&amp;quot;: {&lt;br /&gt;
          &amp;quot;@timestamp&amp;quot;: {&lt;br /&gt;
            &amp;quot;lte&amp;quot;: &amp;quot;2016-11-21&amp;quot;&lt;br /&gt;
          }&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}'&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
# 合并：？？？？什么鬼？？？？&lt;br /&gt;
#: &amp;lt;syntaxhighlight lang=&amp;quot;bash&amp;quot; highlight=&amp;quot;&amp;quot;&amp;gt;&lt;br /&gt;
curl -XPOST 'https://10.0.21.xx:9200/applog/_optimize?max_num_segments=1'&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;/div&gt;</summary>
		<author><name>Eijux</name></author>
	</entry>
</feed>