备份/恢复平台

介绍如何备份平台配置信息,并将其在新环境上进行恢复

备份平台

原理

平台支持通过ocboot进行备份当前系统的配置文件(config.yml)以及使用mysqldump来备份数据库临时文件onecloud.sql并将其压缩。

备份流程

  • 将平台配置文件拷贝到/opt/ocboot
  • 明确备份目标目录;
  • /opt/ocboot目录下执行备份命令;

备份命令

usage: python3 ocboot.py backup [-h] [--backup-path BACKUP_PATH] [--light] config

positional arguments:
  config                config yaml file

optional arguments:
  -h, --help            show this help message and exit
  --backup-path BACKUP_PATH
                        backup path, default: /opt/backup
  --light               ignore yunionmeter and yunionlogger database; ignore
                        tables start with 'opslog' and 'task'.

下面介绍各个参数的作用和注意事项

  • --backup-path保存备份文件的目标目录,备份的内容包括config配置文件,通过mysqldump命令备份的数据库临时文件的压缩包onecloud.sql.tgz,请确保目标目录磁盘空间足够且可写。
  • config是必选参数,即需要备份的配置文件名称,例如config-allinone.yml, config-nodes.yml, config-k8s-ha.yml,以及使用快速安装时会生成的config-allinone-current.yml,因此备份命令不对配置文件名称作假设,需由使用者自行输入配置文件名称
  • --light 这个选项用来做精简备份,原理是在备份过程中,忽略掉一些尺寸较大的特定文件,主要是账单、操作日志等相关的文件。默认保留。
  • 备份后的配置文件名称为config.yml
  • 备份的流程全部采用命令行参数接受输入,备份过程中无交互。因此支持 crontab方式自动备份。但备份程序本身不支持版本 rotate,用户可以使用 logrotate 之类的工具来做备份管理。

举例说明

以iso部署的环境为例介绍如何备份节点到本地的/opt/backup目录。

# 将 `/opt/yunion/upgrade/config.yml`文件拷贝到`/opt/ocboot`目录
$ cp -i /opt/yunion/upgrade/config.yml /opt/ocboot
$ cd /opt/ocboot
# 在`/opt/ocboot`目录执行备份命令,将备份文件保存到`/opt/backup`目录
$ ./ocboot.py backup --backup-path /opt/backup config.yml

FAQ

  • Q: 备份时提示缺MySQLdb 包怎么办?

  • A:在centos上,可以执行如下命令来安装(其他os发行版请酌情修改,或联系客服):

    sudo yum install -y mariadb-devel python3-devel
    sudo yum groupinstall -y "Development Tools"
    sudo pip3 install mysqlclient
    
  • Q: 怎样查看、手工解压备份文件?

  • A:备份文件默认用户名为: /opt/backup/onecloud.sql.gz, 预览、手工解压的方式如下:

    # 预览该文件:
    gunzip --stdout /opt/backup/onecloud.sql.gz | less
    
    # 解压,同时保留源文件:
    gunzip --stdout /opt/backup/onecloud.sql.gz > /opt/backup/onecloud.sql
    
    # 有些高版本的gunzip 提供 -k/--keep 选项,来保存源文件。可以直接执行:
    gunzip -k /opt/backup/onecloud.sql.gz
    

恢复平台

原理

恢复节点即基于上面备份的配置文件和数据库文件恢复到新的节点中,主要包括解压数据库,并根据用户根据新环境生成的配置文件重新安装环境。

恢复流程

  • 参考config.yml配置文件准备新环境,节点数需保持一致;
  • 将备份文件拷贝到新环境。
  • 在新环境中配置ocboot工具;
  • 使用ocboot restore命令恢复环境。

恢复命令

usage: ocboot.py restore [-h] [--backup-path BACKUP_PATH]
                         [--install-db-to-localhost]
                         [--master-node-ips MASTER_NODE_IPS]
                         [--master-node-as-host]
                         [--worker-node-ips WORKER_NODE_IPS]
                         [--worker-node-as-host] [--mysql-host MYSQL_HOST]
                         [--mysql-user MYSQL_USER]
                         [--mysql-password MYSQL_PASSWORD]
                         [--mysql-port MYSQL_PORT]
                         primary_ip
