ES使用中遇到的多种坑,以及解决方案(不按期更新)

最近在使用php中的elasticsearch/elasticsearch库的时候,遇到不少问题,用此博客记录踩过的坑。php

1.查询不到致使404报错

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

咱们固然不但愿抛出异常,这时候就要使用ignore这个参数来忽略报错,ignore能够忽略异常,其值是须要忽略的异常对应的返回码,常见的有400表示索引已存在,404表示索引没找到。app

$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的模式。curl

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才能有结果返回。elasticsearch

search方法就可使用通配符。函数

 

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

我在ES中建立了一些数据做为测试,数据内容以下:post

[
  '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那边变成这样url

[
  'age' => 123,
  'name' => 456 //这里变成数字类型了
]

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

相关文章
相关标签/搜索