我正在设置一个简单的 Node.js REST 服务以使用官方 Javascript 客户端与 Elasticsearch 交互。我在本地运行此代码,但集群位于远程位置。当我通过浏览器时,使用 _head
插件,我可以毫无问题地连接 ES 和查询。但是,通过 Javascript 客户端执行此操作会使所有请求超时。我设置了 ElasticSearch 对象,但向它发送任何请求根本不起作用。我认为这不是网络问题,因为我可以通过浏览器访问 ES。这就是我请求东西的方式,一个非常基本的 get:
var elasticsearch = require("elasticsearch");
var es = new elasticsearch.Client({
host: "https://my-address:9200/", // also tried without protocol part and trailing slashes
log: "error",
sniffOnStart: true
});
es.get({
index: "things",
type: "someThing",
id: "42"
}).then(doSomeStuff, handleStuffFailed);
这失败并显示一条简单的错误消息 Errror: Request timeout after 30000ms.
我在这里错过了什么吗?我已经阅读了客户端文档,这似乎是客户端的基本“hello world”。
原文由 Kroltan 发布,翻译遵循 CC BY-SA 4.0 许可协议
尝试在实例化 ES Client 时扩展 requestTimeout 参数。
我有一个耗时不到 10 分钟的长时间运行过程。通过将 requestTimeout 值设置为 60000(10 分钟),该过程可以在不超时的情况下完成。