positional arguments:
  primary_ip            primary node ip
optional arguments:
  -h, --help            show this help message and exit
  --backup-path BACKUP_PATH
                        backup path, default=/opt/backup
  --install-db-to-localhost
                        use this option when install local db
  --master-node-ips MASTER_NODE_IPS
                        master nodes ips, seperated by comma ','
  --master-node-as-host
                        use this option when use master nodes as host
  --worker-node-ips WORKER_NODE_IPS
                        worker nodes ips, seperated by comma ','
  --worker-node-as-host
                        use this option when use worker nodes as host
  --mysql-host MYSQL_HOST
                        mysql host; not needed if set --install-db-to-
                        localhost
  --mysql-user MYSQL_USER
                        mysql user, default: root; not needed if set
                        --install-db-to-localhost
  --mysql-password MYSQL_PASSWORD
                        mysql password; not needed if set --install-db-to-
                        localhost
  --mysql-port MYSQL_PORT
                        mysql port, default: 3306; not needed if set
                        --install-db-to-localhost
  • primary_ip为必填项,即新环境的IP地址。
  • --backup-path 备份文件所在目录,不填,默认值为/opt/backup目录。
  • --install-db-to-localhost 如需要在本机(primary节点)安装数据库(mariadb-server稳定版),则添加该参数,并自动赋予下面参数默认值
    --mysql-host=127.0.0.1
    --mysql-user=root
    --mysql-password=<继承备份文件里 mysql 的密码>
    --mysql-port=3306
    
  • --mysql-host及其他同类选项:如使用已有数据库则需要配置相关参数。注意--install-db-to-localhost参数与--mysql-*参数互斥。
  • --master-node-ips 同时安装master 节点,如存在多个master节点。该参数是以半角逗号分隔的 ip 列表。适用于多节点模式。
  • --master-node-as-host 安装控制节点master-node时,将其作为host 节点。
  • --worker-node-ips--worker-node-as-host,安装计算节点worker-node,将其作为host 节点。

举例说明

以一个控制节点master node(IP:10.127.190.228)和一个计算节点work node(IP:10.127.190.219)为例,介绍如何基于备份文件恢复到新环境。

  1. 根据备份文件config.yml文件部署新环境,节点数需保持一致。
  2. 将备份文件拷贝到新环境。
# 在备份文件所在服务器将备份文件拷贝到新环境下的`/opt/backup`目录
$ scp /opt/backup/* root@<新环境IP地址>:/opt/backup

  1. 在新环境上配置控制节点master node可以免密登录到计算节点work node
# 在控制节点`master node`上生成ssh密钥
$ ssh-keygen
# 将生成的~/.ssh/id_rsa.pub 公钥拷贝到计算节点`work node`
$ ssh-copy-id -i ~/.ssh/id_rsa.pub root@10.127.190.219
# 在控制节点`master node`上尝试免密登录,获取计算节点的名称
$ ssh root@10.127.190.219 "hostname"
# 免密登录控制节点
$ ssh-copy-id 10.127.190.228
  1. 根据新环境的IP信息修改config.yml文件,修改当前机器 ip、worker node ips、master node ips,生成新的config.yml配置文件。
  2. 部署ocboot服务
# 在`master`节点上安装ansible,以centos为例
# 安装pip
$ yum -y install python3-pip
$ python3 -m pip install --upgrade pip setuptools wheel
$ python3 -m pip install --upgrade ansible
# 拉取ocboot代码
$ git clone https://github.com/yunionio/ocboot.git
$ cd ./ocboot & pip install -r ./requirements.txt
  1. 通过ocboot工具的restore命令恢复节点。
# 在ocboot目录下执行`restore`命令
$ ./ocboot.py restore --backup-path /opt/backup --install-db-to-localhost --master-node-ips 10.127.190.228 --master-node-as-host --worker-node-ips 10.127.190.219 --worker-node-as-host 10.127.190.228

  1. 数据库恢复完成后,根据配置文件恢复平台。
$ /root/ocboot/run.py /root/ocboot/config.yml