Elasticsearch 快照 备份与恢复(本地)


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"

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM