ES搜索系列

ES使用中遇到的多种坑,以及解决方案

2019-01-28  本文已影响57人  95a6af369245

  1.查询不到导致404报错

  在使用get或者search进行查询获取文档的时候,如果没有结果会抛出404的异常。

  我们当然不希望抛出异常,这时候就要使用ignore这个参数来忽略报错,ignore可以忽略异常,其值是需要忽略的异常对应的返回码,常见的有400表示索引已存在,404表示索引没找到。

  $params = [

  'index' = 'test_missing',

  'type' = 'test',

  'id' = 1,

  'client' = [ 'ignore' = 404 ] //忽略404报错,兼容查询不到结果的情况

  ];

  echo $client-get($params);

  //这时候如果没有查询结果,将会返回一个found字段

  [found] = bool(false)

 2.search方法不好使(我使用的是5.0版本)

  不知道为啥,原本提供的search会报411错误(还没有错误信息,跟踪源码也没看出个所以然来),再三确保拼接的参数等都没有问题,查了各种资料都没有解决(据说是body不存在引起的),只能改为curl请求http的模式。

  public function search($params)

  {

  $index = 'your index';

  $type = 'your type';

  $url = sprintf('your es url/%s/%s/_search', $index, $type);

  //封装了curl请求方法

  $data = CurlUtil::post($url, null, json_encode($params['body']));

  $data = json_decode($data, true);

  return $data;

  }

 3.get和delete方法的时候,index不能使用通配符 *

  我想获取(删除)一行id为XXX的数据时,使用了index_*去匹配,发现没有结果返回,要指定到index_1才能有结果返回。

  search方法就可以使用通配符。

4.假如字段默认设定一种类型,则不能插入另一种类型的数据(好像是废话,但是php中很容易出现,弱类型语言。。)

  我在ES中创建了一些数据作为测试,数据内容如下:

  [

  'age' = '123',

  'name' = '456' //注意,这里应该是string类型才对

  ]

  成功插入一行数据,正当我美滋滋把这个创建函数拿去正常流程跑的时候出现问题了。。

  {error:{root_cause:[{type:mapper_parsing_exception,reason:failed to parse [name]}],type:mapper_parsing_exception,reason:failed to parse [name],caused_by:{type:number_format_exception,reason:For input string: \NateHuang\}},status:400}

  类型错误?不能插入string类型的?啥情况?于是我去ES查了下刚刚插入的数据,发现数据去到ES那边变成这样

  [

  'age' = 123,

  'name' = 456 //这里变成数字类型了

  ]

  age被默认设置成数字类型倒还没什么,name这样搞就玩犊子了。。真的坑啊。。

上一篇下一篇

猜你喜欢

热点阅读