ES将快照仓库创建到ceph

这是在ES6.8.7环境进行的,测试7.6.2也是可以的。

注意:所有的ES节点都需要安装对应版本的repository-s3插件。

步骤一:

提前准备好对象存储,和bukect

"access_key": "xxxxxx"

"secret_key": "xxxxxx"

"bucket":"xxxxxx"

步骤二:

设置访问s3账号密码,根据步骤一中准备好的bukect的access_key, secret_key。

#ACCESS-KEY bin/elasticsearch-keystore add s3.client.ceph.access_key

#SECRET-KEY bin/elasticsearch-keystore add s3.client.ceph.secret_key

在所有es节点设置完keystore后,需要执行下面命令让ES重新加载一下安全配置

curl -u 'elastic:xxxx' -X POST "localhost:9200/_nodes/reload_secure_settings?pretty"

注意:上述命令中的ceph,可以自定义名称。例如:bin/elasticsearch-keystore add s3.client.ceph-test.secret_key 注意这个可自定义的ceph-test,下面仓库注册步骤中需要用到这个设置值。 这里设置为ceph

步骤三:

elastcsearch.yml正常不需要进行设置,但是如果搭建的ceph服务不支持https,只支持http访问,则需要在elasticsearch.yml中进行设置s3.client.ceph.protocol: "http" 此参数,默认为https 此参数如果不设置,ES服务虽然可正常启动,集群可正常使用,但是在进行快照仓库注册和使用时,会报错。

步骤四:

集群中的所有节点(master, data, coo)都需要进行步骤二、三设置,所有节点都需要安装repository-s3插件。

完成以上步骤,集群与ceph的对接算是完成了。下面就可以开始进行仓库注册和数据备份了。每个节点完成上述步骤的设置后,需要重启服务。

步骤五:

注册备份仓库

curl -u elastic:xxxx -XPUT localhost:9200/_snapshot/backup -H 'Content-Type: application/json' -d'

{

"type": "s3",

"settings": {

"client": "ceph", # 这里与上述步骤三中提到的自定义的名称一致

"bucket": "test-backup", ## 已经存在的一个bucket

"protocol": "http",

"endpoint": "192.56.0.162:8080",

"compress":"true",

"base_path": "backup" ## 会在bucket桶下创建出这个backup目录作为ES的快照仓库

}

}'

步骤六:

创建快照

curl -u elastic:xxxx -XPUT localhost:9200/_snapshot/backup/test_snapshot_20211115 -H 'Content-Type: application/json' -d'

{

"indices": "*",

"ignore_unavailable": true,

"include_global_state": false

}'

七、备份所有索引数据。

curl -u elastic:xxxxx -XPUT localhost:9200/_snapshot/backup/snapshot_all_1

{ "indices": "*", "ignore_unavailable": true, "include_global_state": false }

八、查看所有的快照

GET /_snapshot/backup/_all

九、查看当前正在进行的快照信息

curl -u elastic:xxxxx -XGET ocalhost:9200/_snapshot/backup/_current

# 删除快照,可终止正在快照的操作

curl -u elastic:xxxxx -XDELETE localhost:9200/_snapshot/backup/snapshot_all_1

十、快照恢复

# 指定索引进行 restore

curl -u elastic:xxxxx -XPOST localhost:9200/_snapshot/backup/test_snapshot_20211115/_restore -H 'Content-Type: application/json' -d'

{

"indices": "log_login_202109",

"rename_pattern": "log_login_(.+)",

"rename_replacement": "restored_log_login_$1"

}'

每天定时任务执行快照的脚本,you can do it.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值