es之ingest、pipeline、painless

一,injest pipeline

// 测试
POST _ingest/pipeline/_simulate
{
  
   "pipeline":{
     "description":"split tags",
     "processors": [
        {
          "split":{
            "field":"tags",
            "separator":","
          }
        }
      ]
   },
   "docs":[
       {
         "index":"index",
         "_id":"id",
         "_source":{
           "tags":"elastic,hadoop,elastic"
         }
       }
    ]
}
//创建
PUT _ingest/pipeline/blog_pipeline
{
  
     "description":"split tags",
     "processors": [
        {
          "split":{
            "field":"tags",
            "separator":","
          }
        }
      ]
   
}
// 测试创建的pipeline
POST _ingest/pipeline/blog_pipeline/_simulate
{
   "docs":[
       {
         "index":"index",
         "_id":"id",
         "_source":{
           "tags":"elastic,hadoop,elastic"
         }
       }
    ]
}
POST my_blog/_doc/?pipeline=blog_pipeline
{
  "tags":"android,java"
}


POST my_blog/_doc/
{
  "tags":"android,java"
}

// 更新数据
POST my_blog/_update_by_query?pipeline=blog_pipeline
{
  "query":{
    "bool": {
      "must":{
        "term":{
           "_id" : "kMiLWXIBgW5fcfR1lXxN"
        }
      }
    }
  }
}

三,painless

在这里插入图片描述
1, 在update中使用脚本

POST users/_update/5
{
  "script":{
    "source": "ctx._source.age += params.new_age",
    "params": {
      "new_age":5
    }
  }
}

2,在query中使用脚本

GET users/_search/
{
  "query": {
    "term": {
      "_id": {
        "value": "1"
      }
    }
  }, 
  "script_fields": {
    "rnd_age": {
      "script": {
        "lang": "painless",
        "source": """
            java.util.Random r = new Random();
            doc['age'].value + r.nextInt(100); 
        """
      }
    }
  }
}

3,在pipeline中使用

POST _ingest/pipeline/_simulate
{
  "pipeline": {
    "description": "tag splitddd",
    "processors": [
      {
        "split": {
          "field": "tags",
          "separator": ","
        }
      },
      {
        "script": 
          """
            if(ctx.containsKey("mm")) {
              ctx.mm_len = ctx.mm.length();
            }else {
              ctx.mm_len = 0;
            }
          """
        
      }
    ]
  },
   
  "docs":[
       {
         "index":"index",
         "_source":{
            "mm":"1111",
            "tags":"1,2,3,4"
         }
       }
    ]
    
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小手追梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值