• ES备份


    Elasticsearch的备份和恢复

    距离上次讲Elasticsearch的安装已经快一个半月了,作为一个半路出家的前端开发,简单的使用中也体验到了Elasticsearch的强大。目前在一个自己开发的小站点中,使用Elasticsearch索引了近200W简单数据,占用资源极小,搜索速度极快。下一步打算优化一下分词(目前使用的是标准分词器),所以想先备份一下,于是有了今天的文章。

    备份

    Elasticsearch的一大特点就是使用简单,api也比较强大,备份也不例外。简单来说,备份分两步:1、创建一个仓库。2、备份指定索引。下面一步一步来:

    1、创建一个仓库(creating the repository)

    备份数据之前,要创建一个仓库来保存数据,仓库的类型支持Shared filesystem, Amazon S3, HDFS和Azure Cloud。下面以文件系统为例:

    1. PUT http://127.0.0.1:9200/_snapshot/my_backup
    2. {
    3. "type": "fs",
    4. "settings": {
    5. "location": "/mount/backups/my_backup"
    6. }
    7. }

    上面的代码,我们创建了一个名叫my_backup 的备份,存放在本地的/mount/backups/my_backup 目录下。除了location 参数外,还可以通过max_snapshot_bytes_per_sec 和max_restore_bytes_per_sec 来限制备份和恢复时的速度,如下:

    1. POST http://127.0.0.1:9200/_snapshot/my_backup/
    2. {
    3. "type": "fs",
    4. "settings": {
    5. "location": "/mount/backups/my_backup",
    6. "max_snapshot_bytes_per_sec" : "50mb",
    7. "max_restore_bytes_per_sec" : "50mb"
    8. }
    9. }

    注意:第一段代码用的是PUT 请求,用来创建repository,第二段代码用的是POST 请求,来修改已经存在的repository。

    2、备份索引

    仓库创建好之后就可以开始备份了。一个仓库可以包含多个快照(snapshots),快照可以存所有的索引,部分索引或者一个单独的索引。可以给索引指定一个唯一的名字:

    1. PUT http://127.0.0.1:9200/_snapshot/my_backup/snapshot_1

    上面的代码会将所有正在运行的索引,备份到my_backup仓库下一个叫snapshot_1的快照中。上面的api会立刻返回,然后备份工作在后台运行。如果你想api同步执行,可以加wait_for_completion 标志:

    1. PUT http://127.0.0.1:9200/_snapshot/my_backup/snapshot_1?wait_for_completion=true

    上面的方法会在备份完成后才返回,如果数据量大的话,会花很长时间。

    如果只想备份部分索引的话,可以加上indices 参数:

    1. PUT http://127.0.0.1:9200/_snapshot/my_backup/snapshot_2
    2. {
    3. "indices": "index_1,index_2"
    4. }

    3、删除备份

    不要手动删除文件(Elasticsearch一贯主张使用api操作,尤其是大集群中),删除snapshot_2:

    1. DELETE http://127.0.0.1:9200/_snapshot/my_backup/snapshot_2

    如果备份正在后台进行,也可以直接删除来取消此次备份。

    4、查看备份信息

    直接使用GET 请求即可:

    1. GET http://127.0.0.1:9200/_snapshot/my_backup/snapshot_2

    返回类似下面的值:

    1. {
    2. "snapshots": [
    3. {
    4. "snapshot": "snapshot_2",
    5. "indices": [
    6. ".marvel_2014_28_10",
    7. "index1",
    8. "index2"
    9. ],
    10. "state": "SUCCESS",
    11. "start_time": "2014-09-02T13:01:43.115Z",
    12. "start_time_in_millis": 1409662903115,
    13. "end_time": "2014-09-02T13:01:43.439Z",
    14. "end_time_in_millis": 1409662903439,
    15. "duration_in_millis": 324,
    16. "failures": [],
    17. "shards": {
    18. "total": 10,
    19. "failed": 0,
    20. "successful": 10
    21. }
    22. }
    23. ]
    24. }

    如果要查看所有索引的信息,使用如下api:

    1. GET http://127.0.0.1:9200/_snapshot/my_backup/_all

    另外还有个一api可以看到更加详细的信息:

    1. GET http://127.0.0.1:9200/_snapshot/my_backup/snapshot_3/_status

    具体不说了,自己玩一下就知道了,详细内容可以查看官方的文档

    恢复

    备份好后,恢复就更容易了,恢复snapshot_1里的全部索引:

    1. POST http://127.0.0.1:9200/_snapshot/my_backup/snapshot_1/_restore

    这个api还有额外的参数:

    1. POST http://127.0.0.1:9200/_snapshot/my_backup/snapshot_1/_restore
    2. {
    3. "indices": "index_1",
    4. "rename_pattern": "index_(.+)",
    5. "rename_replacement": "restored_index_$1"
    6. }

    参数indices 设置只恢复index_1索引,参数rename_pattern 和rename_replacement 用来正则匹配要恢复的索引,并且重命名。和备份一样,api会立刻返回值,然后在后台执行恢复,使用wait_for_completion 标记强制同步执行。

    另外可以使用下面两个api查看状态:

    1. GET http://127.0.0.1:9200/_recovery/restored_index_3
    2. GET http://127.0.0.1:9200/_recovery/

    如果要取消恢复过程(不管是已经恢复完,还是正在恢复),直接删除索引即可:

    1. DELETE http://127.0.0.1:9200/restored_index_3

    更多内容参看官方文档

     
  • 相关阅读:
    景瑞地产商业智能BI整体实施过程
    域名访问和IP访问问题
    sitemesh定义多个装饰器
    8.8.2 EXPLAIN Output Format 优化输出格式
    Python_List对象内置方法详解
    Python_List对象内置方法详解
    Python_序列对象内置方法详解_String
    Python_序列对象内置方法详解_String
    CentOS设置服务开机启动的两种方法
    perl 没有关键文件句柄引起的逻辑错误
  • 原文地址:https://www.cnblogs.com/gaoyuechen/p/8707955.html
Copyright © 2020-2023  润新知