Elasticsearch 快照 备份与恢复(本地) - Star-Hitian - 博客园
2019-07-18 15:25:58 Author: www.cnblogs.com(查看原文) 阅读量:280 收藏

Elasticsearch 快照备份与恢复

修改es配置文件,增加本地保存路径

path.repo: ["/es_backup/my_backup/"] #如果想保存到多个路径可以逗号隔开
# 修改完之后,记得重启Es
# 如果本地没有该目录,创建该目录,目录权限也要设置正确

创建基于本地的快照仓库

curl -X PUT "http://localhost:9200/_snapshot/my_backup&pretty" -H 'Content-Type: application/json' -d'
{
    "type": "fs",
    "settings": {
        "compress" : "true",
        "location": "/es_backup/my_backup/"
    }
}'

# 查看仓库信息
curl -XGET "http://localhost:9200/_snapshot/my_backup?pretty"

# 删除仓库
curl -XDELETE 'http://localhost:9200/_snapshot/my_backup'

创建快照

# 创建快照
curl -XPUT ’http://localhost:9200/_snapshot/my_backup/snapshot_2?wait_for_completion=true‘

# 使用当前日期来命名快照,日期格式:snapshot-2018.11.29 curl -X PUT "http://localhost:9200/_snapshot/my_backup/%3Csnapshot-%7Bnow%2Fd%7D%3E"# 查看索引
curl -XGET 'http://localhost:9200/_cat/indices?v'
# 指定索引创建快照 curl
-XPUT 'http://localhost:9200/_snapshot/my_backup/snapshot_1' -H 'Content-Type: application/json' -d '{ "indices": "nginx-ingress-controller-log-2018.11.27,nginx-ingress-controller-log-2018.11.28", "ignore_indices": "missing" }'

# 查看所有快照
curl -XGET "http://localhost:9200/_snapshot/my_backup?pretty"
# 查看指定快照
curl -XGET "localhost:9200/_snapshot/my_backup/_all?pretty"

恢复快照

# 恢复快照(所有索引)
curl -XPOST http://localhost:9200/_snapshot/my_backup/snapshot_1/_restore
# 恢复快照(指定索引)
curl -XPOST "http://localhost:9200/_snapshot/my_backup/snapshot-2018.11.29/_restore?wait_for_completion=true" -H 'Content-Type: application/json' -d'
{
    "indices":"nginx-ingress-controller-log-2018.11.29",
    "ignore_unavailable":"true"
}'

# 注意:恢复快照的时候需要停止要恢复的索引
# 快照恢复前需要关掉索引
curl -XPOST "http://localhost:9200/my_index/_close"
curl -XPOST "http://localhost:9200/customer/_close"
 
# 开启索引
curl -XPOST "http://localhost:9200/my_index/_open"
 
# 查看索引状态
curl -XGET 'http://localhost:9200/_cat/indices?v'
curl -XGET "http://localhost:9200/_recovery/"

以下是一些常用命令:

# 查看仓库信息
curl -XGET "localhost:9200/_snapshot/my_backup?pretty"

# 查看所有快照
curl -XGET "localhost:9200/_snapshot/my_backup/_all?pretty"

# 删除快照
curl -XDELETE "localhost:9200/_snapshot/my_backup/snapshot_2"


# 查看仓库列表
curl -X GET "localhost:9200/_cat/repositories?v" 

# 获取所有已注册快照仓库
curl -X GET "localhost:9200/_snapshot/_all?pretty"

文章来源: https://www.cnblogs.com/Star-Haitian/articles/10039866.html
如有侵权请联系:admin#unsafe.sh