前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ES使用中遇到的多种坑,以及解决方案(不定期更新)

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

作者头像
NateHuang
发布2019-03-12 17:27:19
2.2K0
发布2019-03-12 17:27:19
举报
文章被收录于专栏:开发经验记录开发经验记录

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.查询不到导致404报错
  • 2.search方法不好使(我使用的是5.0版本)
  • 3.get和delete方法的时候,index不能使用通配符 *
  • 4.假如字段默认设定一种类型,则不能插入另一种类型的数据(好像是废话,但是php中很容易出现,弱类型语言。。)
相关产品与服务
Elasticsearch Service
腾讯云 Elasticsearch Service(ES)是云端全托管海量数据检索分析服务,拥有高性能自研内核,集成X-Pack。ES 支持通过自治索引、存算分离、集群巡检等特性轻松管理集群,也支持免运维、自动弹性、按需使用的 Serverless 模式。使用 ES 您可以高效构建信息检索、日志分析、运维监控等服务,它独特的向量检索还可助您构建基于语义、图像的AI深度应用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档