ES使用中遇到的多种坑,以及解决方案
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这样搞就玩犊子了。。真的坑啊。。