为了账号安全,请及时绑定邮箱和手机立即绑定

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

标签:
大数据

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

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这样搞就玩犊子了。。真的坑啊。。

点击查看更多内容
3人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
PHP开发工程师
手记
粉丝
6767
获赞与收藏
195

关注作者,订阅最新文章

阅读免费教程

感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消