我们正在做一些操作,然后我们尝试将数据插入到弹性数据库中。我的问题是,很少有记录插入索引,也很少丢失。我可以在我的日志文件中看到数据,而且我也没有弹性错误。由于没有错误,我也无法调试。即使没有插入,客户也会得到响应。下面是我的代码。
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);
}
这个问题只发生在负载高的时候。可能是什么原因?
答案 0 :(得分:2)
它是不稳定的,正如您所说的“负载高时会发生这种情况”。如果您在索引新文档时设置 refresh=true
,它可能会解决问题。
来自Index API:
<块引用>refresh(可选,枚举)如果为 true,Elasticsearch 会刷新受影响的分片以使此操作对搜索可见,如果为 wait_for 则等待刷新以使此操作对搜索可见,如果为 false 则执行没有刷新。有效值:true、false、wait_for。默认值:false。