javascript - elasticsearch.js&nodejs scoll方法的问题

查看:143
本文介绍了javascript - elasticsearch.js&nodejs scoll方法的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

不知道有没有用过nodejs结合elasticsearch做开发的。今天想尝试一下,执行了一个scoll查询,出现一个很奇怪的错误,请帮忙看看。
这是我的方法

esdao.searchScollFor130 = function() {
    esClient.search({
        index: esconf.index130,
        type: esconf.ttype,
        scroll: '30s',
        search_type: 'scan',
        body: {query: {match_all: {}}}
    }, function getMoreUntilDone(err, ress) {
        console.log(ress);
        if (92202 !== allresult.length) {
            esClient.scroll({
                scrollId: ress._scroll_id,
                scroll: '30s'
            }, getMoreUntilDone);
        } else {
            console.log('every "test" title', allTitles);
        }
    });
    console.log(allresult);
}

但是执行过程中后台一直抛错

换一种写法,把92202换成ress.hits.total想取得总条数,但是:

很是郁闷,我直接把这个返回结果复制出来赋给一个变量,却是可以取得到total值。

解决方案

我自己已经找到问题原因了,把解决方案说一下,免得遇到同样问题的再走弯路,因为我的服务器版本是比较老的1.2的版本,所以,只要在创建客户端的时候加上版本号就好了。

var esClient = new elasticsearch.Client({
  host: esconf.host130,
  apiVersion: "0.90",
  log: 'error'
  });

这是我在github上提的问题,是看到另一个提问的人给了我的启发。大家也可以参考一下我的解决过程。

这篇关于javascript - elasticsearch.js&nodejs scoll方法的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