【Elasticsearch】_reindex api请求

在Elasticsearch中,你可以使用 `_tasks` API 来检查 `_reindex` 任务的状态。当你发起一个 `_reindex` 请求时,Elasticsearch 会返回一个任务 ID,你可以使用这个任务 ID 来查询任务的详细状态。

以下是如何检查 `_reindex` 任务状态的步骤:

1. 获取任务 ID

首先,你需要获取 `_reindex` 任务的 ID。当你发送 `_reindex` 请求时,Elasticsearch 会返回一个响应,其中包含任务 ID。例如:

```json

POST _reindex

{

"source": {

"index": "kibana_sample_data_logs",

"size": 50

},

"dest": {

"index": "lang-test",

"pipeline": "my-lang-pipeline"

}

}

```

响应可能类似于:

```json

{

"took": 123,

"tasks": "node_id:task_id",

"total": 50,

"created": 50,

"deleted": 0,

"batches": 1,

"version_conflicts": 0,

"noops": 0,

"retries": {

"bulk": 0,

"search": 0

},

"throttled_millis": 0,

"requests_per_second": -1.0,

"throttled_until_millis": 0,

"failures": []

}

```

在这个响应中,`"tasks": "node_id:task_id"` 是任务的唯一标识符。

2. 使用 `_tasks` API 查询任务状态

你可以使用 `_tasks` API 来查询任务的详细状态。假设任务 ID 是 `node_id:task_id`,你可以发送以下请求来获取任务状态:

```json

GET _tasks/node_id:task_id

```

这将返回任务的详细信息,包括任务的状态、进度和任何潜在的错误信息。例如:

```json

{

"completed": true,

"task": {

"node": "node_id",

"id": 123456789,

"type": "transport",

"action": "indices:data/write/reindex",

"status": {

"total": 50,

"updated": 50,

"created": 50,

"deleted": 0,

"batches": 1,

"version_conflicts": 0,

"noops": 0,

"retries": {

"bulk": 0,

"search": 0

},

"throttled_millis": 0,

"requests_per_second": -1.0,

"throttled_until_millis": 0

},

"description": "reindex from [kibana_sample_data_logs] to [lang-test]",

"start_time_in_millis": 1642956000000,

"running_time_in_nanos": 123456789,

"cancellable": true,

"headers": {}

}

}

```

3. 检查任务状态

在返回的 JSON 中,你可以查看以下字段来了解任务的状态:

  • `completed`: 任务是否已完成。

  • `status`: 任务的详细状态,包括已处理的文档数量、创建的文档数量、删除的文档数量等。

  • `running_time_in_nanos`: 任务运行的时间(纳秒)。

  • `cancellable`: 任务是否可以取消。

通过这些信息,你可以了解 `_reindex` 任务的进展和结果。

4. 取消任务(可选)

如果需要取消正在进行的 `_reindex` 任务,你可以使用 `_tasks` API 的 `cancel` 功能。例如:

```json

POST _tasks/node_id:task_id/_cancel

```

这将尝试取消指定的任务。请注意,取消操作可能不会立即生效,具体取决于任务的当前状态和进度。

相关推荐
muyun280018 小时前
Docker 下部署 Elasticsearch 8 并集成 Kibana 和 IK 分词器
elasticsearch·docker·容器
在未来等你1 天前
Elasticsearch面试精讲 Day 17:查询性能调优实践
大数据·分布式·elasticsearch·搜索引擎·面试
在未来等你2 天前
Elasticsearch面试精讲 Day 18:内存管理与JVM调优
大数据·分布式·elasticsearch·搜索引擎·面试
Elasticsearch2 天前
在 Elastic Observability 中使用 Discover 的追踪获取更深入的应用洞察
elasticsearch
婲落ヽ紅顏誶2 天前
测试es向量检索
大数据·elasticsearch·搜索引擎
咖啡Beans2 天前
Docker安装ELK(Elasticsearch + Logstash + Kibana)
后端·elasticsearch·docker
一勺菠萝丶2 天前
Jenkins 构建 Node 项目报错解析与解决——pnpm lockfile 问题实战
elasticsearch·servlet·jenkins
小花鱼20252 天前
Elasticsearch (ES)相关
大数据·elasticsearch
阿里嘎多哈基米2 天前
ES——(三)DSL高级查询
elasticsearch·搜索引擎·全文检索·kibana·倒排索引
AAA修煤气灶刘哥2 天前
ES 高级玩法大揭秘:从算分骚操作到深度分页踩坑,后端 er 速进!
java·后端·elasticsearch