如何使用elasticdump进行elasticsearch数据还原

使用elasticsearch进行开发,生产环境不能改动,可能需要将数据从生产环境复制到测试环境。

elasticdump是实现这一功能的理想工具,可通过简单几行命令,即完成数据的复制迁移。

这里尝试基于docker版本的elasticsearch,验证elasticdump迁移复制数据的功能。

1 安装elasticdump

这里假设使用conda环境,先安装npm工具nodejs,然后安装elasticdump

conda install conda-forge::nodejs

npm install -g elasticdump

2 测试elasticdump

2.1 elasticsearch创建

采用docker创建elasticsearch,版本为8.11.3,启动命令如下所示。

为简化操作关闭安全验证,具体为xpack.security.enabled=false 。

这种操作通常应用于内部系统或开发测试环境。

docker run --name es01 -p 9200:9200 -p 8300:9300 \

-e "discovery.type=single-node" \

-e ES_JAVA_OPTS="-Xms1G -Xmx1G" \

-e xpack.security.enabled=false \

-d docker.elastic.co/elasticsearch/elasticsearch:8.11.3

es启动完成后,可通过以下命令直接验证。

curl http://localhost:9200/

2.2 创建索引

创建index,名称为index_name

curl -XPUT "https://localhost:9200/index_name"

2.3 导出数据

从现有源es dump索引数据,包括mapping数据和data数据。

假设现有es未设置ca证书、用户名、密码。

elasticdump \

--input='http://es_host:es_port/index_name' \

--output=/path/to/index_mapping.json \

--type=mapping

elasticdump \

--input='http://es_host:es_port/index_name \

--output= /path/to/index_data.json \

--type=data

2.4 导入数据

将之前导出的源es索引数据,导入本地创建的es。

命令如下

lasticdump \

--input=/path/to/index_mapping.json \

--output=http://localhost:9200/index_name \

--type=mapping

elasticdump \

--input=/path/to/index_data.json \

--output=http://localhost:9200/index_name \

--type=data

输出示例如下

Tue, 04 Nov 2025 10:09:00 GMT | starting dump

Tue, 04 Nov 2025 10:09:00 GMT | got 100 objects from source file (offset: 0)

Tue, 04 Nov 2025 10:09:00 GMT | got 100 objects from source file (offset: 100)

......

Tue, 04 Nov 2025 10:09:03 GMT | Total Writes: xxxx

Tue, 04 Nov 2025 10:09:03 GMT | dump complete

reference


elasticsearch-dump

https://github.com/elasticsearch-dump/elasticsearch-dump

【ElasticSearch】elasticdump 导入/导出数据及常见报错

https://blog.csdn.net/zzddada/article/details/121744016

Mac本地docker安装Kibana+ElasticSearch

https://blog.csdn.net/liliang199/article/details/151581138

python访问基于docker搭建的elasticsearch

https://blog.csdn.net/liliang199/article/details/151586083

Elasticsearch备份与还原:使用elasticdump

https://cloud.tencent.com/developer/article/2360111

Elasticsearch8关闭安全认证功能

https://juejin.cn/post/7203637198120878137

相关推荐
Coder_Boy_17 分钟前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
2501_9449347318 分钟前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
九河云1 小时前
5秒开服,你的应用部署还卡在“加载中”吗?
大数据·人工智能·安全·机器学习·华为云
Gain_chance2 小时前
36-学习笔记尚硅谷数仓搭建-DWS层数据装载脚本
大数据·数据仓库·笔记·学习
每日新鲜事2 小时前
热销复盘:招商林屿缦岛203套售罄背后的客户逻辑分析
大数据·人工智能
AI架构全栈开发实战笔记3 小时前
Eureka 在大数据环境中的性能优化技巧
大数据·ai·eureka·性能优化
AI架构全栈开发实战笔记3 小时前
Eureka 对大数据领域服务依赖关系的梳理
大数据·ai·云原生·eureka
自挂东南枝�4 小时前
政企舆情大数据服务平台的“全域洞察中枢”
大数据
Dragon~Snow4 小时前
Linux Centos9 安装 Elasticsearch
linux·elasticsearch·jenkins
熊延4 小时前
麒麟V10系统安装部署elasticsearch
linux·运维·服务器·elasticsearch·搜索引擎·全文检索