javascript - elasticsearch.js&nodejs scoll方法的問題
phpcn_u1582
phpcn_u1582 2017-05-24 11:38:21
0
1
810

不知道有沒有用過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值。

phpcn_u1582
phpcn_u1582

全部回覆(1)
给我你的怀抱

我自己已經找到問題原因了,把解決方案說一下,免得遇到同樣問題的再走彎路,因為我的伺服器版本是比較老的1.2的版本,所以,只要在創建客戶端的時候加上版本號就好了。

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

這是我在github上提的問題,是看到另一個提問的人給了我的啟發。大家也可以參考一下我的解決過程。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板