由于生产环境的控制节点是单点,因此控制节点的备份工作至关重要。

控制节点备份主要包括两块,一块是配置文件的备份,一块是mysql数据库的备份。

    1、数据库mysql的备份。对mysql进行全库备份,备份完成后将备份文件压缩打包传输到另外一台单独的备份服务器上:

    备份openstack的mysql数据库并拷贝到192.168.8.66:/opt/backup/openstack_mysql/目录,其中192.168.8.66是备份服务器的IP地址,请根据实际情况调整。另外需要注意备份服务器的存储空间,选取比较大的文件系统存放,下面是备份脚本:

vim /backup/shell/backupmysql.sh

#!/bin/bash

backup_dir="/backup/mysql"

filename="${backup_dir}/mysql-`hostname`-`eval date +%Y%m%d`.sql.gz"

# Dump the entire MySQL database

/usr/bin/mysqldump --opt --all-databases | gzip > $filename

scp $filename 192.168.8.66:/opt/backup/openstack_mysql/

# Delete backups older than 7 days

find $backup_dir -ctime +7 -type f -delete


       加入定时程序:

crontab -e

0 0 * * * /backup/shell/backupmysql.sh &>/dev/null


    (注意,scp需要建立信任关系,在目的主机的authorized_keys中加入源主机的id_rsa_pub验证码)


    2、备份openstack控制节点的的/etc目录:

vim /backup/shell/backup_etc.sh

#!/bin/bash

backup_dir="/backup/etc"

filename="${backup_dir}/etc-`hostname`-`eval date +%Y%m%d`.gz"

# Dump the entire MySQL database

tar czf $filename /etc

scp $filename 192.168.8.66:/opt/backup/openstack_files/

# Delete backups older than 7 days

find $backup_dir -ctime +7 -type f -delete


    由于控制节点的配置文件不会变更,因此,只需要备份最近一次修改后的etc目录即可。