弹性搜索不使用 Nodejs 插入记录?

时间:2021-02-15 05:47:55

标签: node.js elasticsearch

我们正在做一些操作,然后我们尝试将数据插入到弹性数据库中。我的问题是,很少有记录插入索引,也很少丢失。我可以在我的日志文件中看到数据,而且我也没有弹性错误。由于没有错误,我也无法调试。即使没有插入,客户也会得到响应。下面是我的代码。

 file.js
 async function InsertModelES() {
    var objn= {
        PID: ID,
        TID: MID,
        UserID:userID,
        HID: HrID,
    };
    await elasticClient.index({
        index: 'scrn', 
        type: '_doc',
        id: ID ,
        body: objn
    }, function (err, data) { 
    if (err) {
        console.log("err ", err)
    }
    else {
    } 
 })  

 app.js
 
 app.post('/allrequest', async function(req, res){ 
  let result = await file1.allrequest(data,urn);
  await file1.InsertModelES()
  res.send(result);  
 }

这个问题只发生在负载高的时候。可能是什么原因?

1 个答案:

答案 0 :(得分:2)

它是不稳定的,正如您所说的“负载高时会发生这种情况”。如果您在索引新文档时设置 refresh=true,它可能会解决问题。

来自Index API

<块引用>

refresh(可选,枚举)如果为 true,Elasticsearch 会刷新受影响的分片以使此操作对搜索可见,如果为 wait_for 则等待刷新以使此操作对搜索可见,如果为 false 则执行没有刷新。有效值:true、false、wait_for。默认值:false。

相关问题